[英]How to SELECT Comma Separated variable From Mysql
我有一个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
(这是基于我的复选框选择)
status
是字符串。 你需要用quotes
包装它们。 并且IN
needs ()
包装字符串值。 试试 -
$mstat= "'" . implode ("','", $status) . "'";
$query="SELECT * FROM USER WHERE status IN ($mstat)";
假设$status
包含数据库中以数组格式显示的部分或全部值。
这是100%的工作答案
$mstat= implode ("','", $status);
$query="SELECT * FROM USER WHERE status IN ('$mstat')";
IN就像这样的IN('Active','Passive','Dormat')所以我们必须在implode函数中添加所有值中的''。
将此行更改为:
$query="SELECT * FROM USER WHERE status IN ('$mstat')";
论证必须在()
! 每个单词必须在''like:$ query =“SELECT * FROM USER WHERE status IN('Active','Inactive')”
你可以改变它:
if ($mstat) $query .= ' ({$db->quote($status}) ';
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.