微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 使用预准备语句检查数据库中是否已有电子邮件

我试图将我的代码mysql更改为msqli预处理语句.我不知道如何调整我目前工作的代码检查数据库中是否已有电子邮件.以下是我目前正在使用的代码.如何将其更改为准备好的语句并获得相同的结果?
//if email is equal to an email already in the database,display an error message

if(MysqL_num_rows(MysqL_query("SELECT * FROM users WHERE email = '".MysqL_real_escape_string($_POST['email'])."'")))
{
  echo "<p class='red'>Email is already registered with us</p>";
} else {
  // missing code?
}
应该是这样的:
// create MysqLi object
$MysqLi = new MysqLi(/* fill in your connection info here */);

$email = $_POST['email']; // might want to validate and sanitize this first before passing to database...

// set query
$query = "SELECT COUNT(*) FROM users WHERE email = ?"

// prepare the query,bind the variable and execute
$stmt = $MysqLi->prepare( $query );
$stmt->bind_param( 's',$email );
$stmt->execute()

// grab the result
$stmt->store_result();

// get the count
$numRows = $stmt->num_rows();

if( $numRows )
{
     echo "<p class='red'>Email is already registered with us</p>";
}
else
{
    // ....
}

链接也可以帮助您:

http://www.php.net/manual/en/mysqli.quickstart.prepared-statements.php

原文地址:https://www.jb51.cc/php/138344.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐