Create type (transact-sql)create type (transact-sql)
Содержание:
- Table of contents
- Create Table Foreign Key Syntax
- Пишем SQL запрос для создания таблицы базы данных
- Предусловия
- Introduction to the SQL Server CREATE TABLE statement
- SQL CREATE TABLE examples
- Работа в сервисе sql fiddle
- Create Table Primary Key Syntax
- Introduction to SQL CREATE TABLE statement
- SQL Create Database statement
- Oracle CREATE TABLE Errors and Exceptions
- Инструкция CREATE TABLE
- SQL Инструкция CREATE VIEW
- вступление
- Плагины для создания и вставки таблиц на сайт
- Исходные данные
- SQL Учебник
Table of contents
Learn SQL: CREATE DATABASE & CREATE TABLE Operations | |
Learn SQL: INSERT INTO TABLE | |
Learn SQL: Primary Key | |
Learn SQL: Foreign Key | |
Learn SQL: SELECT statement | |
Learn SQL: INNER JOIN vs LEFT JOIN | |
Learn SQL: SQL Scripts | |
Learn SQL: Types of relations | |
Learn SQL: Join multiple tables | |
Learn SQL: Aggregate Functions | |
Learn SQL: How to Write a Complex SELECT Query | |
Learn SQL: The INFORMATION_SCHEMA Database | |
Learn SQL: SQL Data Types | |
Learn SQL: Set Theory | |
Learn SQL: User-Defined Functions | |
Learn SQL: User-Defined Stored Procedures | |
Learn SQL: SQL Views | |
Learn SQL: SQL Triggers | |
Learn SQL: Practice SQL Queries | |
Learn SQL: SQL Query examples | |
Learn SQL: Create a report manually using SQL queries | |
Learn SQL: SQL Server date and time functions | |
Learn SQL: Create SQL Server reports using date and time functions | |
Learn SQL: SQL Server Pivot Tables | |
Learn SQL: SQL Server export to Excel | |
Learn SQL: Intro to SQL Server loops | |
Learn SQL: SQL Server Cursors | |
Learn SQL: SQL Best Practices for Deleting and Updating data | |
Learn SQL: Naming Conventions | |
Learn SQL: SQL-Related Jobs | |
Learn SQL: Non-Equi Joins in SQL Server | |
Learn SQL: SQL Injection | |
Learn SQL: Dynamic SQL | |
Learn SQL: How to prevent SQL Injection attacks |
Create Table Foreign Key Syntax
Like the primary key definition, you can declare a foreign key both inline and out of line in the SQL Create Table command.
Inline foreign keys are declared like this:
You use the word REFERENCES, then the name of the table that the foreign key refers to, then within brackets you specify the column that the foreign key links to.
The other method of adding a foreign key using the CREATE TABLE command is the out of line method.
You need to start with the word CONSTRAINT, then the name of the foreign key. The name needs to be unique across the database, so I like to start with the term “fk”, then the two tables I am referring to.
Then, you specify the words FOREIGN KEY, then the name of the other table within brackets. Then you add the word REFERENCES, then within brackets, you specify the column name from the table you’re referring to (which is probably the primary key).
Пишем SQL запрос для создания таблицы базы данных
Суммируем все исходные данные и получаем такой SQL запрос:
/*Таблица пользователей clients*/ create table clients ( /*client_id будет первичный ключ (обязательно целое число) с автоинкрементом (+1), который никогда не будет равен нулю*/ client_id integer not null auto_increment primary key, client_customer varchar(13), /*имя */ client_surclient varchar(22), /*фамилия */ client_login varchar(21), /*логин*/ client_passwd varchar(7), /*пароль*/ client_email varchar(44) /*email*/ client_telefon varchar(26) /*телефон*/ );
Примечание: SQL запрос для создания таблицы создаем в текстовом редакторе типа Notepad++. В скобках ограничиваем длину поля, может быть от 1 до 255.
Итоги статьи
- В этой статье мы познакомились с первым оператором SQL языка CREATE TABLE
- Создали SQL запрос для создания одной (первой) таблицы базы данных с первичным ключом.
WebOnTo.ru
Предусловия
Перед началом работы у вас должен быть установлен как сам MS SQL Server, так и SSMS. Версию сервера следует выбирать, исходя из технических характеристик своего компьютера и установленной операционной системы. В статье используется MS SQL Server 2017 Express.
Также таблицы (tables) не могут существовать без базы данных. Поэтому, прежде чем приступить к созданию таблиц, следует создать пустую БД. Это делается очень просто – достаточно запустить среду SSMS и выполнить несколько простых действий:
1) кликаем правой кнопкой мыши по контейнеру «Базы данных» и выбираем «Создать базу данных»;
2) в появившемся поле прописываем имя БД;
3) нажимаем «ОК».
Introduction to the SQL Server CREATE TABLE statement
Tables are used to store data in the database. Tables are uniquely named within a database and schema. Each table contains one or more columns. And each column has an associated data type that defines the kind of data it can store e.g., numbers, strings, or temporal data.
To create a new table, you use the statement as follows:
In this syntax:
- First, specify the name of the database in which the table is created. The must be the name of an existing database. If you don’t specify it, the defaults to the current database.
- Second, specify the schema to which the new table belongs.
- Third, specify the name of the new table.
- Fourth, each table should have a primary key which consists of one or more columns. Typically, you list the primary key columns first and then other columns. If the primary key contains only one column, you can use the keywords after the column name. If the primary key consists of two or more columns, you need to specify the constraint as a table constraint. Each column has an associated data type specified after its name in the statement. A column may have one or more column constraints such as and .
- Fifth, a table may have some constraints specified in the table constraints section such as , , and .
Note that is complex and has more options than the syntax above. We will gradually introduce you to each individual options in the subsequent tutorials.
SQL CREATE TABLE examples
Suppose you have to store the training data of employees in the database with a requirement that each employee may take zero or many training courses, and each training course may be taken by zero or many employees.
You looked at the current database and found no place to store this information, therefore, you decided to create new tables.
The following statement creates the table:
The table has two columns: and .
The is the primary key column of the table. Each table has one and only one primary key that uniquely identifies each row in the table. It is a good practice to define a primary key for every table.
The data type of the is integer denoted by the keyword. In addition, the value of the column is . It means that when you insert a new row into the table without providing the value for the column, the database system will generate an integer value for the column.
The stores the names of courses. Its data type is the character string ( ) with maximum length is 50. The constraint ensures that there is no NULL values stored in the column.
Now you have the table to store the course data. To store the training data, you create a new table named training as follows.
The table consists of three columns:
- The column store the id of employees who took the course.
- The column store the course that employee took.
- The column stores the date when the employee took the course.
Because the primary key of the table consists of two columns: and , we had to use the table constraint.
In this tutorial, you have learned how to use the SQL statement to create new a new table in the database.
Работа в сервисе sql fiddle
Онлайн проверка sql запросов возможна при помощи сервиса sqlFiddle.
Самый простой способ организации работы состоит из следующих этапов:
- В верхней части рабочей области сервиса выбираем язык: SQLite(WebSQL);
Открывшаяся рабочая область разделена визуально на 3 окна: левое — для кода создания таблиц и заполнения их данными, правое — для кода запросов, нижнее — для отображения результатов запросов. - В левое окно помещается код для создания таблиц и вставки в них данных (пример кода расположен ниже). Затем щелкается кнопка «Build Schema».
После того как схема построена (об этом сигнализирует надпись на зеленом фоне «Schema Ready»), в правое окошко вставляется код запроса и щелкается кнопка Run SQL.
Еще пример:
Теперь некоторые пункты рассмотрим подробнее.Создание таблиц:
Пример: создайте сразу три таблицы (teachers, lessons и courses); добавьте по нескольку значений в каждую таблицу.
* для тех, кто незнаком с синтаксисом — просто скопировать полностью код и вставить в левое окошко сервиса
* урок по созданию таблиц в языке SQL далее
/*teachers*/ CREATE TABLE `teachers` ( `id` INT(11) NOT NULL, `name` VARCHAR(25) NOT NULL, `code` INT(11), `zarplata` INT(11), `premia` INT(11), PRIMARY KEY (`id`) ); INSERT INTO teachers VALUES (1, 'Иванов',1,10000,500), (2, 'Петров',1,15000,1000) ,(3, 'Сидоров',1,14000,800), (4,'Боброва',1,11000,800); /*lessons*/ CREATE TABLE `lessons` ( `id` INT(11) NOT NULL, `tid` INT(11), `course` VARCHAR(25), `date` VARCHAR(25), PRIMARY KEY (`id`) ); INSERT INTO lessons VALUES (1,1, 'php','2015-05-04'), (2,1, 'xml','2016-13-12'); /*courses*/ CREATE TABLE `courses` ( `id` INT(11) NOT NULL, `tid` INT(11), `title` VARCHAR(25), `length` INT(11), PRIMARY KEY (`id`) ); INSERT INTO courses VALUES (1,1, 'php',54), (2,1, 'xml',72), (3,2, 'sql',25); |
В результате получим таблицы с данными:
Отправка запроса:
Для того чтобы протестировать работоспособность сервиса, добавьте в правое окошко код запроса.
Пример: при помощи запроса выберите все данные из таблицы teachers, касаемые учителя с фамилией Иванов
SELECT * FROM `teachers` WHERE `name` = 'Иванов'; |
На дальнейших уроках SQL будет использоваться та же схема, поэтому необходимо будет просто копировать схему и вставлять в левое окно сервиса.
Онлайн визуализации схемы базы данных
Для онлайн визуализации схемы базы данных можно воспользоваться сервисом https://dbdesigner.net/:
- Создать свой аккаунт (войти в него, если уже есть).
- Щелкнуть по кнопке Go to Application.
- Меню Schema -> Import.
- Скопировать и вставить в появившееся окно код создания и заполнения таблиц базы данных
Далее к уроку 0 Язык sql создание таблиц
Create Table Primary Key Syntax
You can specify a primary key on a table when you create in two ways:
- Next to the column data type when you declare it on the same line (an inline constraint)
- At the end of all column declarations (an out of line constraint)
The method you choose would be dependent on your team’s standards and whether or not you need to have two or more columns in your primary key (you can only specify one column in an inline constraint).
To declare a primary key inline using a CREATE TABLE statement:
That’s it. You just add the words PRIMARY KEY after the data type. They are separate words – there’s no underscore or hyphen between them.
The out of line method of declaring a primary key in a Create Table command is a bit different.
You need to add it after all of your column definitions. You also need to start with the word CONSTRAINT.
Then, give the primary key a name. You only need to do this for out of line constraints. In this example, I’ve given it the name of “pk_tbl1”, to indicate that it is a primary key, and the “tbl1” would be the name of the table.
Inside the brackets after the word PRIMARY KEY, you specify the column names. If there is more than one, separate them by a comma.
Introduction to SQL CREATE TABLE statement
So far, you have learned various ways to query data from one or more table in the sample database. It is time to learn how to create your own tables.
A table is a collection of data stored in a database. A table consists of columns and rows. To create a new table, you use the statement with the following syntax:
The minimum required information for creating a new table is a table name and a column name.
The name of the table, given by the , must be unique within the database. If you create a table whose name is the same as the one that already exists, the database system will issue an error.
In the statement, you specify a comma-separated list of column definitions. Each column definition is composed of a column name, column’s data type, a default value, and one or more column constraints.
The data type of a column specifies the type of data that column can store. The data type of the column can be the numeric, characters, date, etc.
The column constraint controls what kind of value that can be stored in the column. For example, the constraint ensures that the column does not contain any NULL value.
A column may have multiple column constraints. For example, the column of the table can have both and constraints.
In case a constraint contains multiple columns, you use the table constraint. For example, if a table has the primary key that consists of two columns, in this case, you have to use the table constraint.
SQL Create Database statement
After installing and opening Microsoft SQL Server Management Studio, our screen looks something like this:
It doesn’t look fun at all. We’ll make it more fun by creating a new database. After clicking on the New Query, the new window opens and we’re able to type something in. It looks like on the picture below:
Before typing anything, we should be sure we’re typing it in the right way. T-SQL is a language and as such it has its’ words – set of rules on how to write different commands.
Luckily, one of these commands is the SQL Create Database command. You can see the full T-SQL Create Database syntax
on Microsoft pages.
I’ll simplify it a lot and go only with the most basic form. In order to create a new database on our server, we
need to use the following command:
1 | CREATEDATABASEdatabase_name; |
Where we’ll use the desired name instead of the database_name.
Oracle CREATE TABLE Errors and Exceptions
These are some of the errors and exceptions that may appear when you’re creating a table. As a database developer, you’ll get these kinds of errors all the time!
Exception: ORA-00955: name is already used by an existing object
Reason: You’re attempting to create a table with a name that is already being used.
Resolution: Use a different name for your table, or drop the table with the existing name. Or, use a different schema for your table if that’s applicable.
Exception: ORA-02260: table can have only one primary key
Reason: You’re attempting to add a primary key to a table that already has one.
Resolution: Review your SQL CREATE TABLE statement and remove all but one PRIMARY KEY definition.
Exception: ORA-02267: column type incompatible with referenced column type
Reason: The column you’re referring to is not compatible with the column you’re defining it on. This could happen when defining a foreign key.
Resolution: Make sure the data types are the same for both columns. And, make sure you’re not referring to the same table for the foreign key (it should be a different table).
Exception: ORA-00904: : invalid identifier
Reason: There are many reasons for this error, but it’s usually a syntax error.
Resolution: Check that you have all of your commas and brackets in the right places in your statement.
Exception: ORA-00957: duplicate column name
Reason: You have two columns with the same name.
Resolution: Rename one of your columns to make sure it is not a duplicate. Also, check that your commas and brackets are all in the right places.
Инструкция CREATE TABLE
Создать новую таблицу можно и с помощью инструкции CREATE TABLE. CREATE TABLE является ключевым словом, которое сообщает СУБД, что именно вы хотите выполнить. Синтаксис создания в языке (language) SQL следующий:
Как видите, после оператора CREATE TABLE надо указать имя либо идентификатор таблицы, потом список столбцов и тип данных для каждого столбца, а также первичный ключ.
Для примера создадим table CUSTOMERS. В качестве первичного ключа укажем столбец ID. Также установим ограничения для полей, которые не могут иметь нулевое значение при создании записей (NOT NULL):
Увидеть структуру созданной table можно, если сделать соответствующий запрос (query) командой DESC:
Вот и всё. Очень надеемся, что статья помогла вам разобраться в том, как создавать table в реляционных системах управления базами данными
Если же вас интересуют более продвинутые знания как по базам данных, так и по MS SQL Server конкретно, обратите внимание на следующие курсы в OTUS:
— https://otus.ru/lessons/subd/;
— https://otus.ru/lessons/ms-sql-server-razrabotchik/
При подготовке статьи использовались следующие материалы:
• https://www.tutorialspoint.com/sql/sql-create-table.htm;
• https://info-comp.ru/obucheniest/716-create-table-in-ms-sql-server.html;
• https://info-comp.ru/obucheniest/715-create-database-in-ms-sql-server.html.
SQL Инструкция CREATE VIEW
В SQL представление — это виртуальная таблица, основанная на результирующем наборе инструкции SQL.
Представление содержит строки и столбцы, как и настоящая таблица. Поля в представлении — это поля из одной или нескольких реальных таблиц в базе данных.
Вы можете добавить в представление инструкции SQL функций, WHERE и JOIN и представить данные так, как если бы они поступали из одной таблицы.
Синтаксис CREATE VIEW
CREATE VIEW view_name AS
SELECT column1, column2, …
FROM table_name
WHERE condition;
Примечание: В представлении всегда отображаются актуальные данные!
Компонент database engine воссоздает данные, используя инструкцию SQL представления, каждый раз, когда пользователь запрашивает представление.
вступление
В теории реляционных баз данных для каждой сущности требуется один или несколько ключевых кандидатов, которые по определению должны быть уникальными. Один из этих ключевых кандидатов выбирается в качестве первичного ключа и реализуется как таковой при преобразовании объекта в таблицу базы данных. Несмотря на это соглашение, существуют также системы баз данных, которые позволяют определять таблицы без определения первичного ключа. Поэтому такие таблицы также допускают дублирование записей данных и, следовательно, не являются реляционными объектами по определению.
Супер ключ ⊇ ключевые кандидаты, из них выбирается первичный ключ
Различают ключевые термины
в реляционных базах данных.
- Супер ключ (иногда также называемый верхним ключом)
- Набор из (полей) в соотношении (таблице) , которые однозначно идентифицируют те кортежи (строки) в этом отношении, т.е. всегда содержат различные значения для кортежей , выбранных в парах (один также говорит «являются уникальными»). Например, тривиальный суперключ — это набор всех общих атрибутов отношения . (Тривиально, потому что отношение — это набор кортежей. Элементы наборов должны быть уникальными, поэтому в отношении не может быть двух одинаковых кортежей.)
- Ключевой кандидат (также называемый кандидатным ключом или альтернативным ключом )
- Минимальное подмножество атрибутов суперключа, которое позволяет идентифицировать кортеж (ключевые кандидаты ⊆ суперключ).
- Первичный ключ
- Выбранный ключевой кандидат, который впоследствии используется для сопоставления отношений. Значения этого ключа используются как внешние ключи при обращении к таблицам .
Формальное определение
Пусть дана некоторая реляционная схема R (каркас таблицы, т.е. все столбцы). Подмножество S атрибутов (столбцов) схемы R называется ключом, если:
- Уникальность
- R не может содержать два разных кортежа, в которых значения S одинаковы. Цель состоит в том, чтобы гарантировать, что никакое (возможное) выражение R не может содержать два разных кортежа, для которых значения S одинаковы: технически не законное, возможное заполнение таблицы может привести к появлению двух (технически разных) строк, ведущих к то же ключевое значение.
- Определение
- Некоторые системы баз данных допускают нулевые значения при условии, что это не нарушает уникальность. Цель должна состоять в том, чтобы все записи в таблице фактически определяли атрибуты из S; ни одна из записей не должна быть .
- Минимализм
- Так что ключ также является ключевым кандидатом, ни одно реальное подмножество S не должно уже удовлетворять условию уникальности.
Примеры
ISBN | автор | Заголовок книги | … |
---|---|---|---|
0001 | Ганс | В. | … |
0002 | Лутц | W. | … |
0003 | Питер | W. | … |
0004 | Питер | Икс | … |
0005 | Ральф | Y | … |
… | … | … | … |
Фамилия | день рождения | место жительства | … |
---|---|---|---|
Хайнц Хоффманн | 01.08.1966 | Север, BBS | … |
Альф Аппель | 08.11.1957 | Mömlingen | … |
Себастьян Саншайн | 04.08.1979 | Гамбург | … |
Клаус Клебер | 15.04.1970 | Франкфурт | … |
Барбара Бахманн | 17.10.1940 | Кирхгайм | … |
… | … | … | … |
прямой руководитель (ID) | Сотрудник (ID) |
---|---|
002 | 104 |
030 | 512 |
115 | 519 |
234 | 993 |
234 | 670 |
… | … |
- а
- Здесь ключ — это единственный атрибут. ISBN очень подходит для этого, потому что нет двух книг с одинаковым ISBN. Книги вполне могут иметь одно и то же название или принадлежать одному автору. Примечание: ISBN ( международный стандартный номер книги ) показан здесь только символически как серийный номер, ISBN на самом деле более сложен.
- б
- Здесь в качестве ключа используется комбинация двух атрибутов. Разработчик базы данных предполагает, что в один и тот же день нет клиентов с одинаковыми именами и днями рождения. Если в этом примере есть клиенты с одинаковым именем и день рождения в один и тот же день, то часть выбранных здесь атрибутов не может использоваться в качестве ключа.
- c
- Здесь только все атрибуты отношения рассматриваются как ключи. Персональный номер показывает, какой сотрудник компании является начальником какого другого сотрудника. Примечание. Записи данных этого отношения содержат только однозначные слева кортежи (1: n), потому что по техническим причинам и причинам, связанным с содержанием, у сотрудников обычно есть только один непосредственный руководитель. В принципе, конечно, кортежи отношений, которые являются типами отношений, могут содержать все возможные n: m назначений.
Плагины для создания и вставки таблиц на сайт
Для разных движков, будь то это WordPress, Joomla или любой другой, существуют дополнения или плагины, расширяющие возможности оформления страниц сайта. В зависимости от того, какой движок у вашего сайта, вы можете просто в поисковике набрать что-то типа: таблица в Водпресс или как создать таблицу в Joomla и получить кучу сайтов, которые делают подробный разбор разных плагинов.
Для движка Вордпресс, например, один из самых популярных плагинов для создания таблиц, это плагин TablePress.
У каждого плагина есть свои собственные преимущества. Одни могут позволять быстро создавать простые таблицы на сайте, в других же придется повозиться, чтобы сделать красивые таблицы для сайта.
Но, также необходимо понимать, что у плагинов есть и свои недостатки.
Так, чем больше разных плагинов установлено на сайте, тем более нагруженным и уязвимым становится сайт.
Кроме того, не все плагины будут корректно работать с разными темами (шаблонами). Вот, к примеру, даже такой популярный плагин, как расширенный текстовый редактор CKEditor, тоже работает не безупречно.
В нем, конечно, есть много ценных возможностей, таких как изменение шрифта и его размера, а также выделение текста разным цветом. И, что касается нашей темы, то в этом плагине есть возможность создания и вставки таблиц:
Удобно, — ставим курсов в том месте текста, где нужно создать и вставить таблицу, нажимаем на значок таблицы, как показано на снимке выше и с помощью всплывающего окна настраиваем нужную нам таблицу:
Здесь все интуитивно понятно. И просто поэкспериментировав, можно быстро понять, как создавать таблицы на сайте с помощью этого плагина. Единственное что хочется дополнить, — если у вас тема сайта адаптивная, т.е. размер корректно изменяется под экраны мобильных устройств, и если вам нужно сделать таблицу во всю ширину страницы, то в поле Ширина можно указывать в процентах, например 100%.
Удобный плагин-редактор, что и говорить! Но, как я уже говорил, есть и недостаток у него с некоторыми темами. Например, при сохранении страниц в некоторых темах добавляются лишние переносы строк и убираются они только в режиме HTML. Конечно, можно приспособиться, но, если не хватает внимательности, то можно это пропустить и в оформлении страниц будут лишние переносы строк.
Также данный плагин не «дружит» с некоторыми другими плагинами, которые добавляют свои кнопки в стандартную панель редактора для быстрого и удобного вывода функций.
Вот, к примеру, есть плагин WP-Опросы для удобного создания и ведения опросов на сайте. При установке он автоматически встраивает кнопку Вставить опрос:
При нажатии по кнопке появляется дополнительное окно, в котором можно просто поставить ID опроса и нажать ОК:
Опрос вставится в то место страницы, где стоял курсор.
А узнать ID опроса можно в разделе, где находятся все созданные опросы:
Достаточно удобно! Но, при добавлении расширенного редактора CKEditor данная кнопка не работает, т.е. не выводит всплывающее окно (по крайней мере, в некоторых темах).
Конечно, здесь тоже можно приспособиться, просто вставляя вручную код , где цифра 2, это ID опроса.
Этот пример лишь подчеркивает, что не все может быть гладко с разными плагинами. И если в них действительно есть необходимость, то нужно выбирать, какой подойдет и можно ли приспособиться к некорректной работе, если она появится.
И, что касается создания и вставки таблиц, так уж ли необходимо использовать плагины или можно воспользоваться другими способами?! Рассмотрим другие способы.
Исходные данные
База создана, поэтому можно подумать о её структуре. Планируется создание двух таблиц:
1. Goods – table с информацией о товарах. Будет содержать несколько столбцов:
— ProductId. Представляет собой идентификатор товара. Значение не должно быть NULL. Также здесь будет первичный ключ;
— Category. Это ссылка на категорию товара. Не NULL. Если товар не распределён в нужную категорию, ему присваивается категория по умолчанию («Не указана», «Не определена»);
— ProductName. В этом столбце будет наименование товара. Не NULL;
— Price. Речь идёт о стоимости. Если цена ещё не определена, возможен NULL.
2. Categories — вторая table. В ней будет описание категорий реализуемых товаров, представленное двумя столбцами:
— CategoryId. Представляет собой идентификатор категории. Не NULL, первичный ключ;
— CategoryName. Название категории, не NULL.
Для того чтобы нельзя было внести товар с несуществующей категорией, будет добавлено ограничение внешнего ключа.
SQL Учебник
SQL ГлавнаяSQL ВведениеSQL СинтаксисSQL SELECTSQL SELECT DISTINCTSQL WHERESQL AND, OR, NOTSQL ORDER BYSQL INSERT INTOSQL Значение NullSQL Инструкция UPDATESQL Инструкция DELETESQL SELECT TOPSQL MIN() и MAX()SQL COUNT(), AVG() и …SQL Оператор LIKESQL ПодстановочныйSQL Оператор INSQL Оператор BETWEENSQL ПсевдонимыSQL JOINSQL JOIN ВнутриSQL JOIN СлеваSQL JOIN СправаSQL JOIN ПолноеSQL JOIN СамSQL Оператор UNIONSQL GROUP BYSQL HAVINGSQL Оператор ExistsSQL Операторы Any, AllSQL SELECT INTOSQL INSERT INTO SELECTSQL Инструкция CASESQL Функции NULLSQL ХранимаяSQL Комментарии