Проверьте, есть ли письмо в базе данных, используя подготовленные заявления - PullRequest
3 голосов
/ 23 февраля 2012

Я пытаюсь изменить свой код на подготовленные операторы msqli из mysql. Я не уверен, как адаптировать мой код, который в настоящее время работает, чтобы проверить, есть ли уже электронное письмо в базе данных. Ниже приведен код, который я сейчас использую, который работает. Как мне превратить это в подготовленное утверждение и получить тот же результат?

//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?
}

1 Ответ

0 голосов
/ 23 февраля 2012

Должно быть примерно так:

// 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

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...