Fuelen » 2010.03.20 11:33

Код:

1
span style="color: #0000BB"><?php$q = mysql_query('SELECT * FROM `table`');while($row = mysql_fetch_assoc($q)){echo mysql_result(mysql_query('SELECT COUNT(*) FROM `table2` WHERE `tags` LIKE "%'.$row['name'].'%"'),0);}

Как обьединить эти 2 запроса, чтобы при выводе в ячейке counter было значение второго запроса и в результате было примерно такое

Код:

1
span style="color: #0000BB"><?php$q = mysql_query('???');while($row = mysql_fetch_assoc($q)){echo $row['counter'];}

? В таблице table поля counter нет

Gemorroj » 2010.03.20 12:14

Код:

1
2
3
4
SELECT `t1`.`name`, COUNT(`t2`.`tags`) AS `count`
FROM `table` AS `t1`
INNER JOIN `table2` AS `t2` ON `t2`.`tags` LIKE CONCAT("%", `t1`.`name`, "%")
GROUP BY `t1`.`name`
Fuelen » 2010.03.20 14:45

Спасибо :)

Fuelen » 2010.03.30 13:23

Но у меня ничего не выводит гг

Gemorroj » 2010.03.30 13:54

охуенный фидбэк =)

Fuelen » 2010.04.03 10:50

Array ( [0] => 42000 [1] => 1305 [2] => FUNCTION fuelen_db.CONCAT does not exist )

Gemorroj » 2010.04.03 11:09

Эммм.. похоже на PDO. А какая СУБД используется? MySQL? CONCAT есть в MySQL с древних времен.

Fuelen » 2010.04.03 12:28

Да, PDO MySQL

Gemorroj » 2010.04.03 12:33

покажи сам php код в который этот SQL вставляется

Fuelen » 2010.04.03 13:17

Код:

1
span style="color: #0000BB"><?phpforeach($db->query('SELECT `t1`.*, COUNT(`t2`.`tags`) AS `count` FROM `categories` AS `t1` INNER JOIN `articles` AS `t2` ON `t2`.`tags` LIKE CONCAT ("%", `t1`.`name`, "%") GROUP BY `t1`.`name`') as $row){print_r($row);}print_r($db->errorInfo());
Gemorroj » 2010.04.03 13:29

Код:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
CREATE TABLE IF NOT EXISTS `articles` (
`id` int(11) NOT NULL,
`tags` varchar(255) NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
 
INSERT INTO `articles` (`id`, `tags`) VALUES
(1, 'xxx'),
(2, 'yyy');
 
CREATE TABLE IF NOT EXISTS `categories` (
`id` int(11) NOT NULL,
`name` varchar(255) NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
 
INSERT INTO `categories` (`id`, `name`) VALUES
(1, 'xxx'),
(2, 'zzz');

Код:

1
span style="color: #0000BB"><?php$db = new PDO('mysql:host=localhost;port=3306;dbname=test', 'root', '');$sql = 'SELECT `t1`.*, COUNT(`t2`.`tags`) AS `count`FROM `categories` AS `t1`INNER JOIN `articles` AS `t2` ON `t2`.`tags` LIKE CONCAT("%", `t1`.`name`, "%")GROUP BY `t1`.`name`';foreach($db->query($sql) as $row){ print_r($row);}

Код:

1
2
3
4
5
6
7
8
9
Array
(
[id] => 1
[0] => 1
[name] => xxx
[1] => xxx
[count] => 1
[2] => 1
)
Fuelen » 2010.04.03 14:10

Фигня какая-то... Всё не как в людей :(
В процедурном стиле всё нормально выводит... Ппц

Код:

1
span style="color: #0000BB"><?php$q = mysql_query('SELECT `t1`.*, COUNT(`t2`.`tags`) AS `count` FROM `categories` AS `t1` INNER JOIN `articles` AS `t2` ON `t2`.`tags` LIKE CONCAT("%", `t1`.`name`, "%") GROUP BY `t1`.`name`');while($row = mysql_fetch_assoc($q)){ print_r($row);}

Добавлено спустя   6 минут  32 секунды:
Пойду плакать %) ыЫ

Fuelen » 2010.04.03 17:05

Всё заработало. Спасибо :)

Gemorroj » 2010.04.03 18:58

в чем дело было?

Fuelen » 2010.04.03 19:57

Не знаю :) мне кажется, что через то, что я в запросе энтэры на пробелы заменил Гг