PHP5 mysqli的prepare準備語句使用說明
更新時間:2012年12月06日 17:34:11 作者:
mysqli對prepare的支持對于大訪問量的網(wǎng)站是很有好處的,它極大地降低了系統(tǒng)開銷,而且保證了創(chuàng)建查詢的穩(wěn)定性和安全性.prepare準備語句分為綁定參數(shù)和綁定結(jié)果
mysqli對prepare的支持對于大訪問量的網(wǎng)站是很有好處的,它極大地降低了系統(tǒng)開銷,而且保證了創(chuàng)建查詢的穩(wěn)定性和安全性。prepare準備語句分為綁定參數(shù)和綁定結(jié)果,下面將會一一介紹!
(1)綁定參數(shù)
看下面php代碼:
復(fù)制代碼 代碼如下:
<?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)建一個準備查詢語句:
* ?是個通配符,可以用在任何有文字的數(shù)據(jù)
* 相當于一個模板,也就是預(yù)備sql語句
*/
if ($stmt = $mysqli->prepare("insert into `vol_msg`(mid,content) values(?,?)")){
/*第一個參數(shù)是綁定類型,"s"是指一個字符串,也可以是"i",指的是int。也可以是"db",
* d代表雙精度以及浮點類型,而b代表blob類型,第二個參數(shù)是變量
*/
$stmt->bind_param("is",$id,$content);
//給變量賦值
$id = "";
$content = "這是插入的內(nèi)容";
//執(zhí)行準備語句
$stmt->execute();
//顯示插入的語句
echo "Row inserted".$stmt->affected_rows;
//下面還可以繼續(xù)添加多條語句,不需要prepare預(yù)編譯了
//關(guān)閉數(shù)據(jù)庫的鏈接
$mysqli->close();
}
?>
以上php實例運行結(jié)果:
Row inserted:1
(2).綁定結(jié)果:綁定結(jié)果就是將你綁定的字段給php變量,以便必要時使用這些變量
請看下面的php代碼:
復(fù)制代碼 代碼如下:
<?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)建準備語句
if ($stmt = $mysqli->prepare("select mid,content from `vol_msg`")){
//執(zhí)行查詢
$stmt->execute();
//為準備語句綁定實際變量
$stmt->bind_result($id,$content);
//顯示綁定結(jié)果的變量
while($stmt->fetch()){
echo "第".$id."條: ".$content."<br />";
}
//關(guān)閉數(shù)據(jù)庫的鏈接
$mysqli->close();
}
?>
您可能感興趣的文章:
- ubuntu14.04LTS安裝nginx+mariaDB+php7+YAF的方法
- 在Mac OS上編譯安裝Nginx+PHP+MariaDB開發(fā)環(huán)境的教程
- CentOS 7 x64下Apache+MySQL(Mariadb)+PHP56的安裝教程詳解
- php開啟mysqli擴展之后如何連接數(shù)據(jù)庫
- php使用mysqli向數(shù)據(jù)庫添加數(shù)據(jù)的方法
- php封裝的mysqli類完整實例
- php中數(shù)據(jù)庫連接方式pdo和mysqli對比分析
- PHP以mysqli方式連接類完整代碼實例
- PHP使用mysqli擴展連接MySQL數(shù)據(jù)庫
- PHP+MariaDB數(shù)據(jù)庫操作基本技巧備忘總結(jié)
相關(guān)文章
小白安裝登錄mysql-8.0.19-winx64的教程圖解(新手必看)
這篇文章主要介紹了安裝登錄mysql-8.0.19-winx64的教程圖解,非常適合新手學(xué)習(xí)參考,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03mysql 獲取昨天日期、今天日期、明天日期以及前一個小時和后一個小時的時間
這篇文章主要介紹了mysql 獲取昨天日期、今天日期、明天日期以及前一個小時和后一個小時的時間,需要的朋友可以參考下2018-01-01MySQL與PHP的基礎(chǔ)與應(yīng)用專題之數(shù)據(jù)完整性
MySQL是一個關(guān)系型數(shù)據(jù)庫管理系統(tǒng),由瑞典MySQL?AB?公司開發(fā),屬于?Oracle?旗下產(chǎn)品。MySQL?是最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)之一,本系列將帶你掌握php與mysql的基礎(chǔ)應(yīng)用,本篇從數(shù)據(jù)完整性開始2022-02-02mysql性能優(yōu)化腳本mysqltuner.pl使用介紹
無意中發(fā)現(xiàn)了,major哥們開發(fā)的一個性能分析腳本,很有意思,可以通過這個腳本學(xué)學(xué)他的思想2013-02-02