星空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日
  • 展开全部

悬赏问题

  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真