使用 PHP 在 mysql 数据库中进行数组搜索


Array search in mysql database with PHP

有一个数据库,我在其中存储产品详细信息。(编号、名称、价格、类别、单位)

首先,我在名为"input.php"的 php 文件中列出了可供选择的产品。它就像一个魅力。

// SQL query
    $query = "SELECT    * 
              FROM      products
              ORDER BY  p_name
              ASC";
            $result = mysql_query($query);
            if($result === FALSE) {die(mysql_error());}?>
                <table width="100%">
                    <tr>
                        <td></td>
                        <td width="800px"><h1>Product name</h1></td>
                        <td width="400px"><h1>Product price</h1></td>
                        <td>Category</td>
                    </tr>
                </table>
            <?
            while ($row = mysql_fetch_assoc($result)) {?>
                <table>
                    <tr>
                        <td><input type="checkbox" name="pro_name[]" value="<?=$row['p_name']?>"></td>
                        <td width="800px" align="left"><b><?=$row['p_name']?></b></td>
                        <td width="400px" align="left"><?=$row['p_price']?></td>
                        <td align="center"><?=$row['p_cat']?></td>
                    </tr>
                </table>
                <?}

我将数据提交到"index.php"并处理其中的变量。

 if($_SERVER['REQUEST_METHOD']== "POST"){
// Variables
$c_name = $_POST['c_name'];             //  ['company name']
$c_consumption = $_POST['c_consumption'];   //  ['company consumptions']
$f_price = $_POST['f_price'];               //  ['fuel price']
$o_sales = $_POST['o_sales'];               //  ['sales']
$pro_name = $_POST['pro_name'];         //  ['products names']
$pro_id = $_POST['pro_id'];             //  ['product id']  
$pro_price = $_POST['pro_price'];           //  ['product price']

我卡住的第三步...我需要列出所选产品的详细信息。

的想法是从数据库中选择详细信息,并搜索我之前选择的产品名称。

我尝试过用IN,喜欢,内爆....等等,但它没有用。:(

// SQL query
      $query = "SELECT  * 
                      FROM      products
                      WHERE     p_name IN (".implode(',', $pro_name).")
                      ORDER BY  p_name
                      ASC";
            $result = mysql_query($query);
            if($result === FALSE) {die(mysql_error());}
            while ($row = mysql_fetch_array($result)) {?>
                <table>
                    <tr>                            
                        <td width="800px" align="left"><b><?=$row['p_name']?></b></td>
                        <td width="400px" align="left"><?=$row['p_price']?></td>
                        <td align="center"><?=$row['p_cat']?></td>
                    </tr>
                </table>
                <?}
                }

编辑:

 var_dump($pro_name); result
 array(3) { [0]=> string(14) "12 V szivattyú" [1]=> string(17) "120 l/p szivattyú" [2]=> string(28) "24 hónapra bővített garancia" } 

什么是 $pro_name 值?如果你正在使用内爆,那么应该是一个数组,如 $pro_name=array('水果','巧克力','镜像');然后查询将是:

SELECT  * 
                      FROM      products
                     -> WHERE     p_name IN ("Fruit,Chocolate,Mirror")
                      ORDER BY  p_name
                      ASC

但问题是查询还是错的,因为",那么你应该删除并改为

WHERE     p_name IN (implode(',', $pro_name))

然后查询将像

SELECT  * 
                          FROM      products
                         -> WHERE     p_name IN (Fruit,Chocolate,Mirror)
                          ORDER BY  p_name
                          ASC

如果p_name是字符串类型,我很确定您要内爆的 $pro_names 需要用 ' (单引号分隔符)分隔。看起来您在脚本中的内容会被 sql 解析器解释为列名。

试试这个SQL

 $pr_name = ltrim(implode(',' , '".$pro_name."'), ',');  
 $query = "SELECT  * 
           FROM products
           WHERE p_name IN ($pr_name)
           ORDER BY p_name
           ASC";

感谢您的回复。帮助我解决问题。

这是我的解决方案:

<input type="checkbox" name="pro_id[]" value="<?=$row['p_id']?>">

它创建一个数组:

string(24) "6, 7, 10, 20, 21, 49, 54"

$list = implode(', ', $pro_id);

.SQL

// SQL query
$query = " SELECT      * 
           FROM       products
           WHERE      p_id IN ($list)
           ORDER BY   p_name
           ASC ";

我认为名称包含查询无法处理的字符,因此现在基于 ID 的查询。我不知道为什么一开始我不使用 id...我的坏。