我有以下 html 文件以关联数组的形式发送数据。该表单使用 Jquery Ajax 动态提交(无需提交按钮)。
<html>
<form id="checkboxform" method="GET">
<input type="checkbox" name="navi[key1]" value="value1" <?php echo array_key_exists("value1",$navi)?"checked":""; ?>> Item1
<input type="checkbox" name="navi[key2]" value="value2" <?php echo array_key_exists("value2",$navi)?"checked":""; ?>> Item2
<input type="checkbox" name="navi[key3]" value="value3" <?php echo array_key_exists("value3",$navi)?"checked":""; ?>> Item3
</form>
</html>
然后我有以下 php 文件来处理表单并从 Mysql 数据库中选择数据。查询是根据用户检查的输入字段动态生成的。
<?php
if(isset($_GET['navi'])):
$navi=$_GET['navi'];
//foreach
foreach($navi as $key =>$value):
$query=$key."="."'".$value."'";
endforeach;
// run the query using PDO
$content = $db->getRows("SELECT * FROM products WHERE $query");
endif;
?>
我的问题如下,如果用户选择多个复选框,如何在“$query”变量后添加“OR”。 Whick 将生成如下所示的查询:
SELECT * FROM products WHERE key1='value1' OR key2='value2' OR key3='value3'
我的代码生成以下查询,没有 OR 并且它不正确。
SELECT * FROM products WHERE key1='value1' key2='value2' key3='value3'
谢谢
最佳答案
你可以试试这个 -
$query = array();
foreach($navi as $key =>$value):
$query[] = $key."="."'".$value."'"; // store in array
endforeach;
// run the query using PDO
$content = $db->getRows("SELECT * FROM products WHERE " . implode(' OR ', $query)); // implode with OR
关于php - 从复选框检索数组值并动态构建查询以选择内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36449532/