0

我的 SQL 语句不起作用...

这是我的变量:

$email="test@test.com";

这些陈述不起作用:

$sql = "SELECT * FROM table WHERE email = $email";
$sql = 'SELECT * FROM table WHERE email = ' . $email;

1064 您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 1 行的“@test.com”附近使用正确的语法

但是如果我使用字符串而不是变量,它可以工作:

$sql = "SELECT * FROM table WHERE email = 'test@test.com'";  

我的陈述有什么问题?谢谢!

4

3 回答 3

1

请在mysql中转义字符串

$sql = "SELECT * FROM table WHERE email = $email"; 
$sql = 'SELECT * FROM table WHERE email = ' . $email;

这应该工作

$sql = "SELECT * FROM table WHERE email = '$email'"; 
于 2013-06-12T16:44:51.873 回答
0

table是关键字,所以可以这样写

$sql = "SELECT * FROM `table` WHERE email='$email'";
于 2016-05-20T05:43:39.050 回答
-1
 $this->db->where('email', $this->input->post('email'));
    $query =$this->db->get($this->user);

  //$sql = "SELECT * FROM  user WHERE email = '$email'"; 
if($query->num_rows == 1)
{
    return true;
}
else
{
    return false;
}

} }

于 2016-05-20T05:17:36.940 回答