PDO 执行语句的替代 mysqli 执行语句是什么?
What is the alternative mysqli execute statement for a PDO execute statement?
我有一个 pdo 语句的片段,我想将其用作 mysqli 语句,但我似乎没有掌握它的窍门。
我正在尝试 "convert" mysqli->execute(array()) 从 pdo 语句到 mysqli 语句。
据我了解,有一个 execute() 语句,它在 mysqli 中不需要参数,但在 PDO 中它需要一个参数?
这是代码,我想将其转换为 mysqli 语句:
$sql = "SELECT * FROM users WHERE username = :username";
$sth = $GLOBALS["DB"]->prepare($sql);
$sth->execute(array(":username" => $username));
$result = $sth->fetchAll();
if (!empty($result)) {
$privUser = new PrivilegedUser();
$privUser->user_id = $result[0]["user_id"];
$privUser->username = $username;
$privUser->password = $result[0]["password"];
$privUser->email_addr = $result[0]["email_addr"];
$privUser->initRoles();
return $privUser;
} else {
return false;
}
这就是我当前的代码:
$sql = "SELECT * FROM users WHERE user_id = ?";
$stmt = $mysqli -> prepare($sql);
$stmt->bind_param('s', $user_id);
// line below is what i need to convert to a mysqli statement
$stmt->execute(array(":user_id" => $user_id));
//$stmt->store_result();
$result = $stmt->fetchAll();
if (!empty($result)) {
$privUser = new PrivilegedUser();
$privUser->user_id = $result[0]["user_id"];
$privUser->username = $user_id;
$privUser->password = $result[0]["password"];
$privUser->email_addr = $result[0]["email_addr"];
$privUser->initRoles();
return $privUser;
} else {
return false;
}
就像上面的 Nigel Ren 所说,引用:
"With mysqli, the call to bind_param() is the only way to link bind variables, so the call to execute() will literally be that $stmt->execute();"
我有一个 pdo 语句的片段,我想将其用作 mysqli 语句,但我似乎没有掌握它的窍门。
我正在尝试 "convert" mysqli->execute(array()) 从 pdo 语句到 mysqli 语句。
据我了解,有一个 execute() 语句,它在 mysqli 中不需要参数,但在 PDO 中它需要一个参数?
这是代码,我想将其转换为 mysqli 语句:
$sql = "SELECT * FROM users WHERE username = :username";
$sth = $GLOBALS["DB"]->prepare($sql);
$sth->execute(array(":username" => $username));
$result = $sth->fetchAll();
if (!empty($result)) {
$privUser = new PrivilegedUser();
$privUser->user_id = $result[0]["user_id"];
$privUser->username = $username;
$privUser->password = $result[0]["password"];
$privUser->email_addr = $result[0]["email_addr"];
$privUser->initRoles();
return $privUser;
} else {
return false;
}
这就是我当前的代码:
$sql = "SELECT * FROM users WHERE user_id = ?";
$stmt = $mysqli -> prepare($sql);
$stmt->bind_param('s', $user_id);
// line below is what i need to convert to a mysqli statement
$stmt->execute(array(":user_id" => $user_id));
//$stmt->store_result();
$result = $stmt->fetchAll();
if (!empty($result)) {
$privUser = new PrivilegedUser();
$privUser->user_id = $result[0]["user_id"];
$privUser->username = $user_id;
$privUser->password = $result[0]["password"];
$privUser->email_addr = $result[0]["email_addr"];
$privUser->initRoles();
return $privUser;
} else {
return false;
}
就像上面的 Nigel Ren 所说,引用: "With mysqli, the call to bind_param() is the only way to link bind variables, so the call to execute() will literally be that $stmt->execute();"