Главная
страница 1страница 2 ... страница 8страница 9

Министерство образования и науки Российской Федерации


Кузнецкий институт информационных и управленческих технологий

БАЗЫ ДАННЫХ

Методические указания


к лабораторным работам


Кузнецк 2011

Лабораторная работа N 1

Тема: Выборка данных из базы данных с использованием языка SQL


Цель работы: изучить принципы работы с базой данных в архитектуре клиент-сервер, изучить спецификации запроса языка баз данных SQL, получить практические навыки составления и содержательной интерпретации запросов выборки данных (операторов SELECT), а также их выполнения на SQL-сервере с использованием клиентских утилит.

Порядок выполнения работы


  1. Запустить MS SQL Server 7.0 : Пуск – Программы - MS SQL Server – Enterprice Manager.

  2. Изучить структуру учебной БД PUBS (изучить состав книготорговой компании , структуру и семантику ее таблиц ).

  3. Запустить утилиту Query Analyzer, входящую в набор клиентских утилит для СУБД SQL Server : меню Tools - Query Analyzer.

  4. Изучить структуру и элементы SQL-запроса выборки, в том числе разделы FROM, WHERE, GROUP BY, HAVING, ORDER BY, а также предикаты условия поиска и агрегатные функции.

  5. Изучить операции реляционной алгебры (соединение, пересечение, объединение, разность и др.).

  6. Получить у преподавателя номер варианта задания.

  7. В соответствии с вариантом задания типа А произвести содержательную интерпретацию заданных SQL-запросов, выполнить их на SQL-сервере с использованием клиентских утилит, проинтерпретировать результаты выполнения запросов.

  8. В соответствии с вариантом задания В составить SQL-запросы по их заданному содержательному описанию, выполнить SQL-запросы на SQL-сервере с использованием клиентских утилит, проинтерпретировать результаты выполнения запросов.

  9. Оформить отчет.

Содержание отчета

1) Титульный лист; 2) цель работы; 3) тексты SQL-запросов и их содержательная интерпретация; 4) результаты выполнения запросов по заданиям типа А и В и их интерпретация; 5) выводы. 


Теоретические сведения

Язык SQL


Первый международный стандарт языка SQL был принят в 1989 г. (SQL/89). В конце 1992 г. Был принят новый международный стандарт SQL/92. “Родным” языком Microsoft SQL Server является язык Transact-SQL (T-SQL), являющийся диалектом стандартного языка SQL. T-SQL поддерживает большинство возможностей языков SQL/89 и SQL/92, а также ряд расширений, увеличивающих возможность программирования и гибкость языка. В частности, в язык T-SQL добавлены конструкции для задания последовательности операций управления в программе (например, if и while), локальных переменных и других конструкций, позволяющих писать более сложные запросы и строить программные объекты, хранящиеся на сервере, в том числе процедуры и триггеры.

Язык SQL включает следующие языки:



    • язык определения данных (Data Definition Language или DDL), предназначенный для добавления, модификации и удаления данных в таблицах;

    • язык модификации данных (Data Modification Language или DML), предназначенный для добавления, модификации и удаления данных в таблицах.

В синтаксических конструкциях при описании языка будут использоваться следующие соглашения. Нетерминальные элементы заключаются в угловые скобки <>. Необязательная конструкция заключается в квадратные скобки []. Запись вида {A}… означает повторение конструкции А произвольное число раз (включая нулевое). Вертикальные разделители | читаются как “ИЛИ” и служат для выбора одной из конструкций, заключенных в скобки. 

Оператор SELECT


Оператор SELECT используется для запросов к базе данных и выборки результатов. Синтаксис оператора SELECT следующий:

<оператор SELECT>::=

SELECT [ALL | DISTINCT] <список выборки>

<табличное выражение>

ORDER BY <спецификация сортировки>]

<табличное выражение>::=

FROM <имя таблицы>[{,<имя таблицы>}…]

[WHERE <условие поиска>]

[GROUP BY <имя столбца> [{,<имя столбца>}…]

[HAVING <условие поиска>] 

Если задано ключевое слово DISTINCT, то из результирующей таблицы удаляются повторяющиеся строки. Список выборки определяет, какие столбцы должны быть возвращены в результирующую таблицу. Данный список представляет список арифметических выражений над значениями столбцов таблиц из раздела FROM и констант. В простейшем случае он может быть, например, списком имен некоторых столбцов таблиц из раздела FROM. В случае, если вместо списка выборки стоит звездочка (*), то выбираются все столбцы таблиц из раздела FROM.

В разделе FROM определяются таблицы, из которых будут извлекаться данные. Следует отметить, что рядом с именем таблицы можно указывать еще одно имя - синоним имени таблицы, который можно использовать в других разделах табличного выражения.

Раздел WHERE служит своего рода фильтром при отборе данных.

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

Результатом выполнения раздела HAVING является сгруппированная таблица, содержащая только те группы строк, для которых результат вычисления условия поиска является истинным. Условие поиска раздела HAVING задает условие на целую группу, а не на индивидуальные строки, поэтому в данном случае прямо можно использовать только столбцы, указанные в качестве столбцов группирования в разделе GROUP BY.

Раздел ORDER BY позволяет установить желаемый порядок просмотра результирующей таблицы. Спецификация сортировки имеет следующий синтаксис:

<спецификация сортировки>::= {<целое без знака> | <имя столбца>} [ASC | DESC]

Как видно, фактически задается список столбцов, и для каждого столбца указывается порядок просмотра строк результирующей таблицы в зависимости от значений этого столбца (ASC - по возрастанию (умолчание), DESC - по убыванию). Указывать сортируемый столбец можно по имени или по порядковому номеру в результирующей таблице.  


Предикаты условия поиска


В условии поиска могут использоваться следующие предикаты: предикат сравнения, предикат BETWEEN , предикат IN, предикат LIKE, предикат NULL, предикат с квантором и предикат EXISTS.

Предикат IN определяется следующим образом:



<предикат IN>::= <выражение> [NOT] IN (<значение> [,<значение>...] | .<подзапрос>)

Значение предиката является истинным, когда значение левого операнда совпадает хотя бы с одним значением списка правого операнда. Использование ключевого слова NOT осуществляет отрицание результата.

Подзапрос- это запрос, используемый в предикате условия поиска. Результатом выполнения подзапроса является единственный столбец.

Предикат BETWEEN определяется следующим образом:



<предикат BETWEEN>::= <выражение> [NOT] BETWEEN <выражение> AND <выражение>

По определению результат x BETWEEN y AND z тот же самый, что результат логического выражения x>=y AND x<=z.

Предикат LIKE имеет следующий синтаксис:

<предикат LIKE>::= <имя столбца> [NOT] LIKE <шаблон>[ESCAPE ]

Значение предиката LIKE является истинным, если шаблон является подстрокой заданного столбца. При этом, если раздел ESCAPE отсутствует, то при составлении шаблона со строкой производится специальная интерпретация символов-заместителей шаблона: символ подчеркивания ("_") обозначает любой одиночный символ, символ процента ("%") обозначает последовательность произвольных символов произвольной длины (может быть нулевой), парные квадратные скобки представляют любой символ, записанный в скобках. Если же раздел ESCAPE присутствует и специфицирует некоторый одиночный символ x, то пары символов "x_" и "x%" представляют одиночные символы "_" и "%" соответственно.

Предикат NULL описывается синтаксическим правилом:

<предикат NULL>::= <имя столбца> IS [NOT] NULL

Значение "x IS NULL" является истинным, когда значение x неопределено.

Предикат EXISTS имеет следующий синтаксис:

<предикат EXISTS>::= EXISTS <подзапрос>

Значение предиката является истинным, когда результат вычисления подзапроса не пуст. 


Агрегатные функции


Агрегатные функции (функции множества) в запросе предназначены для вычисления некоторого значения для заданного множества строк. Таким множеством строк может быть группа строк, если агрегатная функция применяется к сгруппированной таблице, или вся таблица. В языке SQL определены следующие агрегатные функции:

    • AVG - функция определения среднего значения;

    • MAX - функция определения максимального значения;

    • MIN - функция определения минимального значения;

    • SUM - функция суммирования значений;

    • COUNT - функция для подсчета числа строк или значений.

Грамматика агрегатных функций следующая:

<агрегатная функция>::= COUNT(*) | |

::= {AVG | COUNT | MAX | MIN | SUM} (DISTINCT <имя столбца>)

::= {AVG | MAX | MIN | SUM} ([ALL]<выражение>)

Вычисление функции COUNT(*) производится путем подсчета числа строк в заданном множестве. Функция типа distinct выполняет вычисления только над одним столбцом, а в вычислениях используются только уникальные значения столбца. При использовании функции типа all список значений формируется из значений арифметического выражения, вычисляемого для каждой строки заданного множества.


Операции реляционной алгебры


Большинство SQL-запросов требует одновременного обращения к нескольким таблицам. Часто такого рода запросы основываются на операциях реляционной алгебры, в частности, соединения, декартова произведения, объединения, пересечения и разности.

При соединении двух таблиц по некоторому условию образуется результирующая таблица, строки которой являются конкатенацией (сцеплением) строк первой и второй таблиц и удовлетворяют этому условию. Операцию соединения можно реализовать с использованием обычного SQL-запроса типа SELECT-FROM-WHERE. По стандарту ANSI операция соединения таблиц может указываться явно в разделе FROM. Синтаксис раздела FROM в этом случае следующий:



<раздел FROM>::= FROM <имя таблицы> [JOIN <имя таблицы> ON <условие соединения> ...]

При выполнении декартова произведения двух таблиц производится таблица, строки которой являются конкатенацией строк первой и второй таблиц. Операцию декартова произведения можно реализовать с использованием SQL-запроса типа SELECT-FROM. По стандарту ANSI операция декартова произведения может указываться явно в разделе FROM с использованием ключевой фразы CROSS JOIN.

При выполнении операции объединения двух таблиц производится таблица, включающая все строки, входящие хотя бы в одну из таблиц-операндов. При этом число столбцов и типы данных этих столбцов должны быть одинаковыми для всех операндов. Для объединения результирующих таблиц операторов SELECT используется ключевое слово UNION.

Операция пересечения двух таблиц производит таблицу, включающую все строки, входящие в обе исходные таблицы.

Таблица, являющаяся разностью двух таблиц, включает все строки, входящие в таблицу - первый операнд, такие, что ни одна из них не входит в таблицу, являющуюся вторым операндом. 

Основные операции реляционной алгебры



  1. Проекция (projection).

Это унарная операция (выполняемая над одним отношением), служащая для выбора подмножества атрибутов из отношения R. Она уменьшает арность отношения и может уменьшить мощность отношения за счёт исключения одинаковых кортежей.

Пример 1. Пусть имеется отношение R(A,B,C) (рис.2,а).

Тогда проекция  A,C(R) будет такой, как показано на рис.2,б.

а) Отношение R


A

B

C

a

b

c

c

a

d

c

b

d

б) Проекция  A,C(R)

A

C

a

c

c

d

Рис.2. Пример проекции отношения

  1. Селекция (selection).

Это унарная операция, результатом которой является подмножество кортежей исходного отношения, соответствующих условиям, которые накладываются на значения определённых атрибутов.

Пример 2. Для отношения R(A,B,C) (рис. 3,а) селекция  C=d(R) (при условии "значение атрибута C равно d") будет такой (рис. 3,б):

а) Отношение R



A

B

C

a

b

c

c

a

d

c

b

d

б) Селекция  C=d(R)

A

B

C

c

a

d

c

b

d

Рис.3. Пример селекции отношения

  1. Декартово произведение (Cartesian product).

Это бинарная операция над разносхемными отношениями, соответствующая определению декартова произведения для РМД.

Пример 3. Пусть имеются отношение R(A,B) и отношение S(C,D,E) (рис.4,а). Тогда декартово произведение R S будет таким (рис.4,б):

а) Исходные отношения



A

B

a

B

c

A

b

D




C

D

E

g

h

a

a

b

c

б) Декартово произведение

A

B

C

D

E

a

b

g

h

a

a

b

a

b

c

c

a

g

h

a

c

a

a

b

c

b

d

g

h

a

b

d

a

b

c

Рис.4. Пример декартова произведения отношений

  1. Объединение (union).

Объединением двух односхемных отношений R и S называется отношение T = R U S, которое включает в себя все кортежи обоих отношений без повторов.

  1. Разность (set difference).

Разностью односхемных отношений R и S называется множество кортежей R, не входящих в S.

Пример 4. Пусть имеются отношение R(A,B,C) и отношение S(A,B,C) (рис.5,а). Тогда разность R–S будет такой (рис.5,б):

а) Исходные отношения



A

B

C

a

b

c

c

a

d

c

h

c




A

B

C

g

h

a

a

b

c

h

d

d

б)

A

B

C

c

a

d

c

h

c

Рис.5. Пример разности отношений

1.3.2. Вспомогательные операции реляционной алгебры



  1. Пересечение (intersection).

Пересечение двух односхемных отношений R и S есть подмножество кортежей, принадлежащих обоим отношениям. Это можно выразить через разность:

R ∩ S = R – (R – S).



  1. Соединение (join).

Эта операция определяет подмножество декартова произведения двух разносхемных отношений. Кортеж декартова произведения входит в результирующее отношение, если для атрибутов разных исходных отношений выполняется некоторое условие. Если условием является равенство атрибутов исходных отношений, такая операция называется эквисоединением. Естественным называется эквисоединение по одинаковым атрибутам исходных отношений.

Пример 5. Пусть имеются отношения R(A,B,C) и S(A,D,E) (рис.6,а). Тогда естественное соединение
R  S будет таким, как показано на рис.6,б.

а) Исходные отношения



A

B

C

a

b

c

c

a

d

c

h

c

g

b

d




A

D

E

g

h

a

c

b

c

h

d

d

б) Соединение отношений

A

B

C

D

E

c

a

d

b

c

c

h

c

b

c

g

b

d

h

a

Рис.6. Пример естественного соединения отношений

  1. Деление (division).

Пусть отношение R содержит атрибуты {r1,r2,...,ri,...,rn}, а отношение S – атрибуты {r1,r2,...,ri}. Результирующее отношение содержит атрибуты {ri+1,...,rn}. Кортеж включается в результирующее отношение, если его декартово произведение с каким-либо кортежем отношения S входит в R.

Пример 6. Пусть имеются отношения R(A,B,C) и S(A,B) (рис. 7,а). Тогда частное R/S будет таким как показано на рис. 7,б.

а) Исходные отношения



A

B

C

D

a

b

c

f

c

b

a

b

g

h

d

c

c

b

b

c




A

B

g

h

c

b

b

a

б) Частное

C

D

d

c

a

b

b

c

Рис.7. Пример операции деления

 

Описание задания


База данных книготорговой компании


Рассмотрим простую предметную область жизнедеятельности, связанную с книгоизданием и маркетингом. В рамках данной предметной области существуют издатели, которые публикуют книги, авторы, которые книги пишут, и издания (сами книги). Разработана база данных pubs, определяющая описанную выше предметную область. Инфологическая модель предметной области с использованием диаграмм “сущность-связь” (ER-диаграмм) [1]), разработанных Ченом, представлена на рис. 1.

На данном рисунке прямоугольниками обозначены типы сущностей (объектов), а ромбами - типы связей между сущностями. Атрибуты сущностей указаны мелким шрифтом в том же прямоугольнике, который отображает типы сущностей. Имя типа сущности отмечено в верхней части прямоугольника жирным шрифтом. Атрибуты связей в данном случае обозначены овалами. Как видно из рис. 1 у связи “Написана” имеется два атрибута: первый атрибут определяет порядок автора в названии книги, второй атрибут - гонорар автора книги.



Рис. 1


База данных книготорговой компании (база данных pubs) включает три таблицы, определяющие сущности: таблица authors определяет авторов, таблица publishers - издателей, а таблица titles - сами книги. Четвертая таблица titleauthor задает отношение между таблицами titles и authors. Она показывает, какие авторы написали какие книги. Связь между таблицами titiles и publishers определяется столбцом pub_id в данных таблицах.

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



Структура таблицы authors

Имя столбца

Тип данных

Размерность

Возможность значений null

Содержательное описание

au_id

varchar

11

Нет

Идентификатор автора

au_lname

varchar

40

Нет

Фамилия автора

au_fname

varchar

20

Нет

Имя автора

phone

char

12

Нет

Номер телефона

address

varchar

40

Да

Адрес (улица, дом, квартира)

city

varchar

20

Да

Город проживания

state

char

2

Да

Штат проживания

zip

char

5

Да

Энергичность

contract

bit

1

Нет

Наличие контракта

Структура таблицы publishers

Имя столбца

Тип данных

Размерность

Возможность значений null

Содержательное описание

pub_id

char

4

Нет

Идентификатор издательства (издателя)

pub_name

varchar

40

Да

Название издательства (имя издателя)

city

varchar

20

Да

Город

state

char

2

Да

Штат

country

varchar

30

Да

Страна

 Структура таблицы titles

Имя столбца

Тип данных

Размерность

Возможность значений null

Содержательное описание

title_id

varchar

6

Нет

Идентификатор книги

title

varchar

80

Нет

Название книги

type

char

12

Нет

Тип книги

pub_id

char

4

Да

Идентификатор издательства

price

money

8

Да

Цена

advance

money

8

Да

Аванс (стоимость предварительной продажи)

royalty

int

4

Да

Гонорар

ytd_sales

int

4

Да

Число книг, проданных в текущем году

notes

varchar

200

Да

Замечания

pubdate

datetime

8

Нет

Дата опубликования

 Структура таблицы titleauthor

Имя столбца

Тип данных

Размерность

Возможность значений null

Содержательное описание

au_id

varchar

11

Нет

Идентификатор автора книги

title_id

varchar

6

Нет

Идентификатор книги

au_ord

tinyint

1

Да

Порядок автора в названии книги

royaltyper

int

4

Да

Авторский гонорар

 В столбце type таблицы titles используются следующие типы книг: business - книги по бизнесу, mod_cook - книги по современной кулинарии, popular_comp - книги по компьютерной тематике, psychology - книги по психологии, trad_cook - книги по традиционной кулинарии, UNDECIDED - неопределенный тип книги.

В столбцах state таблиц authors и publishers используются следующие обозначения административных единиц США: CA - штат Калифорния, DC - округ Колумбия, IL - штат Иллинойс, IN - штат Индиана, KS -штат Канзас, MD - штат Мэриленд, MA - штат Массачусетс, MI - штат Мичиган, NY - штат Нью-Йорк, OR - штат Орегон, TN - штат Теннесси, TX - штатТехас, UT - штат Юта.

В столбце country таблицы publishers используются следующие обозначения стран: France - Франция, Germany - Германия, USA - США.

Домен городов, используемый в таблицах authors и publishers, включает города Ann Arbor, Berkeley, Boston, Chicago, Corvallis, Colevo, Dallas, Gary, Lawrence, Menlo Park, Munchen, Nashville, New York, Oakland, Palo Alto, Paris, Rockville, Salt Lake City, San Francisco, San Jose, Vacaville, Walnul Creek, Washington.

В приложении 1 приведен полный пример базы данных pubs.

Лабораторные задания типа А


Дать содержательную интерпретацию SQL-запросам, выполнить их на SQL-сервере с использованием клиентских утилит ISQL/w или SQL-EM, дать содержательную интерпретацию результатам выполнения SQL-запросов. 

1) SELECT au_lname, au_fname

FROM authors

2) SELECT au_lname, au_fname

FROM authors

ORDER BY au_lname

3) SELECT au_lname, au_fname

FROM authors

ORDER BY au_lname, au_fname

4) SELECT title_id, price, ytd_sales,

price*ytd_sales "ytd dollar sales"

FROM titles

ORDER BY price*ytd_sales

5) SELECT title_id, price, ytd_sales,

price*ytd_sales "ytd dollar sales"

FROM titles

ORDER BY price*ytd_sales DESC

6) SELECT title_id, type, ytd_sales

FROM titles

ORDER BY type ASC, ytd_sales DESC

7) SELECT AVG(price)

FROM titles

8) SELECT DISTINCT type

FROM titles

ORDER BY type ACS

9) SELECT DISTINCT city

FROM authors

ORDER BY city DESC

10) SELECT DISTINCT state

FROM authors

ORDER BY state

11) SELECT DISTINCT country

FROM publishers

ORDER BY country DESC

12) SELECT AVG(price), AVG(DISTINCT price)

FROM titles

13) SELECT *

FROM titles

14) SELECT au_lname, au_fname

FROM authors

WHERE state= "CA"

15) SELECT type, title_id, price

FROM titles

WHERE price*ytd_sales < advance

16) SELECT au_id, city, state

FROM authors

WHERE state= "CA" OR city= "Palo Alto"

17) SELECT title_id, price

FROM titles

WHERE price between $5 AND $15

18) SELECT title_id, price

FROM titles

WHERE type IN ("mod_cook", "trad_cook", "business")

19) SELECT au_lname, au_fname, city, state

FROM authors

WHERE city like "San%"

20) SELECT type, title_id, price

FROM titles

WHERE title_id like "B_2075"

21) SELECT type, title_id, price

FROM titles

WHERE title_id like "B[AUN]7832"

22) SELECT AVG(price) "AVG"

FROM titles

WHERE type= "business"

23) SELECT AVG(price) "avg" SUM(price) "sum"

FROM titles

WHERE type IN ("business", "mod_cook")

24) SELECT COUNT(*)

FROM authors

WHERE state= "CA"

25) SELECT COUNT(*)

FROM titles

WHERE LIKE "Co%s"

26) SELECT title

FROM titles

WHERE ytd_sales IS NULL

27) SELECT au_lname "Фамилия”, au_fname "Имя”

FROM authors

WHERE contract=1 AND phone LIKE "408____-__2_"

28) SELECT phone

FROM authors

WHERE address LIKE "%Broadway Av.%"

29) SELECT title, pubdate

FROM titles

WHERE pubdate>= "Jun 9 1991 12:00AM"

AND pubdate< "6/16/91"

30) SELECT type, AVG(price) "avg", SUM(price) "sum"

FROM titles

WHERE type IN ("business", "psychology")

GROUP BY type

31) SELECT type, pub_id, AVG(price) "avg", SUM(price) "sum"

FROM titles

WHERE type IN ("business", "mod_cook")

GROUP BY type, pub_id

32) SELECT type, AVG(price)

FROM titles

WHERE price>$11

GROUP BY type

HAVING AVG(price)>$19.7

33) SELECT au_id, COUNT(*)

FROM authors

GROUP BY au_id

HAVING COUNT(*)>1

34) SELECT type, MIN(price), MAX(price)

FROM titles

GROP BY type

ORDER BY type

35) SELECT type, MIN(price), MAX(price)

FROM titles

GROUP BY type

HAVING MAX(price)-MIN(price)>=3

36) SELECT state, COUNT(DISTINCT pub_id)

FROM publishers

GROUP BY state

37) SELECT pub_name, AVG(price) "avg",

COUNT(DISTINCT title_id) "count"

FROM titles t JOIN publishers p ON t.pub_id=p.pub_id

GROUP BY pub_name

38) SELECT type, (MIN(price)+MIN(price))/2, AVG(price)

FROM titles

GROUP BY type

HAVING type<> "UNDECIDED"

ORDER BY 2 DESC

39) SELECT type, MIN(pubdate), MAX(pubdate)

FROM titles

GROUP BY type

40) SELECT title, pub_name

FROM titles CROSS JOIN publishers

41) SELECT *

FROM titles, publishers

42) SELECT title, pub_name

FROM titles, publishers

WHERE titles.pub_id=publishers.pub_id

43) SELECT title, pub_name

FROM titles JOIN publishers

ON titles.pub_id=publishers.pub_id

44) SELECT *

FROM titles t, publishers p

WHERE t.pub_id=p.pub_id

45) SELECT t.*, pub_name

FROM titles t, publishers p

WHERE t.pub_id=p.pub_id

46) SELECT a.city, a.state

FROM authors a, publishers p

WHERE a.city=p.city AND a.state=p.state

47) SELECT au_lname, au_fname

FROM authors a JOIN titleauthor ON a.au_id=ta.au_id

JOIN titles t ON ta.title_id=t.title_id

WHERE au_lname LIKE "R%"

AND state IN ("CA", "TX", "NY", "OR", "UT")

AND (title LIKE "_h_ %" OR title LIKE "% _h_ %"

OR title LIKE "% _h_")

48) SELECT title, type

FROM authors a, titles t, titleauthor ta, publishers p

WHERE ta.title_id=t.title_id AND a.au_id=ta.au_id

AND t.pub_id=p.pub_id AND p.city=a.city

49) SELECT au_lname, au_fname, title

FROM authors a, titles t, titleauthor ta, publishers p

WHERE ta.title_id=t.title_id AND a.au_id=ta.au_id

AND t.pub_id=p.pub_id

AND ((p.country= ‘USA’ AND t.type=’popular_comp’)

OR (p.country=’France’ AND t.type=’psychology’))

50) SELECT au_lname, au_fname, city

FROM authors a, titles t, titleauthor ta

WHERE ta.title_id=t.title_id AND a.au_id=ta.au_id

AND (city LIKE "[CPR]%" OR city LIKE "%San%")

AND (title LIKE "% the %" OR title LIKE "The %"

OR title LIKE "% a %" OR title LIKE "A %")

51) SELECT DISTINCT au_lname, au_fname

FROM authors a JOIN titleauthor ta ON a.au_id=ta.au_id

JOIN titles t ON ta.title_id=t.title_id

JOIN publishers p ON p.pub_id=t.pub_id

WHERE p.state= "CA"

ORDER BY au_lname, au_fname

52) SELECT pub_name

FROM publishers p JOIN titles t ON p.pub_id=t.pub_id WHERE $15>price AND type= "psychology"

ORDER BY pub_name

53) SELECT pub_name, AVG(price)

FROM titles t, publishers p

WHERE t.pub_id=p.pub_id

GROUP BY pub_name

54) SELECT pub_name, AVG(price)

FROM titles t JOIN publishers p ON t.pub_id=p.pub_id

GROUP BY pub_name

55) SELECT au_lname, au_fname, title

FROM authors a, titles t, titleauthor ta

WHERE ta.title_id=t.title_id AND a.au_id=ta.au_id

AND type= "popular_comp"

56) SELECT au_lname, au_fname, title

FROM authors a JOIN titleauthor ta ON a.au_id=ta.au_id

JOIN titles t ON ta.title_id=t.title_id

WHERE type= "psychology"

57) SELECT au_lname, au_fname, pub_name, COUNT(*)

FROM authors a, titles t, titleauthor ta, publishers p

WHERE ta.title_id=t.title_id AND a.au_id=ta.au_id

AND t.pub_id=p.pub_id

GROUP BY au_lname, au_fname, pub_name

58) SELECT MIN(price)

FROM titles t, publishers p

WHERE t.pub_id=p.pub_id

GROUP BY country

HAVING country=’USA’

59) SELECT pub_name, COUNT(*)

FROM titles t, publishers p

WHERE t.pub_id=p.pub_id

AND (type= ‘mod_cook’ OR type=’trad_cook’)

GROUP BY pub_name

60) SELECT pub_name, COUNT(*)

FROM publishers p, titles t

WHERE p.pub_id=t.pub_id AND price>$15

GROUP BY pub_name

ORDER BY pub_name DESC

61) SELECT title, COUNT(DISTINCT a.au_id)

FROM titles t JOIN titleauthor ta ON t.title_id=ta.title_id

JOIN authors a ON ta.au_id=a.au_id

JOIN publishers p ON p.pub_id=t.pub_id

GROUP BY title

62) SELECT state, COUNT(DISTINCT p.pub_id)

FROM publishers p JOIN titles t ON p.pub_id=t.pub_id

GROUP BY state

63) SELECT title

FROM titles

WHERE pub_id=

(SELECT pub_id

FROM publishers

WHERE pub_name= "Binnet & Hardley")

64) SELECT pub_name

FROM publishers

WHERE pub_id IN

(SELECT pub_id

FROM titles

WHERE type= "business")

65) SELECT pub_name

FROM publishers p

WHERE EXISTS

(SELECT *

FROM titles t

WHERE p.pub_id=t.pub_id

AND type="popular_comp")

66) SELECT pub_name

FROM publishers p

WHERE NOT EXISTS

(SELECT *

FROM titles t

WHERE p.pub_id=t.pub_id

AND type="mod_cook")

67) SELECT pub_name

FROM publishers

WHERE pub_id NOT IN

(SELECT pub_id

FROM titles

WHERE type="psychology")

68) SELECT type, price

FROM titles

WHERE price < (SELECT AVG(price) FROM titles)

69) SELECT type, AVG(price)

FROM titles

GROUP BY type

HAVING AVG(price) < (SELECT AVG(price) FROM titles)

70) SELECT DISTINCT a.city, a.state

FROM authors a

WHERE NOT EXISTS

(SELECT *

FROM publishers p

WHERE a.city=p.city AND a.state=p.state)

71) SELECT DISTINCT p.city, p.state

FROM publishers p

WHERE NOT EXISTS

(SELECT *

FROM authors a

WHERE p.city=a.city AND p.state=a.state)

72) SELECT MIN(price)

FROM titles t

WHERE t.pub_id IN

(SELECT pub_id

FROM publishers

WHERE country=’USA’)

73) SELECT title, type, price

FROM titles

WHERE price>ALL

(SELECT price

FROM titles

WHERE type= "psychology")

74) SELECT COUNT(DISTINCT city)

FROM publishers

WHERE pub_id IN

(SELECT pub_id

FROM titles

WHERE type= "psychology")

75) SELECT pub_name

FROM publishers p

WHERE 15>SOME

(SELECT price

FROM titles t

WHERE p.pub_id=t.pub_id

AND type= "trad_cook")

76) SELECT pub_name, state

FROM publishers

WHERE pub_id NOT IN

(SELECT pub_id

FROM titles)

77) SELECT title

FROM titles

WHERE pub_id NOT IN

(SELECT pub_id

FROM publishers)

78) SELECT title

FROM titles t

WHERE price>=

(SELECT AVG(price)

FROM titles tt, publishers pp

GROUP BY pub_id

HAVING t.pub_id=pp.pub_id)

79) SELECT au_lname, au_fname, price

FROM authors a, titles t, titleauthor ta, publishers p

WHERE ta.title_id=t.title_id AND a.au_id=ta.au_id

AND t.pub_id=p.pub_id AND country=’USA’

AND price=

(SELECT MIN(price)

FROM titles tt, publishers pp

WHERE tt.pub_id=pp.pub_id

GROUP BY country

HAVING country=’USA’)

80) SELECT DISTINCT au_lname, au_fname

FROM authors a, titles t, titleauthor ta

WHERE a.au_id=ta.au_id AND ta.title_id IN

(SELECT title_id

FROM titles

WHERE ytd_sales=

(SELECT MAX(ytd_sales)

FROM titles))

81) SELECT DISTINCT a.city, a.state

FROM authors a

WHERE NOT EXISTS

(SELECT *

FROM publishers p

WHERE a.city=p.city AND a.state=p.state)

UNION SELECT DISTINCT p.city, p.state

FROM publishers p

WHERE NOT EXISTS

(SELECT *

FROM authors a

WHERE p.city=a.city AND p.state=a.state)

82) SELECT title, price

FROM titles t JOIN publishers p ON t.pub_id=p.pub_id

WHERE p.country= "USA" AND t.price=

(SELECT MAX(price)

FROM titles tt JOIN publishers pp

ON tt.pub_id=pp.pub_id

WHERE country= "USA")

83) SELECT pub_name, COUNT(*)

FROM titles t, publishers p

WHERE t.pub_id=p.pub_id

GROUP BY pub_name

HAVING COUNT(*)>=ALL

(SELECT COUNT(*)

FROM titles tt, publishers pp

WHERE tt.pub.id=pp.pub_id

GROUP BY pub_name)

84) SELECT pub_name, city, state, country

FROM publishers p

WHERE EXISTS

(SELECT *

FROM titles t

WHERE t.pub_id=p.pub_id)

AND 20>ALL

(SELECT price

FROM titles t

WHERE t.pub_id=p.pub_id

AND price IS NOT NULL)

85) SELECT state, SUM(price)

FROM titles t, publishers p

WHERE t.pub_id=p.pub_id

GROUP BY state

HAVING state NOT IN ("TN", "MA", "TX")

AND SUM(price)>

(SELECT SUM(price)

FROM titles tt, publishers pp

WHERE tt.pub.id=pp.pub_id

AND pp.city= "Boston")

86) SELECT pub_name, MIN(price)

FROM titles t, publishers p

WHERE t.pub_id=p.pub_id

GROUP BY pub_name

HAVING MIN(price)>=ALL

(SELECT MIN(price)

FROM titles tt JOIN publishers pp

ON tt.pub_id=pp.pub_id

GROUP BY pub_name)

87) SELECT *

FROM publishers

WHERE pub_id IN

(SELECT pub_id

FROM titles

WHERE type= "psychology" AND pub_id IN

(SELECT pub_id

FROM publishers

WHERE country= "USA"

AND state<> "CA")

88) SELECT au_lname, au_fname

FROM authors a

WHERE a.au_id IN

(SELECT au_id

FROM titleauthor ta

WHERE ta.title_id IN

(SELECT title_id

FROM titles t

WHERE "CA"=SOME

(SELECT state

FROM publishers p

WHERE p.pub_id=t.pub_id)))

ORDER BY au_lname, au_fname

89) SELECT state, COUNT(*)

FROM publishers p

WHERE EXISTS

(SELECT *

FROM titles t

WHERE p.pub_id=t.pub_id)

AND $22>ALL

(SELECT price

FROM titles t

WHERE p.pub_id=t.pub_id

AND price IS NOT NULL)

GROUP BY state

ORDER BY state ASC

90) SELECT state

FROM publishers p1

GROUP BY state

HAVING COUNT(DISTINCT pub_name)=

(SELECT COUNT(*)

FROM publishers p2

WHERE EXISTS

(SELECT *

FROM titles t

WHERE p2.pub_id=t.pub_id)

AND $22.5>ALL

(SELECT price

FROM titles t

WHERE p2.pub_id=t.pub_id

AND price IS NOT NULL)

GROUP BY state

HAVING p1.state=p2.state)

91) SELECT p1.pub_id

FROM titles t1, publishers p1

WHERE t1.pub_id=p1.pub_id

GROUP BY p1.pub_id

HAVING COUNT(DISTINCT title)=

(SELECT COUNT(*)

FROM titles t2

WHERE t2.pub_id=p1.pub_id

AND EXISTS

(SELECT *

FROM titleauthor ta3, authors a3

WHERE ta3.au_id=a3.au_id

AND ta3.title_id=t2.title_id

AND a3.state IN

(SELECT state

FROM publishers p4

WHERE "business"=SOME

(SELECT type

FROM titles t5

WHERE p4.pub_id=

t5.pub_id))))

92) SELECT city, state

FROM authors

UNION SELECT city, state

FROM publishers

ORDER BY state, sity

93) SELECT city

FROM authors

UNION SELECT city

FROM publishers

94) SELECT state

FROM authors

UNION SELECT state

FROM publishers

95) SELECT city, state

FROM authors

WHERE state IS NOT NULL

UNION SELECT city, state

FROM publishers

WHERE state IS NOT NULL

ORDER BY city DESC, state ASC

96) SELECT state, MIN(price), MAX(price), AVG(price)

FROM authors a, titles t, titleauthor ta

WHERE ta.title_id=t.title_id AND a.au_id=ta.au_id

GROUP BY state

HAVING state<> "CA"

Лабораторные задания типа B

Составить SQL-запросы по их заданному содержательному описанию, выполнить SQL-запросы на SQL-сервере с использованием клиентских утилит ISQL/w или SQL-EM, проинтерпретировать результаты выполнения запросов. 

1) Выбрать имена и фамилии авторов книг.

2) Выбрать имена и фамилии авторов, проживающих в Калифорнии.

3) Выбрать информацию о книгах, объеме (стоимость) продаж которых в текущем году меньше стоимости предварительной продажи. Информация о книгах должна включать тип книги, идентификатор и цену книги.

4) Выбрать информацию об авторах, проживающих в штате Калифорния или в городе Salt Lake City. Информация об авторах должна включать идентификатор автора, город и штат проживания.

5) Выбрать все идентификаторы и цены книг, причем цена книги должна лежать в диапазоне от 5 до 10 долларов. В SQL запросе использовать предикат BETWEEN.

6) Выбрать все идентификаторы и цены книг по современной и традиционной кулинарии и по бизнесу. В запросе использовать предикат IN.

7) Выбрать информацию об авторах, проживающих в городах, название которых начинается со строки "Sa". Информация об авторах должна включать имя и фамилию автора, а также штат и город проживания.

8) Выбрать информацию о книгах, идентификаторы которых начинаются буквой "B", а кончаются строкой "1342". Информация о книгах должна включать тип, идентификатор и цену книги.

9) Выбрать информацию о книгах, идентификаторы которых начинаются буквой "B", заканчиваются строкой "1342", а вторым символом идентификатора являются буквы "A", "U" или "N". Информация о книгах должна включать тип, идентификатор и цену книги.

10) Выбрать имена и фамилии всех авторов, упорядоченные по возрастанию фамилий авторов.

11) Выбрать имена и фамилии всех авторов, упорядоченные в первую очередь по возрастанию фамилий и, во вторую очередь, по возрастанию имен.

12) Выбрать информацию о книгах, упорядоченную по возрастанию объема продаж (по стоимости). Информация о книгах должна включать идентификатор, цену, объем продаж (по количеству) и объем продаж (по стоимости).

13) То же, что 12, но использовать упорядочение по убыванию.

14) Выбрать информацию о всех книгах, упорядоченную по убыванию типа книги и числа проданных книг. Информация о книгах должна включать идентификатор и тип книги, а также число проданных книг.

15) Определить среднюю цену книги.

16) Определить среднюю цену книг по бизнесу.

17) Определить среднюю цену и стоимость всех книг по бизнесу и современной кулинарии

18) Определить число авторов, проживающих в Калифорнии.

19) Определить среднюю цену и сумму цен на книги по бизнесу и современной кулинарии отдельно для каждого типа книги.

20) Определить среднюю цену и сумму цен на книги по бизнесу и современной кулинарии для каждой комбинации типа книги и идентификатора издателя.

21) Выбрать те типы книг, средняя цена дорогих экземпляров (стоимостью более 10 долларов) которых превышает 20 долларов. В выбираемые данные помимо типа книги включить и среднюю цену дорогих экземпляров.

22) Подсчитать число строк в таблице authors, включающих одинаковые идентификаторы авторов. В выбираемые данные включить идентификатор автора и соответствующее ему число повторяющихся строк.

23) Выбрать названия книг и имена выпустивших их издателей.

24) То же, что и 23, но в разделе FROM запроса использовать операцию соединения JOIN.

25) Произвести проекцию на столбцы title и pub_name декартова произведения таблиц titles и publishers.

26) Определить среднюю цену выпускаемых каждым издателем книг. В выбираемые данные включить имя издателя и среднюю цену книги.

27) То же, что и 26, но в разделе FROM запроса использовать операцию соединения JOIN.

28) Определить, кто из авторов написал какую книгу по психологии. В выбираемые данные включить имя и фамилию автора, а также название книги.

29) То же, что и 28, но в разделе FROM запроса использовать операцию соединению JOIN.

30) Выбрать все столбцы результата эквисоединения таблиц titles publishers по идентификатору издателя.

31) Выбрать все столбцы таблицы titles и столбец pub_name таблицы publishers результата эквисоединения данных таблиц по идентификатору издателя.

32) Выбрать все книги издательства Algodata Infosysytems. В запросе использовать подзапрос для определения нужного идентификатора издателя. В условии поиска использовать предикат "=". В выбираемые данные включить название книги.

33) Выбрать всех издателей литературы по бизнесу. В запросе использовать подзапрос для выборки нужных идентификаторов издателей. В условии поиска использовать предикат IN. В выбираемые данные включить имя издателя.

34) Выбрать всех издателей литературы по бизнесу. В запросе использовать подзапрос, формирующий промежуточную таблицу, в которую включаются те строки из таблицы titles, которые могут “экви-соединиться” по идентификатору издателя со строками из таблицы publishers и которые представляют тип книг по бизнесу. В условии поиска основного запроса использовать предикат EXISTS. В выбираемые данные включить имя издателя.

35) Выбрать издателей, не выпускающих книг по бизнесу. Дополнительные условия формирования запроса взять из варианта 34.

36) Выбрать издателей, не выпускающих книг по бизнесу. Дополнительные условия формирования запроса взять из варианта 33.

37) Выбрать тип и цену для всех книг, цена которых не превышает средней. В запросе использовать подзапрос, определяющий среднюю цену книг.

38) Выбрать тип и среднюю цену книг данного типа, причем эта средняя цена должна быть меньше средней цены всех книг. В запросе использовать подзапрос, определяющий среднюю цену всех книг.

39) Определить города и штаты проживания каждого из авторов и издателей в виде одной результирующей таблицы.

40) Определить все типы книг. Типы книг в результирующей таблице не должны повторяться. Вывести типы книг в порядке возрастания.

41) Определить все города, в которых проживают авторы. Названия городов в результирующей таблице не должны повторяться. Вывести названия городов в порядке убывания.

42) Определить все штаты, в которых проживают авторы. Названия штатов в результирующей таблице не должны повторяться. Вывести названия штатов в порядке возрастания.

43) Определить страны, в которых расположены издательства книг. Названия стран в результирующей таблице не должны повторяться. Вывести названия стран в порядке убывания.

44) Определить все города, в которых проживают авторы и находятся издательства. Названия городов в результирующей таблице не должны повторяться. Вывести названия городов в порядке возрастания.

45) Определить все штаты, в которых проживают авторы и находятся издательства. Названия штатов в результирующей таблице не должны повторяться. Вывести названия штатов в порядке убывания.

46) Определить города и штаты совместного проживания авторов и издателей. (В запросе неявно реализуется операцию пересечения).

47) Определить города и штаты проживания авторов, в которых нет издательств. (В запросе неявно реализуется операция разности).

48) Определить города и штаты нахождения издательств, в которых не проживают авторы. (В запросе неявно реализуется операция разности).

49) Определить, какой город в каком штате находится. Вывести названия городов в порядке возрастания.

50) Определить число книг, название которых начинается со строки "The" и заканчивается буквой "e".

51) Определить авторов на букву "G", проживающих в штатах Теннесси, Иллинойс, Канзас, Орегон или Калифорния, которые опубликовали книги, в которых есть слово из трех букв, причем средней буквой является буква "a".

52) Определить минимальную, максимальную и среднюю цену для каждого из типов книг. Выводимые данные должны быть упорядочены по убыванию типа книг.

53) Определить минимальную и максимальную цену для каждого из типов книг. В результирующую таблицу не включать те типы книг, для которых разность между максимальной и средней ценой меньше 7 долларов.

54) Вычислить среднюю цену всех книг и медиану цены. Под медианой понимается среднее значение всех различных цен всех книг.

55) Определить, какие авторы в каких издательствах опубликовали сколько книг.

56) Определить книги, авторы и издатели которых живут в одном городе.

57) Определить для каждого штата минимальную, максимальную и среднюю цену книг авторов, проживающих в одном штате (кроме штата Калифорния).

58) Определить, какие авторы опубликовали какие книги в США по традиционной кулинарии или в Германии по компьютерам.

59) Найти цену самой дешевой книги (книг), вышедшей в США. В запросе использовать операцию группирования.

60) Найти авторов самых дорогих книг, вышедших в США. В запросе использовать подзапрос и операцию группирования.

61) Найти авторов, у которых вышли самые не распродаваемые книги.

62) Найти цену самой дорогой книги (книг), вышедшей в США. В запросе использовать подзапрос.

63) Определить число книг по компьютерам, выпущенных каждым издательством.

64) Определить авторов из городов, начинающихся с букв "A", "B" или "C" или имеющих в своем составе слово "Salt", и написавших книги, в названии которых есть определенный или неопределенный артикль английского языка.

65) Определить города и штаты проживания авторов и издателей, за исключением городов и штатов их совместного проживания. (В запросе неявно реализуется операция симметрической разности).

66) Определить названия и цену самых дешевых книг, вышедших в США. (Самые дешевые книги имеют минимальную цену).

67) Определить издательство, в котором опубликовано меньше всего книг.

68) Найти книги, цена которых меньше цены каждой из книг по традиционной кулинарии.

69) Определить местонахождение издательств, цена каждой книги которых меньше 22 долларов. В запросе использовать подзапросы и предикат с квантором.

70) Определить штаты (кроме штатов Индиана, Канзас, Юта), в которых сумма цен выпущенных в них книг больше суммы цен книг, выпущенных в городе Вашингтон.

71) Найти издательство, выпустившее свою самую дорогую книгу с наиболее низкой ценой среди всех издательств. В запросе использовать подзапрос, определяющий максимальные цены книг, выпущенные каждым издательством.

72) Определить полную информацию об издателях книг по компьютерам, авторы которых живут в США (за исключением штата Юта). В запросе использовать подзапросы.

73) Определить книги, стоимости которых составляют не более средней стоимости по издательству, где издавались эти книги.

74) Определить для каждого штата число находящихся в нем издательств.

75) Определить число городов, в которых выпускается литература по компьютерам. В запросе использовать подзапрос.

76) Определить авторов, хотя бы одна книга которых была опубликована в штате Массачусетс. В запросе использовать подзапросы и предикат с квантором.

77) Найти издательства, среди изданных книг которых найдется хоть одна книга по компьютерам стоимостью более двух долларов. В запросе использовать подзапрос и предикат с квантором.

78) Определить штаты, во всех издательствах которых все изданные книги имеют цену более 10 долларов. В запросе использовать подзапросы и предикат с квантором.

79) Определить издательства, для каждой книги которых выполняется условие: “Если книга выпущена в данном издательстве, то хотя бы один из авторов книги проживает в штате, в котором находится издательство, некоторые выпущенные книги которого посвящены компьютерам”.

80) Выбрать все столбцы таблицы titles.

81) Выбрать все столбцы декартова произведения таблиц titles и publishers.

82) Определить книги, число продаж для которых неопределено.

83) Определить минимальную и максимальную цену книг, выпущенных издательствами.

84) Определить авторов, хотя бы одна книга которых была опубликована в штате Массачусетс. В запросе не использовать предикаты с квантором.

85) Найти издательства, среди изданных книг которых найдется хоть одна книга по традиционной кулинарии стоимостью от 12 до 16 долларов. В запросе не использовать предикаты с квантором.

86) Определить для каждого издательства число изданных им дешевых книг (ценой менее 13 долларов).

87) Определить для штатов число издательств, в которых выпускаются только книги ценой более 7 долларов. В запросе использовать подзапросы и предикат с квантором.

88) Определить, сколько авторов имеет каждая изданная книга.

89) Определить штаты и число находящихся в них издательств, выпустивших книги.

90) Определить издательства, не выпустившие книг.

91) Определить неопубликованные в издательствах книги.

92) Определить авторов, работающих по контракту и имеющих телефон с кодом города 415 (первые три цифры номера телефона).

93) Определить номера телефонов авторов, проживающих на Седьмой Авеню (Seventh Av.)

94) Определить книги, выпущенные в период с 1 июля 1991 г. по 30 октября 1991 г. (По умолчанию сервер работает с датами в формате xx/yy/zz как с последовательностями месяц/день/год).

95) Вычислить для каждого типа книг среднее арифметическое минимальной и максимальной цены. Результат упорядочить по убыванию значений.

96) Определить временные интервалы, в рамках которых опубликованы книги разных типов.



Примечания: 1. При упорядочении фамилий и имен авторов, городов, штатов, типов книг используется лексикографический порядок.2. “Издатель” и “издательство” являются в данном случае синонимами. Соответственно этому синонимами являются “имя издателя” и “название издательства”.

 Варианты лабораторных заданий



Номер варианта

Задание типа A

Задание типа B

1

1, 25, 49, 81

24, 48, 72, 96

2

2, 26, 50, 63

23, 47, 71, 95

3

3, 27, 51, 64

22, 46, 70, 94

4

4, 28, 46, 65

21, 45, 69, 93

5

5, 29, 57, 84

20, 44, 68, 92

6

6, 30, 58, 83

19, 43, 67, 91

7

7, 31, 55, 79

18, 42, 66, 90

8

8, 32, 56, 80

17, 41, 65, 89

9

9, 33, 57, 81

16, 40, 64, 88

10

10, 34, 58, 82

15, 39, 63, 87

11

11, 35, 59, 83

13, 37, 61, 85

12

12, 36, 60, 84

14, 38, 62, 86

13

13, 37, 61, 85

12, 36, 60, 84

14

14, 38, 62, 86

11, 35, 59, 83

15

15, 39, 63, 87

10, 34, 58, 82

16

16, 40, 64, 88

9, 33, 57, 81

17

17, 41, 65, 89

8, 32, 56, 80

18

18, 42, 66, 90

7, 31, 55, 79

19

19, 43, 67, 91

6, 30, 58, 83

20

20, 44, 68, 92

5, 29, 57, 84

21

21, 45, 69, 93

4, 28, 46, 65

22

22, 46, 70, 94

3, 27, 51, 64

23

23, 47, 71, 95

2, 26, 50, 63

24

24, 48, 72, 96

1, 25, 49, 81




следующая страница >>
Смотрите также:
Выборка данных из базы данных с использованием языка sql
2189.02kb.
9 стр.
В системы управления базами данных
52.4kb.
1 стр.
Доклад февраль Подготовка материалов по описанию базы данных проекта с использованием anova
38.33kb.
1 стр.
Практические занятия к теме №3 задача 1 Задание Создание базы данных
83.93kb.
1 стр.
Материал из Semantic Future
425.22kb.
2 стр.
Темы дипломных проектов специальности 230105 Базы данных
122.96kb.
1 стр.
Отчет по результатам работы по программе усовершенствования базы данных по сортам растений и изложить предложения по усовершенствованию базы данных по сортам растений
712.53kb.
4 стр.
Лекция №1 по дисциплине «Базы данных» базы данных и системы управления базами данных план лекции
219.44kb.
1 стр.
«база данных access»
297.79kb.
1 стр.
Тест по дисциплине «Базы данных». Вариант База данных – это
65.02kb.
1 стр.
Исследование архитектуры базы данных Oracle Архитектура базы данных Oracle Взаимодействие с базой данных Oracle
107.74kb.
1 стр.
Дисциплина. «Базы данных и субд»
127.3kb.
1 стр.