如何使用循环外的数组查询数据库

时间:2013-04-03 13:25:27

标签: php mysql implode

枝。我试图不在循环中放置SQL查询,因为这可以提高性能。我想我应该使用内爆。但无法弄清楚该怎么做。这是我的代码:

<?php 

//FUNCTION CONNECTNG TO DB HERE

function turn_result_to_array($result)
{
   $result_array = array();

   for ($count=0;  $row = mysql_fetch_array($result); $count++)
   {
      $result_array[$count] = $row;
   }
   return $result_array;
}


function get_sender_username()
{
   //connect to DB 

   $query = sprintf("SELECT DISTINCT sender FROM direct_messages
                                    WHERE receiver_username='%s'
                        ORDER BY direct_messages.id DESC", 
                   mysql_real_escape_string($_COOKIE['username']));

   $result = mysql_query($query);

   $result = turn_result_to_array($result);

   return $result;

}

$senders = get_sender_username(); 

foreach($senders as $sender)
{ //SELECT IMAGE(S) FROM USER TABLE WHERE USERNAME = $SENDERS }

而不是将查询放在FOREACH中,我想把它放在后面,所以我不会多次往返数据库。仅供参考我已经知道我们应该切换到PDO。提前谢谢。

2 个答案:

答案 0 :(得分:0)

这是一种方法:

$senderInString = implode("','",$senders);
$senderInString = "('$senderInString')";
$newQuery = "SELECT something FROM tables WHERE sender in $senderInString;"
$newResult = mysql_query($newQuery);

答案 1 :(得分:0)

使用

      $query= "SELECT IMAGE(S) FROM USER TABLE WHERE USERNAME  IN (".implode(',',$senders).")";
      $result = mysql_query($query);

取代foreach