Оптимизируйте время и 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 />';