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包含数据库中以数组格式显示的部分或全部值.

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...