如何从Mysql中选择逗号分隔变量

时间:2016-04-05 09:28:33

标签: php mysql sql arrays mysql-5.5

我有一个MySql数据库结构和值示例如下所示:

sno     firstname      status
1        John            Active
2        Kelly           Inactive
3        Harri           Passive
4        Kris            Dormant

现在我需要从PHP页面执行Sql查询,并且状态值来自多个复选框,我已将其指定为数组。

我在这个数组中使用了Implode函数:

$status = $_POST['status'];    
$mstat= implode (',', $status);
$query="SELECT * FROM USER WHERE status IN '$mstat'";
$result=mysql_query($query);

while ($members = mysql_fetch_assoc($result))
        { 
        $fname= $members['firstname'];
        echo $fname;
        echo '</br>';
        }

问题是我没有得到任何结果。可能是什么问题呢。或者,如果有人可以建议/建议替代。

当我echo $mstat;时,我得到Active,Passive,Dormant(这取决于我的复选框选择)

3 个答案:

答案 0 :(得分:7)

status是字符串。你需要用quotes包装它们。 IN需要()来包装字符串值。试试 -

$mstat= "'" . implode ("','", $status) . "'";
$query="SELECT * FROM USER WHERE status IN ($mstat)";

假设$status包含数据库中以数组格式显示的部分或全部值。

答案 1 :(得分:1)

这是100%正在回答的作品

$mstat= implode ("','", $status);
$query="SELECT * FROM USER WHERE status IN ('$mstat')";

IN就像这样工作IN(&#39; Active&#39;,&#39; Passive&#39;,&#39; Dormat&#39;) 所以我们必须添加&#39;&#39;在implode函数中完成的所有值。

答案 2 :(得分:-2)

将此行更改为:

$query="SELECT * FROM USER WHERE status IN ('$mstat')";

参数必须在()

!!! 每个字必须在&#39; &#39; 喜欢: $ query =&#34; SELECT * FROM USER WHERE status IN(&#39; Active&#39;,&#39; Inactive&#39;)&#34;

您可以将其更改为:

if ($mstat) $query .= ' ({$db->quote($status}) ';