Запрос случайного возврата всех предметов или только некоторых предметов - PullRequest
1 голос
/ 08 ноября 2011

У меня есть 4 таблицы:

mysql> describe solution_sections;
+---------------------+---------------+------+-----+---------+----------------+
| Field               | Type          | Null | Key | Default | Extra          |
+---------------------+---------------+------+-----+---------+----------------+
| solution_section_id | int(10)       | NO   | PRI | NULL    | auto_increment |
| display_order       | int(10)       | NO   |     | NULL    |                |
| section_name        | varchar(1000) | YES  |     | NULL    |                |
+---------------------+---------------+------+-----+---------+----------------+
3 rows in set (0.00 sec)

mysql> describe suggested_solution_comments;

+-----------------------+----------------+------+-----+---------+----------------+
| Field                 | Type           | Null | Key | Default | Extra          |
+-----------------------+----------------+------+-----+---------+----------------+
| comment_id            | int(10)        | NO   | PRI | NULL    | auto_increment |
| problem_id            | int(10)        | NO   |     | NULL    |                |
| suggested_solution_id | int(10)        | NO   |     | NULL    |                |
| commenter_id          | int(10)        | NO   |     | NULL    |                |
| comment               | varchar(10000) | YES  |     | NULL    |                |
| solution_part         | int(3)         | NO   |     | NULL    |                |
| date                  | date           | NO   |     | NULL    |                |
+-----------------------+----------------+------+-----+---------+----------------+


mysql> describe users;
+--------------+---------------+------+-----+---------+----------------+
| Field        | Type          | Null | Key | Default | Extra          |
+--------------+---------------+------+-----+---------+----------------+
| user_id      | int(10)       | NO   | PRI | NULL    | auto_increment |
| first_name   | varchar(100)  | NO   |     | NULL    |                |
| last_name    | varchar(100)  | NO   |     | NULL    |                |
| email        | varchar(150)  | NO   |     | NULL    |                |
| user_pass    | varchar(40)   | NO   |     | NULL    |                |
| zip          | varchar(100)  | NO   |     | NULL    |                |
| country      | varchar(100)  | NO   |     | NULL    |                |
| city         | varchar(100)  | NO   |     | NULL    |                |
| state        | varchar(100)  | NO   |     | NULL    |                |
| lat          | float(9,6)    | YES  |     | NULL    |                |
| lng          | float(9,6)    | YES  |     | NULL    |                |
| agreed_terms | tinyint(1)    | YES  |     | NULL    |                |
| join_date    | date          | NO   |     | NULL    |                |
| last_login   | date          | NO   |     | NULL    |                |
| bio_blurb    | varchar(5000) | YES  |     | NULL    |                |
+--------------+---------------+------+-----+---------+----------------+
15 rows in set (0.03 sec)

mysql> describe member_photo;
+-------------------+---------------+------+-----+---------+----------------+
| Field             | Type          | Null | Key | Default | Extra          |
+-------------------+---------------+------+-----+---------+----------------+
| photo_id          | int(10)       | NO   | PRI | NULL    | auto_increment |
| member_id         | int(10)       | NO   |     | NULL    |                |
| photo_description | varchar(3000) | YES  |     | NULL    |                |
| photo_path        | varchar(1000) | NO   |     | NULL    |                |
| small_thumb       | varchar(1000) | YES  |     | NULL    |                |
| mid_thumb         | varchar(1000) | YES  |     | NULL    |                |
| is_main_photo     | tinyint(1)    | YES  |     | NULL    |                |
+-------------------+---------------+------+-----+---------+----------------+

И у меня есть такой запрос:

select comment_id,
       commenter_id,
       section_name,
       comment,
       solution_part,
       display_order,
       solution_section_id,
       suggested_solution_id, 
       DAYOFMONTH(date),
       DAYNAME(date),
       YEAR(date),
       MONTH(date),
       first_name,
       last_name,
       email,
       small_thumb,
       mid_thumb 
from solution_sections 
left join suggested_solution_comments on
    solution_sections.solution_section_id = suggested_solution_comments.solution_part 
left join users on
    suggested_solution_comments.commenter_id = users.user_id  
left join member_photo on
    suggested_solution_comments.commenter_id = member_photo.member_id
where suggested_solution_id = 61 OR 
      suggested_solution_id IS NULL
order by solution_section_id,
         comment_id,
         section_name,
         comment,
         solution_part,
         display_order;

Что он должен сделать, это получить каждое имя_раздела из таблицы solution_sections, а затемнайти комментарии (и данные о том, кто прокомментировал).Иногда нет комментариев, но он все равно должен возвращать хотя бы строку с section_name и всеми другими значениями, равными NULL.

Но по какой-то причине это не так.И самая странная часть в том, что если я дам ему другой предлагаемый_согласующий_идентификатор для сопоставления, он вернет все строки разделов решения.

Есть идеи, почему такое может произойти?Спасибо !!

И я только что понял одну вещь - если для какой-то проблемы_ был сделан другой комментарий, этот запрос не вернет строку с этим разделом.

Ответы [ 2 ]

1 голос
/ 08 ноября 2011

Вам необходимо левое внешнее объединение для просмотра всех записей из родительской таблицы, когда дочерние записи не гарантированно завершаются. Я также избегал бы добавления предложения where при использовании внешних объединений. Я думаю, что было бы удобнее читать объединение и отфильтровывать результаты. Попробуйте что-то вроде этого:

select * from 
(
    select sc.comment_id,
           sc.commenter_id,
           ss.section_name,
           sc.comment,
           sc.solution_part,
           ss.display_order,
           ss.solution_section_id,
           sc.suggested_solution_id, 
           DAYOFMONTH(sc.date),
           DAYNAME(sc.date),
           YEAR(sc.date),
           MONTH(sc.date),
           u.first_name,
           u.last_name,
           u.email,
           mp.small_thumb,
           mp.mid_thumb 
    from solution_sections ss
    left outer join suggested_solution_comments sc on ss.solution_section_id = sc.solution_part
    left outer join users u on sc.commenter_id = u.user_id  
    left outer join member_photo mp on sc.commenter_id = mp.member_id) a
where a.suggested_solution_id = 61 OR 
      a.suggested_solution_id IS NULL
order by a.solution_section_id,
         a.comment_id,
         a.section_name,
         a.comment,
         a.solution_part,
         a.display_order;

РЕДАКТИРОВАТЬ:

select sc.comment_id,
       sc.commenter_id,
       ss.section_name,
       sc.comment,
       sc.solution_part,
       ss.display_order,
       ss.solution_section_id,
       sc.suggested_solution_id, 
       DAYOFMONTH(sc.date),
       DAYNAME(sc.date),
       YEAR(sc.date),
       MONTH(sc.date),
       u.first_name,
       u.last_name,
       u.email,
       mp.small_thumb,
       mp.mid_thumb 
from solution_sections ss
left outer join suggested_solution_comments sc on ss.solution_section_id = sc.solution_part 
                                               AND sc.suggested_solution_id = 61
left outer join users u on sc.commenter_id = u.user_id  
left outer join member_photo mp on sc.commenter_id = mp.member_id
order by solution_section_id,
         comment_id,
         section_name,
         comment,
         solution_part,
         display_order;
1 голос
/ 08 ноября 2011

Если вы хотите показать solution_sections, даже если все остальные не существуют, вы можете использовать «left external join»:

select comment_id,commenter_id, section_name, comment, solution_part, 
    display_order, solution_section_id, suggested_solution_id, 
    DAYOFMONTH(date), DAYNAME(date), YEAR(date), MONTH(date), 
    first_name, last_name, email, small_thumb,mid_thumb 
from solution_sections 
left outer join suggested_solution_comments on  solution_sections.solution_section_id = suggested_solution_comments.solution_part 
    and suggested_solution_id = 61
left outer join users on  suggested_solution_comments.commenter_id = users.user_id  
left outer join member_photo on  suggested_solution_comments.commenter_id = member_photo.member_id
where solution_section_id = ????
order by solution_section_id, comment_id, section_name, comment, solution_part,display_order;

psпопробуйте использовать псевдонимы для таблиц, это более читабельно: -)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...