2 つの変数を 1 つのquestion mark
!にバインドすることはできません。
バインドする変数ごとに、1 つ必要ですquestion mark
「bind_param」は、各変数が要件に一致するかどうかをチェックします。その後、文字列値が引用符で囲まれます。
これは機能しません。
"SELECT name FROM table WHERE city IN (?)"; ( becomes too )
$q_prepared->bind_param("s", $cities);
"SELECT name FROM table WHERE city IN ('city1,city2,city3,city4')";
でなければなりません。
"SELECT name FROM table WHERE city IN (?,?,?,?)"; ( becomes too )
$q_prepared->bind_param("ssss", $city1,$city2,$city3,$city4);
"SELECT name FROM table WHERE city IN ('city1','city2','city3','city4')";
$query_prepared->bind_param
文字列パラメーターを 1 つずつ引用符で囲みます。
また、変数の数と文字列型の長さは、ステートメントのパラメーターと一致する必要があります。
$query_str= "SELECT name FROM table WHERE city IN ('Nashville','Knoxville')";
となります
$query_str= "SELECT name FROM table WHERE city IN (?,?)";
今bind_param
でなければならない
bind_param("ss",$arg1,$arg2)
これとともに
$query_str= "SELECT name FROM table WHERE city IN (?)";
そしてbind_param
_
bind_param("s",$cities)
あなたが得る
$query_str= "SELECT name FROM table WHERE city IN ('Nashville,Knoxville')";
そのため、配列は機能しません。
この事実に対する唯一の解決策は、call_user_func_array
ステートメントを初期化する場合、以下は不要です
$query_prepared = $mysqli->stmt_init();
if($query_prepared && $query_prepared->prepare($query_str)) {
正解です
$query_prepared = $mysqli->stmt_init();
if($query_prepared->prepare($query_str)) {
使用したくない場合call_user_func_array
で、引数の数が少ない
場合は、次のコードで実行できます。
[...]
$cities= explode(",", $_GET['cities']);
if (count($cities)>3) { echo "too many arguments"; }
else
{
$count = count($cities);
$SetIn = "(";
for($i = 0; $i < $count; ++$i) {
$code.='s';
if ($i>0) {$SetIn.=",?";} else {$SetIn.="?";}
}
$SetIn.=")";
$query_str= "SELECT name FROM table WHERE city IN ".$SetIn;
// with 2 arguments $query_str will look like
// SELECT name FROM table WHERE city IN (?,?)
$query_prepared = $mysqli->stmt_init();
if($query_prepared->prepare($query_str))
{
if ($count==1) { $query_prepared->bind_param($code, $cities[0]);}
if ($count==2) { $query_prepared->bind_param($code, $cities[0],$cities[1]);}
if ($count==3) { $query_prepared->bind_param($code, $cities[0],$cities[1],$cities[2]);
// with 2 arguments $query_prepared->bind_param() will look like
// $query_prepared->bind_param("ss",$cities[0],$cities[1])
}
$query_prepared->execute();
}
[...]
}
到達するために試してみることをお勧めしますcall_user_func_array
。
mysqli-stmt.bind-paramの解決策を探しますnick9v