這篇文章主要介紹了帝國(guó)CMS下在PHP文件中調(diào)用數(shù)據(jù)庫(kù)類(lèi)執(zhí)行SQL語(yǔ)句實(shí)例,本文還詳細(xì)介紹了帝國(guó)CMS數(shù)據(jù)庫(kù)類(lèi)中的一些常用方法,需要的朋友可以參考下
例1:連接MYSQL數(shù)據(jù)庫(kù)例子。(a.php)
<?phprequire('e/class/connect.php'); //引入數(shù)據(jù)庫(kù)配置文件和公共函數(shù)文件require('e/class/db_sql.php'); //引入數(shù)據(jù)庫(kù)操作文件$link=db_connect(); //連接MYSQL$empire=new mysqlquery(); //聲明數(shù)據(jù)庫(kù)操作類(lèi)</p> <p>db_close(); //關(guān)閉MYSQL鏈接$empire=null; //注消操作類(lèi)變量?>
例2:更新數(shù)據(jù)例子。(b.php)
<?phprequire('e/class/connect.php'); //引入數(shù)據(jù)庫(kù)配置文件和公共函數(shù)文件require('e/class/db_sql.php'); //引入數(shù)據(jù)庫(kù)操作文件$link=db_connect(); //連接MYSQL$empire=new mysqlquery(); //聲明數(shù)據(jù)庫(kù)操作類(lèi)</p> <p>$empire->query("update {$dbtbpre}ecms_news set onclick=onclick+1"); //給新聞表的點(diǎn)擊數(shù)加1</p> <p>db_close(); //關(guān)閉MYSQL鏈接$empire=null; //注消操作類(lèi)變量?>
例3:查詢(xún)MYSQL數(shù)據(jù)的例子。(c.php)
<?phprequire('e/class/connect.php'); //引入數(shù)據(jù)庫(kù)配置文件和公共函數(shù)文件require('e/class/db_sql.php'); //引入數(shù)據(jù)庫(kù)操作文件$link=db_connect(); //連接MYSQL$empire=new mysqlquery(); //聲明數(shù)據(jù)庫(kù)操作類(lèi)</p> <p>$sql=$empire->query("select * from {$dbtbpre}ecms_news order by newstime limit 10"); //查詢(xún)新聞表最新10條記錄while($r=$empire->fetch($sql)) //循環(huán)獲取查詢(xún)記錄{echo"標(biāo)題:".$r['title']."";}</p> <p>db_close(); //關(guān)閉MYSQL鏈接$empire=null; //注消操作類(lèi)變量?>
/e/class/db_sql.php文件中數(shù)據(jù)庫(kù)操作類(lèi)常用的函數(shù)說(shuō)明:
1、執(zhí)行SQL函數(shù):
$empire->query("SQL語(yǔ)句");$empire->query1("SQL語(yǔ)句");
說(shuō)明:
執(zhí)行成功返回true,執(zhí)行不成功返回false ;
兩者區(qū)別是:query()出錯(cuò)直接中斷程序執(zhí)行,query1()出錯(cuò)不中斷程序執(zhí)行。
使用范例:
$sql=$empire->query("select * from {$dbtbpre}ecms_news");
2、循環(huán)讀取數(shù)據(jù)庫(kù)記錄函數(shù):
$empire->fetch($sql)
說(shuō)明:
$sql為query執(zhí)行SQL返回的結(jié)果。
使用范例:
$sql=$empire->query("select * from {$dbtbpre}ecms_news");while($r=$empire->fetch($sql)){echo"標(biāo)題:".$r['title']."";}
3、讀取單條數(shù)據(jù)庫(kù)記錄函數(shù):(不循環(huán))
$empire->fetch1("SQL語(yǔ)句")
使用范例:
$r=$empire->fetch1("select * from {$dbtbpre}ecms_news where id=1");echo"標(biāo)題:".$r['title'];
4、統(tǒng)計(jì)SQL查詢(xún)記錄數(shù)函數(shù):
復(fù)制代碼代碼如下:$empire->num("SQL語(yǔ)句")$empire->num1($sql)
說(shuō)明:
兩者的區(qū)別是:num()直接寫(xiě)SQL語(yǔ)句,而num1()中的$sql為query執(zhí)行SQL返回的結(jié)果。
使用范例:
$num=$empire->num("select id from {$dbtbpre}ecms_news");echo"新聞表共有 ".$num." 條新聞";
5、統(tǒng)計(jì)SQL查詢(xún)記錄數(shù)函數(shù)2:(相對(duì)于num更高效的函數(shù))
$empire->gettotal("統(tǒng)計(jì)SQL語(yǔ)句");
說(shuō)明:
gettotal()和num()的區(qū)別是:gettotal()采用SQL本身的count(*)函數(shù)來(lái)統(tǒng)計(jì),而num()是采用PHP本身的函數(shù),gettotal()更高效一些。
gettotal()里的統(tǒng)計(jì)數(shù)一定要as total,如:“count(*) as total”。
使用范例:
$num=$empire->gettotal("select count(*) as total from {$dbtbpre}ecms_news");echo"新聞表共有 ".$num." 條新聞";
6、取得剛插入表的自增ID值函數(shù):
$empire->lastid()
使用范例:
$empire->query("insert into {$dbtbpre}ecms_news(title) values('標(biāo)題')");$lastid=$empire->lastid();echo"剛插入的信息ID為:".$lastid;
7、移動(dòng)SQL查詢(xún)結(jié)果記錄指針:
$empire->seek($sql,$pit)
說(shuō)明:
$sql為query執(zhí)行SQL返回的結(jié)果,$pit為指針的偏移數(shù)。
使用范例:
$sql=$empire->query("select * from {$dbtbpre}ecms_news");$empire->seek($sql,2);
8、釋放SQL查詢(xún)結(jié)果函數(shù):(一般不需要使用)
$empire->free($sql)
說(shuō)明:
$sql為query執(zhí)行SQL返回的結(jié)果。
使用范例:
$sql=$empire->query("select * from {$dbtbpre}ecms_news");$empire->free($sql);
導(dǎo)航查詢(xún)例子:
<DIV class=news_dh "color:#000000"></p> <p><!--主欄目導(dǎo)航,此模板中直接指定為classid=69,即法律法規(guī)欄目-->[e:loop={"select classid,classname,classpath from [!db.pre!]enewsclass where classid='69' and showclass=0 order by myorder ",0,24,0}]<span><a href="<?=$public_r[newsurl]?><?=$bqr[classpath]?>" ><?=$bqr[classname]?></a></span> <SPAN><IMGsrc="[!--news.url--]skin/tx/zixun/images/index_line_nav.gif"></SPAN>[/e:loop]</p> <p> </p> <p><!--子欄目導(dǎo)航-->[e:loop={"select classid,classname,classpath from [!db.pre!]enewsclass where bclassid='69' and showclass=0 order by myorder ",0,24,0}]<?$lanmuclass= "lanmu";//echo $bqr[classid] ;//echo "cur:".$GLOBALS[navclassid];if ( $bqr[classid]==$GLOBALS[navclassid]) {//echo "-";$lanmuclass ="curlanmu";}?></p> <p><span class="<?=$lanmuclass?>"><a href="<?=$public_r[newsurl]?><?=$bqr[classpath]?>" ><?=$bqr[classname]?></a></span> <SPAN><IMGsrc="[!--news.url--]skin/tx/zixun/images/index_line_nav.gif"></SPAN></p> <p>[/e:loop]</p> <p><!--新聞導(dǎo)航結(jié)束--></DIV>
新聞熱點(diǎn)
疑難解答
圖片精選