星空2020 2022-03-26 10:17 采纳率: 64.1%
浏览 71
已结题

php+mysql变量为逗号隔开的数据,如何循环批量查询?

逗号隔开的变量数据,循环批量多表(A表,B表,C表,D表)查询,如何修改?
mysql表中查询的字段分别为:A表和B表是字段是name,C表是username,D表的字段是uname

单张表目前都无法实现。

//search input框的值为逗号分开的:AAA,BBB,CCC,DDD
$s = $_POST['search']; //获取searc框里name的值如,AAA,BBB,CCC
$s =explode(',',$s); //以逗号分割数据
for($i=0;$i<count($s);$i++)//错的?
$sql= "select * from A表 where name in ('$s[$i]')"; //这种写法我在输入框里输入AAA,BBB却只能查询到BBB,没有AAA的信息。
$result = $conn->query($sql);

  • 写回答

1条回答 默认 最新

  • PHP技术栈 2022-03-26 20:17
    关注

    改成如下试一下:

    //search input框的值为逗号分开的:AAA,BBB,CCC,DDD
    $s = $_POST['search']; //获取searc框里name的值如,AAA,BBB,CCC
    $s =explode(',',$s); //以逗号分割数据
    for($i=0;$i<count($s);$i++){
         $strList .= $s[$i].‘,’;
    }
    $strList =  substr($strList,0,-1);
    $sql= "select * from A表 where find_in_set  (name,$strList)";
    $result = $conn->query($sql);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 4月6日
  • 已采纳回答 3月29日
  • 修改了问题 3月27日
  • 修改了问题 3月27日
  • 展开全部

悬赏问题

  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥15 stable diffusion
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘