mysqli_stmt::prepare
(mysqli_stmt_prepare)准备一条SQL语句以便执行
函数名称:mysqli_stmt::prepare()
适用版本:PHP 5, PHP 7
函数描述:该函数用于准备执行一条预处理SQL语句。
语法:bool mysqli_stmt::prepare(string $query)
参数:
返回值:如果准备成功,返回true;否则返回false。
示例:
// 创建数据库连接
$mysqli = new mysqli("localhost", "username", "password", "database");
// 检查连接是否成功
if ($mysqli->connect_errno) {
echo "连接数据库失败: " . $mysqli->connect_error;
exit();
}
// 准备预处理语句
$query = "INSERT INTO users (name, email) VALUES (?, ?)";
$stmt = $mysqli->prepare($query);
if ($stmt) {
// 绑定参数
$name = "John Doe";
$email = "john@example.com";
$stmt->bind_param("ss", $name, $email);
// 执行语句
$stmt->execute();
// 检查是否执行成功
if ($stmt->affected_rows > 0) {
echo "插入成功!";
} else {
echo "插入失败!";
}
// 关闭语句
$stmt->close();
} else {
echo "准备语句失败: " . $mysqli->error;
}
// 关闭数据库连接
$mysqli->close();
上述示例中,我们首先创建了一个mysqli
对象来连接数据库。然后,我们使用prepare()
函数准备了一条预处理语句,其中包含两个占位符(?)。接下来,我们使用bind_param()
函数绑定了两个参数的值。然后,我们使用execute()
函数执行了预处理语句。最后,我们检查了执行结果并输出相应的消息。最后,我们关闭了预处理语句和数据库连接。
注意:在实际使用中,你需要根据具体情况修改数据库连接参数、SQL语句和绑定的参数值。