Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: выборка из бд

Сообщения:  [1-2] 

 
 автор: Trianon   (02.12.2007 в 22:35)   письмо автору
 
   для: Devona   (02.12.2007 в 20:49)
 

Для тех, у кого вышестоящая реплика вызвала a sense of obligation, имеет смысл пояснить, что задание, видимо, сформулировано в контексте Microsoft SQL server.

   
 
 автор: Devona   (02.12.2007 в 20:49)   письмо автору
 
 

Написать SQL-запрос, возвращающий название фирмы и ее телефон. В результате должны быть представлены все фирмы по одному разу. Если у фирмы нет телефона, нужно вернуть пробел или прочерк. Если у фирмы несколько телефонов, нужно вернуть любой из них.

так же вернуть фирму, имеющую максимальное кол-во телефонов

на каждое задание - 1 запрос

Исходные данные:


Таблица Firms:
ID Name
1 Sony
2 Panasonic
3 Samsung

Таблица Phones:
phone_id FirmID Phone
1 1 332-55-56
2 1 332-50-01
3 2 256-39-11

Для представленного примера запрос должен вернуть:
Name Phone
Sony 332-55-56
Panasonic 256-39-11
Samsung




2/
Таблицы:
create table company (compid int identity(1,1) primary key, name nvarchar(100) not null)
create table goods (goodid int identity(1,1) primary key, name nvarchar(100) not null)
create table shipment (shipid int identity(1,1) primary key, compid int not null, goodid int not null, quantity float not null, shipdate datetime not null)

set identity_insert company on
insert company (compid, name) values (1, 'Intel')
insert company (compid, name) values (2, 'IBM')
insert company (compid, name) values (2, 'Compaq')
set identity_insert company off

set identity_insert goods on
insert goods (goodid, name) values (1, 'Pentium IV')
insert goods (goodid, name) values (2, 'Celeron')
set identity_insert goods off

insert shipment (compid, goodid, quantity, shipdate) values (1, 1, 100, '02/04/2004')
insert shipment (compid, goodid, quantity, shipdate) values (1, 1, 200, '02/12/2004')
insert shipment (compid, goodid, quantity, shipdate) values (1, 2, 300, '03/02/2004')
insert shipment (compid, goodid, quantity, shipdate) values (1, 2, 400, '03/09/2004')
insert shipment (compid, goodid, quantity, shipdate) values (2, 1, 100, '01/29/2004')
insert shipment (compid, goodid, quantity, shipdate) values (2, 1, 200, '02/06/2004')
insert shipment (compid, goodid, quantity, shipdate) values (2, 2, 300, '02/29/2004')
insert shipment (compid, goodid, quantity, shipdate) values (2, 2, 400, '03/01/2004')

1. Вывести общий объем поставок каждого из продуктов для каждой фирмы
с указаниеи даты последней поставки

2. Аналогично предыдущему, но за последние 30 дней. Если поставки
какого-либо из товаров для компании в этот период отсутствовали,
вывести в столбце объема 'No data'

Таблица Phones:
phone_id FirmID Phone
1 1 332-55-56
2 1 332-50-01
3 2 256-39-11


Для представленного примера запрос должен вернуть:
Name Phone
Sony 332-55-56
Panasonic 256-39-11
Samsung

   

Сообщения:  [1-2] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования