С Новым годом! Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.84/103: Рейтинг темы: голосов - 103, средняя оценка - 4.84
0 / 0 / 0
Регистрация: 14.10.2019
Сообщений: 7

База Поликлиника SQL

16.04.2020, 10:17. Показов 21923. Ответов 5

Студворк — интернет-сервис помощи студентам
Друзья помогите доделать работу!!! НЕ могу дальше врубиться как делать, особенно где нужно сделать выборку из двух таблиц. И там где есть по метки типа
-- НЕ работает
-- НЕ ПРАВИЛЬНО!!!!
тоже нужна ваша помощь!!!!


T-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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
USE master;
GO
DROP DATABASE Поликлиника;
GO
 
CREATE DATABASE Поликлиника
 
Go
-- Удаление таблицы
DROP TABLE patcient
GO
-- Удаление таблицы
DROP TABLE disstributor
GO
-- Удаление таблицы
DROP TABLE treatrment
GO
create table patcient  -- Создание таблицы patient, где храниться информация пациентах
(
patcient_id int not null primary key,      -- ID пациента 
patcient_name varchar(50) not null,        -- имя пациента 
adress varchar(50) not null,              -- адрес пациента 
marital_status varchar(50) not null,      -- социальный статус пациента 
sem_pol varchar(50) not null,             -- семейное положение
year_of_birth  int not null,              -- год рождения пациента 
);
GO
create table disstributor   -- Создание таблицы distributor , где храниться информация о лечении, назначении пациента
(
doctor_id int not null primary key,       -- ID доктора
doctor_name varchar(50) not null,         -- имя доктора 
adress varchar(50) not null,              -- адрес доктора 
qualification varchar(50) not null,       -- квалификация доктора
specialization varchar(50) not null,      -- специализация доктора 
);
GO
 
create table treatrment   -- Создание таблицы treatrment, где храниться информация о лечении, назначении пациента  
(
patcient_id int not null primary key,                                   -- ID пациента 
doctor_id int not null references disstributor(doctor_id),             -- ID доктора 
treatrment_name varchar(50) not null,                                  -- название лечения
start_date varchar(50) not null,                                       -- дата начала лечения 
period int not null,                                                   -- длительность лечения            
);
GO
 
insert into patcient values (1,'Иванов Иван Иванович','Минск','Студент','холост','2005');
insert into patcient values (2,'Петров Петр Петрович','Гомель','Инжинер','холост','2000');
insert into patcient values (3,'Сидоров Петр Иванович','Осиповичи','Врач','женат','1995');
insert into patcient values (4,'Ионов Николай Иванович','Пинск','Рабочий','женат','2001');
insert into patcient values (5,'Николаев Иван Петрович','Гродно','Механик','женат','2005');
insert into patcient values (6,'Петров Семен Петрович','Гомель','Инжинер','холост','2008');
insert into patcient values (7,'Петров Семен Петрович','Гомель','Инжинер','холост','1988');
insert into patcient values (8,'Шкляр Семен Петрович','Столин','Инжинер','холост','1988');
GO
 
 
insert into disstributor values (1,'Иванов Иван Иванович','Минск','Средняя','Невролог');
insert into disstributor values (2,'Крупник Петр Петрович','Брест','Высшая','Терапевт');
insert into disstributor values (3,'Сидоров Петр Иванович','Гродно','Средняя','Травмотолог');
insert into disstributor values (4,'Иванов Николай Иванович','Минск','Высшая','Хирург');
insert into disstributor values (5,'Попов Иван Петрович','Гомель','Высшая','Кардиолог');
insert into disstributor values (6,'Крумкач Кирилл Петрович','Клецк','Средняя','Кардиолог');
insert into disstributor values (7,'Бобко Дминтрий Петрович','Пинск','Средняя','Хирург');
insert into disstributor values (8,'Секач Кирилл Иванович','Клецк','Средняя','Кардиолог');
GO
 
insert into treatrment values (1,2,'Операция','28-05-1995','7');
insert into treatrment values (2,1,'Восполение легких','20-05-2005','15');
insert into treatrment values (3,5,'Герпес','20-03-2005','27');
insert into treatrment values (4,4,'Невроз','20-02-2005','9');
insert into treatrment values (5,3,'Крапивница','20-04-2005','16');
insert into treatrment values (6,3,'Крапивница','20-04-2005','16');
insert into treatrment values (7,3,'Крапивница','20-04-2005','16');
insert into treatrment values (8,3,'Крапивница','20-04-2005','18');
GO
 
--1.Выдать всю имеющуюся информацию о докторах.
 
SELECT * FROM disstributor
GO
 
-- проверка 
SELECT * FROM patcient
GO
 
SELECT * FROM treatrment
GO
--2.Выбрать имена и адрес всех пациентов.
 
SELECT patcient_name [Ф.И.О.], adress [Адрес пациента]  FROM patcient
GO
 
--3.Выбрать имена всех пациентов, проживающих в Минске.
 
SELECT patcient_name [Ф.И.О.], adress [Адрес пациента] FROM patcient WHERE adress='Минск';
GO
 
--4.Выбрать имена всех докторов, работающих в Минске или Гомеле.
 
SELECT doctor_name [Ф.И.О.], adress [Адрес доктора] FROM disstributor WHERE adress='Минск' or adress='Гомель';
GO
 
--5.Выбрать имена всех пациентов, которые женаты и родились в 2005 году.
 
SELECT patcient_name [Ф.И.О.], sem_pol [Семейное положение], year_of_birth [Год рождения]  FROM patcient WHERE sem_pol='женат' and year_of_birth='2005'
GO
 
--6.Выбрать название лечения, у которого период не равен 15 дней.
SELECT treatrment_name [Название лечения], period [Срок лечения] FROM treatrment WHERE period<>'15'
GO
 
--проверка
SELECT * FROM treatrment
GO
 
--7.Выбрать имена всех докторов, которые находятся в Гомеле и имеют специализацию "кардиолог"
 
SELECT doctor_name [Ф.И.О.], adress [Адрес доктора], specialization [Специализация] FROM disstributor WHERE adress='Гомель' and specialization='Кардиолог'
GO
 
--8.Выбрать название лечения, для которых дата начала равна 28-05-1995 и период лечения принадлежит множеству 3. 5, 7. 9.
 
SELECT treatrment_name [Название лечения]  FROM treatrment WHERE start_date='28-05-1995' and period in (3,5,7,9) 
GO
 
--9.Выбрать имена всех докторов, у которых специализация ТРАВМАТОЛОГ, и город проживания принадлежит множеству Гомель , Минск, Гродно.
--1
 
SELECT doctor_name [Ф.И.О.], specialization [Специализация], adress [Адрес доктора] FROM disstributor WHERE specialization='Травмотолог' and adress in ('Гомель', 'Минск', 'Гродно')
GO
 
--2
 
SELECT doctor_name [Ф.И.О.], specialization [Специализация], adress [Адрес доктора] FROM disstributor WHERE specialization='Травмотолог' or adress ='Гомель' and adress='Минск' and adress='Гродно'
GO
 
--10.Вычистить значение выражения 36*55-30 с помощью SQL.
 
SELECT 36*55-30
GO
 
--11.Выбрать имена всех докторов, у город проживания начинается с буквы "К".
 
SELECT doctor_name [Ф.И.О.], adress [Адрес доктора] FROM disstributor WHERE adress LIKE 'К%';
GO
 
--12. Выбрать имена всех пациентов, у которых адрес проживания начинается с буквы “М” и год рождении не заканчивается на 6.
 
SELECT patcient_name [Ф.И.О.], adress [Адрес пациента], year_of_birth [Год рождения] FROM patcient WHERE adress LIKE 'М%' and year_of_birth not like '%6' 
GO
 
 
--13. Вывести все виды лечений, у которых в названии есть слово “операция”.
SELECT treatrment_name [Вид лечения] FROM treatrment WHERE treatrment_name LIKE '%операция%'
GO
 
--14. Вывести специализации врачей без повторений.
SELECT DISTINCT  specialization [Специализация] FROM disstributor
GO
 
--15. Посчитать количество видов лечений, для которых период лечения равен 15 дней.
 
SELECT count (treatrment_name) [Количество видов лечения] FROM treatrment WHERE period=15 
GO
 
--16. Вычислить максимальный период лечения для видов, которые были начаты 20-05-2005.
 
SELECT max (period) [максимальный период лечения] FROM treatrment WHERE start_date = '20-05-2005'
GO
 
--17. Вычислить минимальный год рождения пациентов, проживающих Гомеле.
 
SELECT min (year_of_birth)[Год рождения] FROM patcient  WHERE adress ='Гомель' 
GO
 
--18. Вычислить среднее количество дней, которое уходит на лечение пациентов, год рождения которых 1988.
 
SELECT AVG(period)[Среднее количество дней], year_of_birth [Год рождения]  FROM treatrment e
JOIN patcient s  ON e.patcient_id=s.patcient_id  AND year_of_birth='1988' group by year_of_birth 
GO
 
--19. Вывести наименование лечения, у которого период лечения меньше 10 дней в алфавитном порядке.
 
 SELECT treatrment_name, period FROM treatrment e
 JOIN patcient s  ON e.patcient_id=s.patcient_id WHERE period<10 order by  treatrment_name ASC 
 GO
 
--20. Вычислить среднее количество дней в лечении для каждого из пациентов.
 
SELECT patcient_name [Имя пациента], AVG(period)[Среднее количество дней лечения] FROM treatrment e 
JOIN patcient s  ON e.patcient_id=s.patcient_id    group by patcient_name
GO
 
--21. Вывести все название лечений, у которых средняя продолжительность лечения больше 17 дней.
 
SELECT   treatrment_name, AVG(period) FROM treatrment e 
join patcient s on e.patcient_id=s.patcient_id 
WHERE period>17 group by e.treatrment_name 
Go
 
--22. Вывести все названия лечений, у которых дата начала не ранее 20-03-2005, их в обратном порядке по периоду.
-- не точно
 
SELECT  treatrment_name, start_date FROM treatrment WHERE  start_date CAST(start_date as date) >='20-03-2005'
order by  treatrment_name DESC
GO
 
--23. Вывести список пациентов в виде ‘Пациента’ ['имя пациента'] ‘лечит доктор’ [‘имя доктора’].
--работает  но не точно 
 
SELECT  patcient_name [имя_пациента],  d.doctor_name [имя_доктора] FROM  disstributor  d, patcient s 
JOIN treatrment e on s.patcient_id=e.patcient_id
JOIN disstributor on  e.doctor_id=e.doctor_id
GO
--работает  но не точно 
SELECT  patcient_name [имя_пациента],  doctor_name [имя_доктора] FROM  disstributor  d, patcient s, patcient e
 WHERE  s.patcient_id=e.patcient_id and e.doctor_id=e.doctor_id GROUP BY patcient_name
GO
 
 
--24. Вывести все названия лечений, у которых период равен среднему периоду лечения для пациентов, начавших лечение 20-03-2005.
--25. Вывести названия всех лечений, которые проводят врачи, проживающие в Минске.
--26. Вывести имена всех врачей, у которых количество пациентов более 5.
 
-- НЕ ПРАВИЛЬНО!!!!
 
SELECT doctor_name [имя_доктора], patcient_id, COUNT(*)
    FROM disstributor d
        JOIN patcient e
            ON d.doctor_id = e.patcient_id
                AND patcient_id = 5
    GROUP BY patcient_id
    GO
--27. Вывести имена всех пациентов, которых лечит врач ИВАНОВ.
 
-- Не работает
SELECT   patcient_name FROM patcient s
JOIN treatrment e  on  s.patcient_id=e.patcient_id
JOIN disstributor d  on d.doctor_id=e.doctor_id
WHERE doctor_name ='%ИВАНОВ%' 
Go
 
--28. Вывести имена всех пациентов, которых лечат врачи высшей квалификации.
--29. Вывести имена всех пациентов, назначенное им лечение, а также имена врачей, которых их лечат.
--30. Вывести квалификацию всех врачей, у которых количество пациентов более 4.
--31. Вывести имена пациентов, которые живут в том же городе, что и их лечащий врач.
--32. Вывести имена всех врачей, которые начали лечение 20-04-2005 и период лечения 10 дней.
--33. Вывести название всех городов, в которых живут пациенты, а также названия городов, в которых проживают врачи.
--34. Вывести год рождения пациентов, которых лечат врачи из Минска и Гомеля.
 
SELECT patcient_name, year_of_birth,  FROM patcient s
 
JOIN treatrment e  on  s.patcient_id=e.patcient_id
JOIN disstributor d  on d.doctor_id=e.doctor_id
WHERE d.adress IN ('Минск','Гомель');
 
 
--35. Изменить квалификацию докторов с СРЕДНЯЯ на ВЫСШАЯ.
--36. Увеличить период лечения на 5 дней для пациентов, у которых период лечения равен 7 дням.
--37. Уменьшить дату начала лечения на 7 дней для пациентов, проживающих в Гомеле.
--38. Удалить из таблицы пациентов, которые проживают в городе Осиповичи.
--39. Удалить из таблицы все виды лечений, которые назначали врачи, имеющие специализацию, ХИРУРГ.
--40. Удалить из таблицы всех пациентов, у которых период лечения менее 25 дней, и пациенты проживают в Минске.
--41. Написать SQL запрос, который добавляет врача в таблицу doctor.
 
INSERT INTO disstributor (doctor_id, doctor_name, adress, qualification, specialization)  
VALUES (9, 'Семак Алексей Павлович', 'Солигорск', 'Высшая', 'Стоматолог');
Go
 
--42. Написать SQL запрос, который создает таблицу как результат выполнения команды SELECT.
--43. Написать SQL запросы, которые создавали бы таблицы patient, treatment, doctor.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.04.2020, 10:17
Ответы с готовыми решениями:

База данных поликлиника
Здравствуйте. Делаю БД поликлиника по заданию, посмотрите пожалуйста правильно ли составил ее структуру и схему данных. Задание:...

База Данных Платная Поликлиника!
Нужно создать базу данных? Кто может помочь сделать? или у кого есть готовая? буду благодарен ! Платная поликлиника ...

База данных "Поликлиника". Делаем вместе
Вообщем скажу сразу - я не прошу кого то сделать за меня. Просто парочка наставлений и указаний по работе с бд. Итак. Создаю бд. Нужно: ...

5
5958 / 4534 / 1094
Регистрация: 29.08.2013
Сообщений: 28,139
Записей в блоге: 3
16.04.2020, 10:42
Цитата Сообщение от Анатолий90 Посмотреть сообщение
НЕ могу дальше врубиться как делать, особенно где нужно сделать выборку из двух таблиц
про JOIN почитай

база кривая
1
0 / 0 / 0
Регистрация: 14.10.2019
Сообщений: 7
16.04.2020, 11:45  [ТС]
Спасибо! Уже читаю. А базу как смог так сделал. Если можете, помочь или подсказать как нужно правильно, то буду вам весьма признателен за помощь.
0
5958 / 4534 / 1094
Регистрация: 29.08.2013
Сообщений: 28,139
Записей в блоге: 3
16.04.2020, 12:26
поля
marital_status varchar(50) not null, -- социальный статус пациента
sem_pol varchar(50) not null, -- семейное положение
qualification varchar(50) not null, -- квалификация доктора
specialization varchar(50) not null, -- специализация доктора
нужно сделать справочниками

по полям по которым идет соединение надо сделать индекс
0
0 / 0 / 0
Регистрация: 14.10.2019
Сообщений: 7
16.04.2020, 14:10  [ТС]
Чтоб я еще знал как это делается, я бы обязательно сделал. Но я непременно это учту на будущее. Но для начало мне нужно научиться самому простому, а потом уже переходить на ступеньку выше.

Добавлено через 2 минуты
Может у вас есть хорошая готовая база с пояснениями, что, где и как связывается и т.д. Для тренировки, так сказать на кошках. Заранее спасибо!
0
5958 / 4534 / 1094
Регистрация: 29.08.2013
Сообщений: 28,139
Записей в блоге: 3
16.04.2020, 14:14
база с пояснениями?
это как легкая работа где ничего не надо делать и платят зарплату?

такой базы нет, читай ниги, разбирай примеры
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.04.2020, 14:14
Помогаю со студенческими работами здесь

База данных "Поликлиника" (ВКР)
Здравствуйте! Помогите, пожалуйста с созданием бд &quot;Поликлиника&quot; (ВКР)!Суть всей бд в том, что там хранилась информация о врачах, пациентах,...

База данных "Поликлиника"
Здравствуйте! Я сделала базу данных и 1 запрос в ней, но он почему то не сохраняет строчки в таблице после его выполнения:( Преподаватель...

База данных "Поликлиника"
Ребята,у меня полная неразбериха.Выручайте!Преподаватель как то поверхностно объяснил что нужно от моей базы данных.Посмотрите пожалуйста и...

База данных, основанная на службах vs База данных SQL Server
Доброго времени суток. Делал я, значит, Data Access Layer для ASP.NET MVC проекта. Создал обычную библиотеку классов, моделей туда...

Переход (совмещение) Access и SQL (работающая база Access в SQL)
Имеется вот какая задача: существует база данных Access (работает более 5 лет, более 160 таблиц и более 15000 запросов, макросы),...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru