Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 21.08.2008
Сообщений: 6

Mysql запрос оптимизация

26.10.2009, 19:27. Показов 1439. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
красткая структура базы:
gorod
id
name
magazin
id
id_gorod
name
comments
id
id_magazin
author
text
rating
id
id_magazin
rate

нужно выбрать все магазины чтобы у каждого было название города, в котором он находится,
количество комментариев к этому магазину и рейтинг магазина.
что то типа:

SQL
1
2
3
SELECT gorod.name, magazin.name, COUNT(comments.id), avg(rating.rate)
FROM gorod, magazin, comments, rating
WHERE magazin.id_gorod=gorod.id AND comments.id_magazin=magazin.id AND rating.id_magazin=magazin.id
проблема в Count и Avg они выводят всего одну строку =(

теория: для каждого магазина много человек ставили рейтинг, выводится среднее арифметическое.

связи:
город - магазин = один ко многим
магазин - комментарии = один ко многим
магазин - рейтинг = один ко многим
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
26.10.2009, 19:27
Ответы с готовыми решениями:

Оптимизация запроса MySQL
Прошу помочь оптимизировать данный запрос MySQL SELECT * FROM (SELECT *, (SELECT viewsinday FROM plans WHERE id = t1.plan LIMIT 1) AS...

Оптимизация запросов mysql
Здравствуйте. Есть 3 таблицы: CREATE TABLE IF NOT EXISTS `tblarticles` ( `Id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, ...

Оптимизация mysql my.cnf
Здравствуйте! В интернете раскопал информацию о том, что файл конфигурации mysql my.cnf можно перенастраивать в зависимости от...

9
 Аватар для BasicMan
19318 / 2626 / 84
Регистрация: 17.02.2009
Сообщений: 30,364
26.10.2009, 19:36
а если так?
SQL
1
2
3
4
SELECT gorod.name, magazin.name, COUNT(comments.id), avg(rating.rate)
FROM gorod, magazin, comments, rating
WHERE magazin.id_gorod=gorod.id AND comments.id_magazin=magazin.id AND rating.id_magazin=magazin.id
GROUP BY gorod.name, magazin.name
0
0 / 0 / 0
Регистрация: 21.08.2008
Сообщений: 6
26.10.2009, 23:39  [ТС]
спасибо, помогло, следующая загвоздка: если нет комментариев к магазину или рейтинга к нему то не выбирается строка с этим магазином.

кому проще смореть на сделанных таблицах вот код

SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
СREATE TABLE `comments` (
  `id` INT(11) NOT NULL AUTO_INCREMENT,
  `id_magazin` INT(11) NOT NULL,
  `text` VARCHAR(255) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=latin1 AUTO_INCREMENT=5 ;
 
INSERT INTO `comments` VALUES (1, 1, '123');
INSERT INTO `comments` VALUES (2, 1, '44');
INSERT INTO `comments` VALUES (3, 1, '3');
INSERT INTO `comments` VALUES (4, 2, '123');
 
CREATE TABLE `gorod` (
  `id` INT(11) NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(255) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;
 
INSERT INTO `gorod` VALUES (1, 'kovrov');
INSERT INTO `gorod` VALUES (2, 'moskow');
 
CREATE TABLE `magazin` (
  `id` INT(11) NOT NULL AUTO_INCREMENT,
  `id_gorod` INT(11) NOT NULL,
  `name` VARCHAR(255) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1 AUTO_INCREMENT=4 ;
 
INSERT INTO `magazin` VALUES (1, 1, 'TC');
INSERT INTO `magazin` VALUES (2, 2, 'ashan');
INSERT INTO `magazin` VALUES (3, 2, 'ikea');
 
CREATE TABLE `rating` (
  `id` INT(11) NOT NULL AUTO_INCREMENT,
  `id_magazin` INT(11) NOT NULL,
  `rate` INT(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=latin1 AUTO_INCREMENT=5 ;
 
INSERT INTO `rating` VALUES (1, 1, 4);
INSERT INTO `rating` VALUES (2, 1, 5);
INSERT INTO `rating` VALUES (3, 2, 2);
INSERT INTO `rating` VALUES (4, 2, 4);
0
 Аватар для BasicMan
19318 / 2626 / 84
Регистрация: 17.02.2009
Сообщений: 30,364
26.10.2009, 23:45
krasava, вот к чему код нифига не понятно хоть
тыба лучче сказал, милай, где у тя чо не выбираица канкретна, блин. а то многабукафф ниасилил, а смысла 0 целых 0 десятых

кароч так. запрос давай, нафик, в студию, гляну, а без запроса - я не екстрасекс, не понимаю
0
0 / 0 / 0
Регистрация: 21.08.2008
Сообщений: 6
26.10.2009, 23:52  [ТС]
код базы описан выше, выполняется запрос:
SQL
1
2
3
4
SELECT gorod.name, magazin.name, COUNT(comments.id), avg(rating.rate)
FROM gorod, magazin, comments, rating
WHERE magazin.id_gorod=gorod.id AND comments.id_magazin=magazin.id AND rating.id_magazin=magazin.id
GROUP BY gorod.name, magazin.name
если нет комментариев к магазину или рейтинг не поставлен. название магазина и город не выбираются, а надо чтобы выбирались,но если нет к ним коментариев то в ячейке 0 и если нет рейтинга тоже 0
0
 Аватар для BasicMan
19318 / 2626 / 84
Регистрация: 17.02.2009
Сообщений: 30,364
27.10.2009, 00:01

Не по теме:

руки б те поотрывать за код по-идиотски так написанный


SQL
1
2
3
4
5
6
SELECT gorod.name, magazin.name, isnull(COUNT(comments.id),0) AS comment, isnull(avg(rating.rate),0) AS ratings
FROM gorod
INNER JOIN magazin ON magazin.id_gorod=gorod.id 
LEFT JOIN comments ON comments.id_magazin=magazin.id
LEFT JOIN rating ON rating.id_magazin=magazin.id
GROUP BY gorod.name, magazin.name
Добавлено через 35 секунд
и спасибов не забудь наставить (кнопку тыцни)
1
0 / 0 / 0
Регистрация: 21.08.2008
Сообщений: 6
27.10.2009, 00:06  [ТС]
ОГромное спасибо, разобрался респект. но не IsNULL А iFnull ... is только в SQL Server / MS Access
0
27.10.2009, 00:09

Не по теме:

krasava, я в мускуле ваще не шарю. только в скул сервере и акцессе

0
0 / 0 / 0
Регистрация: 21.08.2008
Сообщений: 6
27.10.2009, 23:21  [ТС]
Бурундукъ ай нид ё хэлп!

на этой базе запрос
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
SELECT gorod.name,
 magazin.name,
 ifnull(count(comments.id),0) AS comment,
 ifnull(avg(rating.rate),0) AS ratings,
--=======================
 ifnull(count(rating.id),0) AS golosovavshih
--=======================
FROM gorod
INNER JOIN magazin ON magazin.id_gorod=gorod.id 
LEFT JOIN comments ON comments.id_magazin=magazin.id
LEFT JOIN rating ON rating.id_magazin=magazin.id
GROUP BY gorod.name, magazin.name
вот строка выделена, она мне нужна - тоесть количесво голосовавших за этот магазин. а он выбирает так, что golosovavshih=comment
0
 Аватар для BasicMan
19318 / 2626 / 84
Регистрация: 17.02.2009
Сообщений: 30,364
28.10.2009, 09:43
krasava, снова нифига не понял

Не по теме:

в смысле, я не понял (такое ощущение, что один из нас дурак, и это похоже скорее всего я=-O)


во-1х ты говорил, что isnull в мускуле не катит, надо ifnull ставить (я твой код откорректировал, все равно ты код не форматировал, так я когда форматил, то заодно и...)
в0-2х, толи ты запятую не поставил, толи я когда твоих козяблей убирал, запятую снес.
в-3х, мне в твои данных влом разбираться, но мот у тя к-во строк в рейтинга, совпадает с к-вом строк в каментах?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.10.2009, 09:43
Помогаю со студенческими работами здесь

Оптимизация баз данных MySQL
Есть какая-нибудь хорошая литература по этому вопросу?

ПOМОГИТЕ профи, оптимизация MySQL, есть ли выход???
Существует сайт на котором есть -чаты -гостевая и т.д. Во всех этих модулях используется база данных MySQL Везде запросы...

Задачка. Сложный запрос или оптимизация таблиц
есть 2 таблицы. 1 имеет вид примерно(not a_i): id | id_a | id_b | text_z | text_x во 2 есть: id, id_a, id_z, id_x (id_z, id_x -...

Сложный запрос из нескольких таблиц. Необходима оптимизация
Всем доброго времени суток! Проблема вот какая. Есть сложный запрос, осуществляемый из нескольких таблиц, время на выполнение которого...

Оптимизация запроса. Почему второй запрос работате гораздо быстрее.
Здравствуйте. было выяснено что следующий запрос очень сильно нагружает сервер SELECT tp.* , tu.user_id , user_name ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru