Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Запрос для получения количества новых сообщений 
:(
    Опции темы
scroollocker
Дата 1.2.2015, 17:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


.{--}.



Профиль
Группа: Участник
Сообщений: 40
Регистрация: 17.9.2010

Репутация: нет
Всего: нет



Здравствуйте,

требуется решить следующий вопрос:
есть 2 таблицы
table1
  •     id
  •     name
  •     text
  •     user_id


table2
  •     id
  •     text
  •     table1_id
  •     read

read может быть либо 1 либо 0 - прочитано или нет

Нужно сделать такой запрос, чтобы показались все записи из первой таблицы, количество записей из table2, относящихся к table1 по table1_id и количество непрочитанных записей по полю read.
И возможно ли уместить это все в один запрос? Или лучше изменить структуру таблиц? если да, то как лучше?

что уже есть:
Код

    create table table1(id integer primary key autoincrement, name varchar(20),text varchar(20),user_id integer);
    create table table2(id integer primary key autoincrement, text varchar(20),table1_id integer,read integer);
    insert into table1(name,user_id) values('test1',1);
    insert into table2(text,table1_id,read) values('test_text1',1,1);
    insert into table2(text,table1_id,read) values('test_text2',1,1);
    insert into table2(text,table1_id,read) values('test_text3',1,0);
    insert into table2(text,table1_id,read) values('test_text4',1,0);
    select `a`.`name`,count(`b`.`id`) from `table1` as `a` left join `table2` as `b` on `a`.`id` = `b`.`table1_id` where `a`.`user_id` = 1;

http://ideone.com/Y8DCF6

как добавить еще вывод новых записей ?

Спасибо. 
PM MAIL WWW ICQ Jabber   Вверх
Akina
Дата 2.2.2015, 09:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 45
Всего: 454



Цитата(scroollocker @  1.2.2015,  18:09 Найти цитируемый пост)
количество непрочитанных записей по полю read

Код

SUM(read = 0)



--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
ТоляМБА
Дата 2.2.2015, 09:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Котэ
***


Профиль
Группа: Завсегдатай
Сообщений: 1607
Регистрация: 15.12.2004

Репутация: 4
Всего: 252



Код
select id, name, "text", "user_id",
(select count(t1.id)
from table1 t1
inner join table2 t2
on t1.id=t2.table1_id) as a,
(select count(t1.id)
from table1 t1
inner join table2 t2
on t1.id=t2.table1_id
where t2."read"=0) as b
from  table1


Ты не указал СУБД, я делал на MS SQL.
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




[ Время генерации скрипта: 0.0841 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.