mysqli 准备语句(Prepared Statements)是一种在数据库交互中用于提高性能和安全性的技术。它允许你预编译 SQL 语句,然后多次执行该语句,每次执行时只需提供不同的参数值。这种方法不仅可以提高性能,还可以防止 SQL 注入攻击。
mysqli 准备语句主要分为两种类型:
以下是一个使用 mysqli 准备语句的简单示例:
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// 检查连接
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
}
// 准备 SQL 语句
$stmt = $conn->prepare("SELECT id, firstname, lastname FROM myTable WHERE firstname=? AND lastname=?");
$firstname = "John";
$lastname = "Doe";
// 绑定参数
$stmt->bind_param("ss", $firstname, $lastname);
// 执行查询
$stmt->execute();
// 绑定结果变量
$stmt->bind_result($id, $firstname, $lastname);
// 获取结果
while ($stmt->fetch()) {
echo "id: " . $id . " - Name: " . $firstname . " " . $lastname . "<br>";
}
// 关闭语句
$stmt->close();
// 关闭连接
$conn->close();
?>
bind_param
方法调用失败。execute
方法返回 false
。fetch
方法返回 false
。通过以上方法,可以有效解决 mysqli 准备语句在使用过程中遇到的常见问题。
领取专属 10元无门槛券
手把手带您无忧上云