1

我一直在尝试寻找一种解决方案,您可以使用一个准备好的语句获取数据库并使用数组值执行它

通常我会用我的陈述来做到这一点:

$search = $db->prepare("SELECT * FROM table WHERE name = ?");
$search->execute(array($name));

但是如果我有一个这样的数组怎么办:

Array ( 
  [0] => Array 
  ( 
    [name] => Burger Joint 
  ) 
  [1] => Array 
  ( 
    [name] => Burger Joint 
  ) 
  [2] => Array 
  ( 
    [name] => Burgers 
  ) 
  [3] => Array 
  ( 
   [name] => Meats 
  )
)

我想以某种方式使用WHERE name=?语句中数组中的任何一个值来浏览我的数据库。但是,有时会有多个相似的名称,有没有办法事先压缩数组,或者在这种情况下最好的做法是什么?

谢谢!

4

3 回答 3

0

您可以通过多种方式执行此操作,但既然您提到了OR,让我们使用它:

首先,您的可能值数组。让我们把你的数组塑造成一个唯一值的数组:

$values_array = array_unique(
    array_map(
        function($element) { 
            return $element['name']; 
        },
        $original_array
    )
);
// $values_array now contains array('Burger Joint', 'Burgers', 'Meats')

现在,我们通过引入尽可能多的占位符来构建准备好的查询:

$query = sprintf('SELECT * FROM table WHERE %s',
    implode(
        ' OR ',
        array_fill(
            'name = ?', 
            count($values_array)
        )
    )
);
// $query now contains 'SELECT * FROM table WHERE name = ? OR name = ? OR name = ?'

并执行它:

$search = $db->prepare($query);
$search->execute($values_array);

或者,您可以IN改用,像这样构建您的查询:

$query = sprintf('SELECT * FROM table WHERE name in (%s)',
    implode(
        ', ',
        array_fill(
            '?', 
            count($values_array)
        )
    )
);
// $query now contains 'SELECT * FROM table WHERE name in (?, ?, ?)'

$search = $db->prepare($query);
$search->execute($values_array);

这将具有相同的效果,并且通过查看代码可以更清楚地了解发生了什么。

于 2013-12-03T13:51:37.770 回答
-1

尝试name IN代替name =.

于 2013-02-21T07:08:55.850 回答
-1

首先,你需要IN。field IN (1,2)等于field=1 OR field=2
接下来,您需要某种辅助函数,将创建正确 SQL 语句的所有技术细节应用程序业务代码中移除。让它在一行中,而不是 50 行。

$data = $db->getAll("SELECT * FROM table WHERE name IN (?a)",$names);

最后,您似乎从另一个查询中获取了您的姓名。
在这种情况下,您只需使用 JOIN 运行单个查询。您可以在标签下提出另一个问题,[mysql]提供您的两个查询。

要仅将名称放入数组中,您必须使用另一个辅助函数(尽管您必须自己创建它或先获取某个位置):

$names = $db->getCol("here goes your query to get names");
于 2013-02-21T07:31:28.833 回答