PHP5中使用mysqli的prepare操作數(shù)據(jù)庫的介紹
php5中有了mysqli對prepare的支持,對于大訪問量的網(wǎng)站是很有好處的,極大地降低了系統(tǒng)開銷,而且保證了創(chuàng)建查詢的穩(wěn)定性和安全性。
PHP5.0后我們可以使用mysqli,mysqli對prepare的支持對于大訪問量的網(wǎng)站是很有好處的,特別是事務(wù)的支持,在大查詢量的時(shí)候?qū)O大地降低了系統(tǒng)開銷,而且保證了創(chuàng)建查詢的穩(wěn)定性和安全性,能有效地防止SQL注入攻擊。
prepare準(zhǔn)備語句分為綁定參數(shù)和綁定結(jié)果兩種。接下來具體介紹。
1、綁定參數(shù)
看下面php代碼:
<?php
//創(chuàng)建連接
$mysqli=new mysqli("localhost","root","","123456");
//檢查連接是否被創(chuàng)建
if (mysqli_connect_errno()) {
printf("Connect failed: %s\n", mysqli_connect_error());
exit();
}
/**
* 創(chuàng)建一個準(zhǔn)備查詢語句:
* ?是個通配符,可以用在任何有文字的數(shù)據(jù)
* 相當(dāng)于一個模板,也就是預(yù)備sql語句
*/
if ($stmt = $mysqli->prepare("insert into `codetc_msg`(mid,content) values(?,?)")){
/**
* 第一個參數(shù)是綁定類型,"is"是指上面SQL語句中第一個?參數(shù)是int類型,第二個?參數(shù)是string類型
* 其中i指int,s指string, 除了i、s之外還有d代表雙精度浮點(diǎn)型,b代表blod類型等
*/
$stmt->bind_param("is",$id,$content);
//給變量賦值
$id = 1;
$content = "這是插入的內(nèi)容";
//執(zhí)行準(zhǔn)備語句
$stmt->execute();
//顯示插入的影響行數(shù)
echo "Row inserted".$stmt->affected_rows;
//關(guān)閉數(shù)據(jù)庫的鏈接
$mysqli->close();
}
?>
2、綁定結(jié)果:綁定結(jié)果就是將你綁定的字段給php變量,以便必要時(shí)使用這些變量
請看下面的php代碼:
<?php
//創(chuàng)建連接
$mysqli=new mysqli("localhost","root","","123456");
//設(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 `codetc_msg`")){
//執(zhí)行查詢
$stmt->execute();
//為準(zhǔn)備語句綁定實(shí)際變量
$stmt->bind_result($id,$content);
//顯示綁定結(jié)果的變量
while($stmt->fetch()){
echo "第".$id."條: ".$content."<br>";
}
//關(guān)閉數(shù)據(jù)庫的鏈接
$mysqli->close();
}
?>
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
- PHP PDO預(yù)處理語句及事務(wù)的使用
- PHP的PDO預(yù)處理語句與存儲過程
- php_pdo 預(yù)處理語句詳解
- PHP封裝類似thinkphp連貫操作數(shù)據(jù)庫Db類與簡單應(yīng)用示例
- php pdo操作數(shù)據(jù)庫示例
- PHP入門教程之使用Mysqli操作數(shù)據(jù)庫的方法(連接,查詢,事務(wù)回滾等)
- PHP使用PDO操作數(shù)據(jù)庫的亂碼問題解決方法
- PHP中使用匿名函數(shù)操作數(shù)據(jù)庫的例子
- PHP中的MYSQL常用函數(shù)(php下操作數(shù)據(jù)庫必備)
- php 使用預(yù)處理語句操作數(shù)據(jù)庫
相關(guān)文章
PHP針對常規(guī)模板引擎中與CSS/JSON沖突的解決方法
這篇文章主要介紹了PHP針對常規(guī)模板引擎中與CSS/JSON沖突的解決方法,非常實(shí)用的技巧,需要的朋友可以參考下2014-08-08
PHP中addcslashes與stripcslashes函數(shù)用法分析
這篇文章主要介紹了PHP中addcslashes與stripcslashes函數(shù)用法,結(jié)合實(shí)例形式分析了addcslashes函數(shù)添加針對固定字符的轉(zhuǎn)義處理與stripcslashes進(jìn)行還原操作相關(guān)技巧,需要的朋友可以參考下2016-01-01
PHP實(shí)現(xiàn)普通和定時(shí)跳轉(zhuǎn)的幾種方式
這篇文章主要為大家詳細(xì)介紹了PHP實(shí)現(xiàn)普通和定時(shí)跳轉(zhuǎn)的幾種方式,文章通過代碼示例介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的小伙伴可以參考下2023-11-11
php實(shí)現(xiàn)用手機(jī)關(guān)閉計(jì)算機(jī)(電腦)的方法
這篇文章主要介紹了php實(shí)現(xiàn)用手機(jī)關(guān)閉計(jì)算機(jī)(電腦)的方法,涉及php使用system方法調(diào)用系統(tǒng)命令的相關(guān)技巧,需要的朋友可以參考下2015-04-04
采用PHP函數(shù)memory_get_usage獲取PHP內(nèi)存清耗量的方法
PHP性能優(yōu)化過程中需要獲取PHP內(nèi)存消耗,使用memory_get_usage()函數(shù)可獲取當(dāng)前的內(nèi)存消耗情況,函數(shù)使用簡單,這里討論一下memory_get_usage()函數(shù)的用法與實(shí)例2011-12-12
php安裝php_rar擴(kuò)展實(shí)現(xiàn)rar文件讀取和解壓的方法
這篇文章主要介紹了php安裝php_rar擴(kuò)展實(shí)現(xiàn)rar文件讀取和解壓的方法,涉及php擴(kuò)展組件的安裝與使用相關(guān)操作技巧,需要的朋友可以參考下2016-11-11
PHP中mb_convert_encoding與iconv函數(shù)的深入解析
本篇文章是對PHP中mb_convert_encoding與iconv函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06

