ホームページ > バックエンド開発 > PHPチュートリアル > mysqli プリペアド ステートメントが失敗するのはなぜですか? パラメータを適切にバインドするにはどうすればよいですか?

mysqli プリペアド ステートメントが失敗するのはなぜですか? パラメータを適切にバインドするにはどうすればよいですか?

Barbara Streisand
リリース: 2024-12-12 20:04:16
オリジナル
606 人が閲覧しました

Why Do My mysqli Prepared Statements Fail, and How Can I Properly Bind Parameters?

mysqli プリペアド ステートメントの使用

プリペアド ステートメントの開始

次のことを行おうとしていますプリペアドステートメントを利用していますが、コードでエラーが発生します。この問題は、準備されたステートメントにパラメーターをバインドするという手順が欠落していることが原因で発生します。

パラメーターのバインド

準備されたステートメントでは、実行前にパラメーターをバインドする必要があります。このプロセスでは、外部変数を SQL クエリ内のプレースホルダー (?) に関連付けます。

$name = 'one';
$age = 1;

$stmt = $mysqli->prepare("INSERT INTO users (name, age) VALUES (?,?)");

// Bind parameters (typehint: string, integer)
$stmt->bind_param('si', $name, $age);

// Now you can execute
$stmt->execute();
ログイン後にコピー

プリペアド ステートメントには mysqli が必要ですか?

はい、mysqli が必要です準備されたステートメントの場合。

Complete例

接続:

$mysqli = new mysqli("localhost", "root", "root", "test");
if ($mysqli->connect_errno) {
    echo "Connection failed: " . $mysqli->connect_error;
}
ログイン後にコピー

挿入:

$stmt = $mysqli->prepare("INSERT INTO users (name, age) VALUES (?,?)");

// Bind parameters (typehint: string, integer)
$stmt->bind_param('si', $name, $age);

// Insert row
$stmt->execute();
ログイン後にコピー

エラーのある選択取り扱い:

$stmt = $mysqli->prepare("SELECT * FROM users WHERE name = ?");
$stmt->bind_param('s', $name);

$stmt->execute();

if ($stmt->errno) {
    echo "Error: " . $stmt->error;
} else {
    $result = $stmt->get_result();
}

// Process result
ログイン後にコピー

以上がmysqli プリペアド ステートメントが失敗するのはなぜですか? パラメータを適切にバインドするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート