Оптимизируйте время и SQL в foreach

Мой код:

$text = '12-name-y-86';
$array = explode('-',$text);
foreach($array as $value) {
    $sql = mysql_query("SELECT * FROM `table` WHERE `pid`='$value' ORDER BY `id` LIMIT 3");
    echo '***'.$value.'***';
    echo '<br />';    
    while($row = mysql_fetch_array($sql)) {
        echo $row['title'];
        echo '<br />';
    }
    echo '<br /><br />';
}

Распечатать:

12

title1

title2

title3

название

ti1

ti2

Ti3

Y

tle1

tle2

tle3

86

mytitle1

mytitle2

mytitle3

Этот код работает полностью, чтобы получить больше значений в $text, сервер отключен!

1 ответ

Решение

Попробуйте выбрать все записи всего за один запрос, например так:

$text = '12-name-y-86';
$array = explode('-', $text);
$array = "'" . implode(',', $array) . "'";
$sql = mysql_query("SELECT * FROM `table` WHERE `pid` IN (' . $array . ') ORDER BY `id` LIMIT 3");
while($row = mysql_fetch_array($sql)) {
    echo $row['title'];
    echo '<br />';
}
echo '<br /><br />';
Другие вопросы по тегам