mysqli對prepare的支持對于大訪問量的網(wǎng)站是很有好處的,它極大地降低了系統(tǒng)開銷,而且保證了創(chuàng)建查詢的穩(wěn)定性和安全性。prepare準(zhǔn)備語句分為綁定參數(shù)和綁定結(jié)果,下面將會(huì)一一介紹!
(1)綁定參數(shù)
看下面php代碼:
//創(chuàng)建連接
$mysqli=new mysqli("localhost","root","","volunteer");
//檢查連接是否被創(chuàng)建
if (mysqli_connect_errno()) {
printf("Connect failed: %s/n", mysqli_connect_error());
exit();
}
/*
* 創(chuàng)建一個(gè)準(zhǔn)備查詢語句:
* ?是個(gè)通配符,可以用在任何有文字的數(shù)據(jù)
* 相當(dāng)于一個(gè)模板,也就是預(yù)備sql語句
*/
if ($stmt = $mysqli->prepare("insert into `vol_msg`(mid,content) values(?,?)")){
/*第一個(gè)參數(shù)是綁定類型,"s"是指一個(gè)字符串,也可以是"i",指的是int。也可以是"db",
* d代表雙精度以及浮點(diǎn)類型,而b代表blob類型,第二個(gè)參數(shù)是變量
*/
$stmt->bind_param("is",$id,$content);
//給變量賦值
$id = "";
$content = "這是插入的內(nèi)容";
//執(zhí)行準(zhǔn)備語句
$stmt->execute();
//顯示插入的語句
echo "Row inserted".$stmt->affected_rows;
//下面還可以繼續(xù)添加多條語句,不需要prepare預(yù)編譯了
//關(guān)閉數(shù)據(jù)庫的鏈接
$mysqli->close();
}
?>
以上php實(shí)例運(yùn)行結(jié)果:
Row inserted:1
(2).綁定結(jié)果:綁定結(jié)果就是將你綁定的字段給php變量,以便必要時(shí)使用這些變量
請看下面的php代碼:
//創(chuàng)建連接
$mysqli=new mysqli("localhost","root","","volunteer");
//設(shè)置mysqli編碼
mysqli_query($mysqli,"SET NAMES utf8");
//檢查連接是否被創(chuàng)建
if (mysqli_connect_errno()) {
printf("Connect failed: %s/n", mysqli_connect_error());
exit();
}
//創(chuàng)建準(zhǔn)備語句
if ($stmt = $mysqli->prepare("select mid,content from `vol_msg`")){
//執(zhí)行查詢
$stmt->execute();
//為準(zhǔn)備語句綁定實(shí)際變量
$stmt->bind_result($id,$content);
//顯示綁定結(jié)果的變量
while($stmt->fetch()){
echo "第".$id."條: ".$content."
";
}
//關(guān)閉數(shù)據(jù)庫的鏈接
$mysqli->close();
}
?>
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com