/* bind result variables */

成都創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),惠濟(jì)企業(yè)網(wǎng)站建設(shè),惠濟(jì)品牌網(wǎng)站建設(shè),網(wǎng)站定制,惠濟(jì)網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,惠濟(jì)網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
$sqlmb-bind_result($result);
/* fetch values */
while ($sqlmb-fetch()) {
var_dump($result);
}
bind_result 才是取的
預(yù)處理語句與存儲過程 :
很多更成熟的數(shù)據(jù)庫都支持預(yù)處理語句的概念。什么是預(yù)處理語句?可以把它看作是想要運(yùn)行的 SQL 的一種編譯過的模板,它可以使用變量參數(shù)進(jìn)行定制。預(yù)處理語句可以帶來兩大好處:
查詢僅需解析(或預(yù)處理)一次,但可以用相同或不同的參數(shù)執(zhí)行多次。當(dāng)查詢準(zhǔn)備好后,數(shù)據(jù)庫將分析、編譯和優(yōu)化執(zhí)行該查詢的計(jì)劃。對于復(fù)雜的查詢,此過程要花費(fèi)較長的時(shí)間,如果需要以不同參數(shù)多次重復(fù)相同的查詢,那么該過程將大大降低應(yīng)用程序的速度。通過使用預(yù)處理語句,可以避免重復(fù)分析/編譯/優(yōu)化周期。簡言之,預(yù)處理語句占用更少的資源,因而運(yùn)行得更快。
提供給預(yù)處理語句的參數(shù)不需要用引號括起來,驅(qū)動程序會自動處理。如果應(yīng)用程序只使用預(yù)處理語句,可以確保不會發(fā)生SQL 注入。(然而,如果查詢的其他部分是由未轉(zhuǎn)義的輸入來構(gòu)建的,則仍存在 SQL 注入的風(fēng)險(xiǎn))。
預(yù)處理語句如此有用,以至于它們唯一的特性是在驅(qū)動程序不支持的時(shí)PDO 將模擬處理。這樣可以確保不管數(shù)據(jù)庫是否具有這樣的功能,都可以確保應(yīng)用程序可以用相同的數(shù)據(jù)訪問模式。
Example #1 用預(yù)處理語句進(jìn)行重復(fù)插入
下面例子通過用?name?和?value?替代相應(yīng)的命名占位符來執(zhí)行一個(gè)插入查詢
?php
$stmt?=?$dbh-prepare("INSERT?INTO?REGISTRY?(name,?value)?VALUES?(:name,?:value)");
$stmt-bindParam(':name',?$name);
$stmt-bindParam(':value',?$value);
//?插入一行
$name?=?'one';
$value?=?1;
$stmt-execute();
//??用不同的值插入另一行
$name?=?'two';
$value?=?2;
$stmt-execute();
?
Example #2 用預(yù)處理語句進(jìn)行重復(fù)插入
下面例子通過用?name?和?value?取代???占位符的位置來執(zhí)行一條插入查詢。
?php
$stmt?=?$dbh-prepare("INSERT?INTO?REGISTRY?(name,?value)?VALUES?(?,??)");
$stmt-bindParam(1,?$name);
$stmt-bindParam(2,?$value);
//?插入一行
$name?=?'one';
$value?=?1;
$stmt-execute();
//?用不同的值插入另一行
$name?=?'two';
$value?=?2;
$stmt-execute();
?
Example #3 使用預(yù)處理語句獲取數(shù)據(jù)
下面例子獲取數(shù)據(jù)基于鍵值已提供的形式。用戶的輸入被自動用引號括起來,因此不會有 SQL 注入攻擊的危險(xiǎn)。
?php
$stmt?=?$dbh-prepare("SELECT?*?FROM?REGISTRY?where?name?=??");
if?($stmt-execute(array($_GET['name'])))?{
while?($row?=?$stmt-fetch())?{
print_r($row);
}
}
?
如果數(shù)據(jù)庫驅(qū)動支持,應(yīng)用程序還可以綁定輸出和輸入?yún)?shù).輸出參數(shù)通常用于從存儲過程獲取值。輸出參數(shù)使用起來比輸入?yún)?shù)要稍微復(fù)雜一些,因?yàn)楫?dāng)綁定一個(gè)輸出參數(shù)時(shí),必須知道給定參數(shù)的長度。如果為參數(shù)綁定的值大于建議的長度,就會產(chǎn)生一個(gè)錯誤。
Example #4 帶輸出參數(shù)調(diào)用存儲過程
?php
$stmt?=?$dbh-prepare("CALL?sp_returns_string(?)");
$stmt-bindParam(1,?$return_value,?PDO::PARAM_STR,?4000);?
//?調(diào)用存儲過程
$stmt-execute();
print?"procedure?returned?$return_value\n";
?
還可以指定同時(shí)具有輸入和輸出值的參數(shù),其語法類似于輸出參數(shù)。在下一個(gè)例子中,字符串“hello”被傳遞給存儲過程,當(dāng)存儲過程返回時(shí),hello 被替換為該存儲過程返回的值。
Example #5 帶輸入/輸出參數(shù)調(diào)用存儲過程
?php
$stmt?=?$dbh-prepare("CALL?sp_takes_string_returns_string(?)");
$value?=?'hello';
$stmt-bindParam(1,?$value,?PDO::PARAM_STR|PDO::PARAM_INPUT_OUTPUT,?4000);?
//?調(diào)用存儲過程
$stmt-execute();
print?"procedure?returned?$value\n";
?
Example #6 占位符的無效使用
?php
$stmt?=?$dbh-prepare("SELECT?*?FROM?REGISTRY?where?name?LIKE?'%?%'");
$stmt-execute(array($_GET['name']));
//?占位符必須被用在整個(gè)值的位置
$stmt?=?$dbh-prepare("SELECT?*?FROM?REGISTRY?where?name?LIKE??");
$stmt-execute(array("%$_GET[name]%"));
?
我覺得你好像用錯了,你這樣寫難道不會報(bào)錯的嗎?
用 prepare 有五步:
prepqre
bind_param
execute
bind_result
fetch
既然是查詢就會有結(jié)果,你要先把結(jié)果綁定在參數(shù)上接收,然后fetch才有用。
另外執(zhí)行一次 fetch() 只返回一個(gè)結(jié)果,如果你有多條結(jié)果要放在一個(gè)循環(huán)里 fetch()。
php 官網(wǎng)的文檔里有詳細(xì)的介紹和代碼示例,你可以去看看,還有不明白可以繼續(xù)問我
先配置數(shù)據(jù)庫------連接數(shù)據(jù)庫--------選擇數(shù)據(jù)庫--------填寫檢索表-------輸出檢索內(nèi)容
第一種解決方法:
一、配置一下數(shù)據(jù)庫:
define("DB_HOST","localhost");//數(shù)據(jù)庫地址,一般為localhost
define("DB_USER","root");//數(shù)據(jù)庫用戶名
define("DB_PSW","");//數(shù)據(jù)庫密碼
define("DB_DB","databasename");//需要操作的數(shù)據(jù)庫
二、連接數(shù)據(jù)庫:
$conn = mysql_connect(DB_HOST,DB_USER,DB_PSW) or die
三、選擇數(shù)據(jù)庫:
mysql_select_db(DB_DB,$conn) or die
四、檢索表:(填寫tablename)
$result = mysql_query("select * from tablename") or die
五、輸出檢索的內(nèi)容:
while ($row = mysql_fetch_row($result)){foreach($row as $data){ ? ?echo $data.' ';} ? ?echo 'br。
新聞標(biāo)題:php預(yù)處理讀取數(shù)據(jù),php怎么讀取數(shù)據(jù)庫
URL分享:http://chinadenli.net/article33/dsgssps.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、標(biāo)簽優(yōu)化、網(wǎng)站策劃、網(wǎng)站營銷、品牌網(wǎng)站建設(shè)、網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)