Rumah > pembangunan bahagian belakang > tutorial php > 小白继续。PHP中怎么把数组作为sql查询语句的条件

小白继续。PHP中怎么把数组作为sql查询语句的条件

WBOY
Lepaskan: 2016-06-13 13:38:28
asal
1095 orang telah melayarinya

小白继续求助。。PHP中如何把数组作为sql查询语句的条件。
小白感谢各位大大对于自己上一个帖子的帮助,终于弄明白是怎么回事了。 现在遇到了另一个问题:

我通过一个页面让用户提交了12个多选列表,
获取出来就是12个数组,

然后根据这12个数组里的内容进行数据库搜索,

可是发现好像没有办法把这12个数组里的内容一项一项提取出来,然后写sql查询语句。。

比如:

$a = array(a,b,c,d);
$b = array(1,2,3,4);
$c = array(I,II,III,IV);
然后我想select * from 表名 where name=a AND name=b AND name=c AND name=d AND name=1 AND name=2..... AND name=IV

不知道如何可以实现呢?用foreach循环的话,只怕每次都是当前元素的值,这样查出来是每一个当前元素可以搜索到的结果。。。

但是我想查询的是所有数组里所有元素存在的条件下,最后的结果。。

求助各位高人!


------解决方案--------------------
呵呵,那么多AND可能找到东西么?

PHP code
$a = array('a','b','c','d');
$b = array(1,2,3,4);
$c = array('I','II','III','IV');
#保证$a,$b,$c任意一个非空数组,自己判断                                                                                                      
echo "select * from table where name='".implode("' OR name='",array_merge($a,$b,$c))."'";
<br><font color="#e78608">------解决方案--------------------</font><br>
在吃饭,给你提示<br>1个是将数组暑输出字符串 implode(',',$arr) 标点符号什么的自己再加工吧<br>1个是修改你的SQL 语句 将同个数组AND 什么的修改成 IN  <br>例如 IN ('a','b','c','d')<br><br>即可
<br><font color="#e78608">------解决方案--------------------</font><br>
Salin selepas log masuk
探讨

引用:

在吃饭,给你提示
1个是将数组暑输出字符串 implode(',',$arr) 标点符号什么的自己再加工吧
1个是修改你的SQL 语句 将同个数组AND 什么的修改成 IN
例如 IN ('a','b','c','d')

即可


谢谢回复! 如果是name IN ('a','b','c','d'),那么应该是OR的关系吧?还是……
Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan