duanqie5741 2016-02-20 16:18
浏览 274
已采纳

非法混合排序(ascii_general_ci,IMPLICIT)和(latin1_swedish_ci,COERCIBLE)

<?php

include 'db_connect.php';

$name = $_REQUEST['sname'];
$email = $_REQUEST['email'];

$query = "SELECT * FROM info_enrol_student WHERE ES_name = '$name' AND ES_EMAIL = '$email'";
$in = mysqli_query($conn,$query) or die(mysqli_error($conn));
$count = mysqli_num_rows($in);
if (mysqli_num_rows($in) > 0)
{
header('location:index.php');
exit;
}

?>

I am making a login form and giving data to this php code but getting this error.

Illegal mix of collations (ascii_general_ci,IMPLICIT) and (latin1_swedish_ci,COERCIBLE) for operation '=' in php

I am not able to understand the error because earlier with the same script I was able to login in the system.

  • 写回答

1条回答 默认 最新

  • dongta5747 2016-02-20 17:16
    关注

    Based on the error stated by you you need to do following:-

    Go to the database table and change the collation of these two fields (ES_name and ES_EMAIL) to utf-8-bin and change your query like below:-

    $query = "SELECT * FROM info_enrol_student WHERE `ES_name` = $name AND `ES_EMAIL` = $email"; `
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?