mysqli預(yù)處理編譯的深入理解
記得以前php點點通也寫過mysqli的預(yù)處理的php教程,那時候只是看書亂寫的,沒懂原理,數(shù)月過后,突然明白了很多:
想想看。假如我們要插入很多1000個用戶,你怎么做,for循環(huán)?還是mysqli處理多條sql? no!這些處理很慢的,php里面有很多操作mysql數(shù)據(jù)庫的函數(shù),無非是把sql語句傳遞給mysql數(shù)據(jù)庫,真正處理sql語句的是mysql,mysql數(shù)據(jù)庫是要編譯sql語句進(jìn)行執(zhí)行的,上面這兩種操作會對相同的sql語句進(jìn)行多次編譯,有這必要嗎?程序員總是很聰明的,于是有了mysqli預(yù)處理技術(shù)!mysqli還能防止sql注入攻擊!
看看下面這個預(yù)編譯代碼:
<?php
//創(chuàng)建連接
$mysqli=new mysqli("localhost","root","","test");
//設(shè)置mysqli編碼
mysqli_query($mysqli,"SET NAMES utf8");
//檢查連接是否被創(chuàng)建
if (mysqli_connect_errno()) {
printf("Connect failed:".mysqli_connect_error());
exit();
}
//創(chuàng)建準(zhǔn)備語句
$stmt = $mysqli->prepare("select id,username from `user` where `id` > ?");
/*************************************************************/
$id=5;
//綁定參數(shù)
$stmt->bind_param("i",$id);
//綁定結(jié)果集
$stmt->bind_result($id,$username);
//執(zhí)行查詢
$stmt->execute();
//顯示綁定結(jié)果的變量
while($stmt->fetch()){
echo "第".$id."個用戶: ".$username."<br />";
}
/**************************************************************/
/*www.phpddt.com為你提示:上面*之間的內(nèi)容可以重復(fù)執(zhí)行類似功能,不需要再次編譯了*/
//釋放結(jié)果
$stmt->free_result();
//關(guān)閉編譯語句
$stmt->close();
//關(guān)閉數(shù)據(jù)庫的鏈接
$mysqli->close();
?>
相關(guān)文章
MySQL-MMM安裝指南(Multi-Master Replication Manager for MySQL)
這篇文章主要介紹了mysql Multi-Master Replication Manager for MySQL的安裝方法,需要的朋友可以參考下2014-02-02
如何解決MYSQL8.4.1 MySQL84--ERROR 1524(HY000):Plugin&n
這篇文章主要介紹了如何解決MYSQL8.4.1 MySQL84--ERROR 1524(HY000):Plugin ‘msql_native_password‘ is not loaded問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
MySQL分表自動化創(chuàng)建的實現(xiàn)方案
在數(shù)據(jù)庫應(yīng)用場景中,隨著數(shù)據(jù)量的不斷增長,單表存儲數(shù)據(jù)可能會面臨性能瓶頸,例如查詢、插入、更新等操作的效率會逐漸降低,分表是一種有效的優(yōu)化策略,它將數(shù)據(jù)分散存儲在多個表中,從而提高數(shù)據(jù)庫的性能和可維護(hù)性,本文介紹了MySQL分表自動化創(chuàng)建的實現(xiàn)方案2025-01-01
使用Grafana+Prometheus監(jiān)控mysql服務(wù)性能
這篇文章主要介紹了使用Grafana+Prometheus監(jiān)控mysql服務(wù)性能的相關(guān)知識,本文給大家介紹的非常詳細(xì),對大家的工作或?qū)W習(xí)具有一定的參考借鑒價值,需要的朋友可以參考下方法2020-03-03
MySQL優(yōu)化案例系列-mysql分頁優(yōu)化
這篇文章主要介紹了MySQL優(yōu)化案例系列-mysql分頁優(yōu)化,需要的朋友可以參考下2016-08-08
mySQL count多個表的數(shù)據(jù)實例詳解
這篇文章通過實例給大家介紹了mySQL中count多個表的數(shù)據(jù),也就是多個表如何聯(lián)合查詢,文中通過項目中遇到的一個問題進(jìn)行分析和實現(xiàn),給出了詳細(xì)的示例代碼,相信對大家的理解和學(xué)習(xí)很有幫助,有需要的朋友們下面來一起看看吧。2016-11-11
windows下mysql?8.0.27?安裝配置方法圖文教程
這篇文章主要為大家詳細(xì)介紹了windows下mysql?8.0.27?安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04

