ホームページ >バックエンド開発 >PHPチュートリアル >PHP で mysqli のプリペアド ステートメントを使用してデータベース内のデータ (バインド パラメーターまたはバインド結果) をクエリできないのはなぜですか? プロジェクトが緊急に必要です。

PHP で mysqli のプリペアド ステートメントを使用してデータベース内のデータ (バインド パラメーターまたはバインド結果) をクエリできないのはなぜですか? プロジェクトが緊急に必要です。

WBOY
WBOYオリジナル
2016-06-13 12:53:12934ブラウズ

PHP で mysqli のプリペアド ステートメントを使用してデータベース内のデータ (バインド パラメーターまたはバインド結果) をクエリできないのはなぜですか? プロジェクトが緊急に必要です。
コードは次のとおりです:

<br />
<?php<br />
/*<br />
	利用mysqli扩展来绑定结果<br />
*/<br />
	//新建服务器连接<br />
	$mysqli=new mysqli('localhost','root','root','searcdb');<br />
	//创建查询<br />
	$query="SELECT adminName,adminPwd FROM admininfo";<br />
	//创建语句对象<br />
	$stmt=$mysqli->stmt_init();<br />
	//为执行准备语句<br />
	$stmt->prepare($query);<br />
	//执行语句<br />
	$stmt->execute();<br />
	//绑定结果参数<br />
	$stmt->bind_result($name,$pwd);<br />
	//循环处理结果并输出数据<br />
	while($stmt->fetch()){<br />
		printf("%s, %s, %s <br />",$name,$pwd);<br />
	}<br />
	//恢复语句资源<br />
	$stmt->close();<br />
	//关闭连接<br />
	$mysqli->close();<br />
?><br />
このステートメントの問題は何ですか? 直接追加、削除、変更、確認することはできますが、結果をバインドする方法やパラメータをバインドする方法は機能しません。インターンシップで使用するので、アドバイスをお願いします。会社はもうすぐプロジェクトに取り組んでいます。至急必要です! !


-----解決策---------
printf("%s, %s , %s df250b2156c434f3390392d09b1c9563",$name,$pwd);? ? ?

パラメータが 1 つありません
つまり、フォーマット文字が 1 つ増えています
------解決策-----
One占有率の高いキャラクター。パラメータが2つしかないんじゃないの?
------解決策----------------------
コードが 1 行欠落しており、クエリの結果が一時的にストレージを使用できる必要があります。
参考のみ:
<br />
function selectLink($oid){<br />
		$sql = "select o.oid,l.lid,c.cid,comName,comPrice,ordTime<br />
				from mis_order o,mis_link l,mis_commodity c<br />
				where o.oid=l.lid and c.cid=l.cid and o.oid=?";<br />
		$stmt = $this->mysqli->prepare($sql);<br />
		$stmt->bind_param("i",$oid);<br />
		$stmt->execute();<br />
		$stmt->store_result();<br />
		$stmt->bind_result($oid,$lid,$cid,$comName,$comPrice,$ordTime);<br />
		$rows = $stmt->affected_rows;<br />
		if($rows > 0){<br />
			$arrLink = array();<br />
			while($stmt->fetch()){<br />
				 $arr = array(<br />
					"oid" => $oid,<br />
					"lid" => $lid,<br />
					"cid" => $cid,<br />
					"comName" => $comName,<br />
					"comPrice" => $comPrice,<br />
					"ordTime" => $ordTime<br />
				);<br />
				array_push($arrLink,$arr);<br />
			}<br />
			return $arrLink;<br />
		}else{<br />
			echo "查询订单明细失败!<br/>";<br />
		}<br />
	}<br />
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。