php – 如何从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>';
}
问题是我没有得到任何结果.可能是什么问题呢.或者,如果有人可以建议/建议替代方案.
当我回复$mstat;我得到主动,被动,休眠(这是基于我的复选框选择)
解决方法:
状态是字符串.你需要用引号包装它们.并且IN needs()包装字符串值.试试 –
$mstat= "'" . implode ("','", $status) . "'";
$query="SELECT * FROM USER WHERE status IN ($mstat)";
假设$status包含数据库中以数组格式显示的部分或全部值.
标签:php,arrays,sql,mysql,mysql-5-5 来源: https://codeday.me/bug/20190824/1705299.html