Create ms sql view: SQL. 20. : (VIEW). [SQL.RU]

Содержание

Transact-SQL | Представления

176

Работа с базами данных в .NET Framework — SQL Server 2012 — Представления

Исходники баз данных

В предыдущих статьях инструкции DDL и DML рассматривались применительно к базовым таблицам. Данные базовой таблицы хранятся на диске. В отличие от базовых таблиц, представления по умолчанию не существуют физически, т.е. их содержимое не сохраняется на диске. Это не относится к так называемым индексированным представлениям, которые рассматриваются позже. Представления (views) — это объекты базы данных, которые всегда создаются на основе одной или более базовых таблиц (или других представлений), используя информацию метаданных. Эта информация (включая имя представления и способ получения строк из базовых таблиц) — все, что сохраняется физически для представления. По этой причине представления также называются виртуальными таблицами.

Создание представления

Представление создается посредством инструкции CREATE VIEW, синтаксис которой выглядит следующим образом:

Инструкция CREATE VIEW должна быть единственной инструкцией пакета. (Это означает, что эту инструкцию следует отделять от других инструкций группы посредством инструкции GO.)

Параметр view_name задает имя определяемого представления, а в параметре column_list указывается список имен, которые будут использоваться в качестве имен столбцов представления. Если этот необязательный параметр опущен, то используются имена столбцов таблиц, по которым создается представление. Параметр select_statement задает инструкция SELECT, которая извлекает строки и столбцы из таблиц (или других представлений). Параметр WITH ENCRYPTION задает шифрование инструкции SELECT, повышая таким образом уровень безопасности системы баз данных.

Предложение SCHEMABINDING привязывает представление к схеме таблицы, по которой оно создается. Когда это предложение указывается, имена объектов баз данных в инструкции SELECT должны состоять из двух частей, т.е. в виде schema.db_object, где schema — владелец, а db_object может быть таблицей, представлением или определяемой пользователем функцией.

Любая попытка модифицировать структуру представлений или таблиц, на которые ссылается созданное таким образом представление, будет неудачной. Чтобы такие таблицы или представления можно было модифицировать (инструкцией ALTER) или удалять (инструкцией DROP), нужно удалить это представление или убрать из него предложение SCHEMABINDING.

Когда при создании представления указывается параметр VIEW_METADATA, все его столбцы можно обновлять (за исключением столбцов с типом данных timestamp), если представление имеет триггеры INSERT или UPDATE INSTEAD OF.

Инструкция SELECT в представлении не может содержать предложение ORDER BY или параметр INTO. Кроме этого, по временным таблицам нельзя выполнять запросы.

Представления можно использовать для разных целей:

  • Для ограничения использования определенных столбцов и/или строк таблиц. Таким образом, представления можно использовать для управления доступом к определенной части одной или нескольких таблиц.

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

  • Для ограничения вставляемых или обновляемых значений некоторым диапазоном.

В примере ниже показано создание представления:

USE SampleDb;

GO
CREATE VIEW view_Consultant
    AS SELECT EmpId, ProjectNumber, EnterDate
    FROM Works_on
    WHERE Job = 'Консультант';

Запрос в этом примере выбирает из таблицы Works_on строки, удовлетворяющие условию Job=’Консультант’. Представление view_Consultant определяется строками и столбцами, возвращаемыми этим запросом. На рисунке ниже отображена таблица Works_on, в которой строки, выбранные в представлении view_Consultant, выделены красным цветом:

SQL VIEW — Oracle PL/SQL •MySQL •MariaDB •SQL Server •SQLite

В этом учебном материале вы узнаете, как создавать, обновлять и удалять SQL VIEWS с синтаксисом и примерами.

Описание

SQL VIEW (представление), по сути, является виртуальной таблицей, которая физически не существует. Скорее, он создается оператором SQL, который объединяет одну или несколько таблиц.

Создать SQL VIE

Синтаксис

Синтаксис для оператора CREATE VIEW в SQL.

CREATE VIEW view_name AS
SELECT columns
FROM tables
[WHERE conditions];

view_name
Имя SQL VIEW, которую вы хотите создать
WHERE conditions
Необязательный. Условия, которые должны быть выполнены для включения записей в представление.

Пример

Вот пример использования SQL CREATE VIEW.

CREATE VIEW sup_orders AS SELECT suppliers.supplier_id, orders.quantity, orders.price FROM suppliers INNER JOIN orders ON suppliers.supplier_id = orders.supplier_id WHERE suppliers.supplier_name = ‘IBM’;

CREATE VIEW sup_orders AS

  SELECT suppliers.supplier_id,

orders.quantity,

orders.price

    FROM suppliers

   INNER JOIN orders

      ON suppliers.supplier_id = orders.supplier_id

   WHERE suppliers.supplier_name = ‘IBM’;

Этот SQL пример CREATE VIEW создаст виртуальную таблицу на основе результирующего набора оператора select. Теперь вы можете запросить SQL VIEW следующим образом.

SELECT * FROM sup_orders;

SELECT *

  FROM sup_orders;

Обновить SQL VIEW

Вы можете изменить определение SQL VIEW, не удаляя его, с помощью SQL оператора CREATE OR REPLACE VIEW.

Синтаксис

Синтаксис для SQL оператора CREATE OR REPLACE VIEW.

CREATE OR REPLACE VIEW view_name AS
SELECT columns
FROM table
[WHERE conditions];

Пример

Вот пример того, как бы вы использовали SQL оператор CREATE OR REPLACE VIEW.

CREATE or REPLACE VIEW sup_orders AS SELECT suppliers.supplier_id, orders.quantity, orders.price FROM suppliers INNER JOIN orders ON suppliers.supplier_id = orders.supplier_id WHERE suppliers.supplier_name = ‘Microsoft’;

CREATE or REPLACE VIEW sup_orders AS

  SELECT suppliers.supplier_id,

         orders.quantity,

orders.price

    FROM suppliers

   INNER JOIN orders

      ON suppliers.supplier_id = orders.supplier_id

   WHERE suppliers.supplier_name = ‘Microsoft’;

В этом SQL примере CREATE OR REPLACE VIEW обновляет определение SQL VIEW, называемое sup_orders, не удаляя его. Если SQL VIEW еще не существует, SQL VIEW будет просто создан впервые.

Drop SQL VIEW

После создания SQL VIEW его можно удалить с помощью SQL оператора DROP VIEW.

Синтаксис

Синтаксис для SQL оператора DROP VIEW.

DROP VIEW view_name;

view_name
Название представления, которое вы хотите удалить

Пример

Вот пример использования SQL DROP VIEW.

В этом SQL примере DROP VIEW удалит VIEW с именем sup_orders.

Часто задаваемые вопросы

Вопрос: Можно ли обновить данные в SQL VIEW.
Ответ: VIEW в SQL создается путем объединения одной или нескольких таблиц. Когда вы обновляете записи в представлении, обновляются записи в базовых таблицах, составляющих представление SQL.

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

Вопрос: Существует ли представление SQL, если таблица удалена из базы данных.
Ответ: Да, в Oracle SQL VIEW продолжает существовать даже после того, как одна из таблиц (на которых основан SQL VIEW) удалена из базы данных. Однако если вы попытаетесь выполнить запрос SQL VIEW после того, как таблица была удалена, вы получите сообщение о том, что в SQL VIEW есть ошибки.
Если вы пересоздаете таблицу (таблицу, которую вы удалили), SQL VIEW снова будет в порядке.

Как создать представление (VIEW) MS SQL?

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

SQL Server создаем  представление (VIEW)

USE AdventureWorks2008;
GO

CREATE VIEW vProductLocation
AS
SELECT   P.Name           AS Product,
         L.Name           AS InventoryLoc,
         SUM(PI.Quantity) AS QtyAvailable
FROM     Production.Product AS P
INNER JOIN Production.ProductInventory AS PI  ON P.ProductID = PI.ProductID
INNER JOIN Production.Location AS L  ON PI.LocationID = L.LocationID
GROUP BY P.Name,
         L.Name
GO

Тестируем нашу выборку получая 5 случайных (псевдослучайных) записи

  
SELECT TOP(5) * FROM vProductLocation
ORDER BY NEWID()
GO

Получаем результат

     /*    Product                       InventoryLoc            QtyAvailable

     Bearing Ball                  Miscellaneous Storage   318
     Internal Lock Washer 4        Miscellaneous Storage   603
     ML Mountain Seat/Saddle       Subassembly             72
     LL Mountain Front Wheel       Subassembly             457
     LL Mountain Frame — Black, 40 Debur and Polish        129  */
     

SQL Server создаем  представление (VIEW)

CREATE VIEW vWorkOrder
AS
  SELECT WorkOrderID,
         P.Name  AS Product,
         OrderQty,
         CONVERT(DATE,DueDate) AS DueDate
FROM   Production.WorkOrder W
INNER JOIN Production.Product P ON W.ProductID = P.ProductID
WHERE  P.ProductSubcategoryID IN (2,3)
GO

 

Тестируем нашу выборку получая 3 случайных (псевдослучайных) записи

SELECT TOP(3) * FROM vWorkOrder
ORDER BY NEWID()
GO

Получаем результат
/*    WorkOrderID Product                 OrderQty    DueDate
34021       Road-550-W Yellow, 44   1           2003-06-04
27710       Road-650 Black, 58      120         2003-02-15
61003       Road-750 Black, 52      1           2004-03-28  */

Создаем представление (VIEW) на основе результата Хранимой Процедуры 

CREATE VIEW vSPWHO
 AS
    SELECT * FROM OPENQUERY(YOURSERVER, ‘exec sp_who’)
GO

SELECT * FROM vSPWHO
GO

Получаем результат
(131 row(s) affected)

Статьи по теме:

CREATE VIEW (Transact-SQL)

 

VIEW — Oracle PL/SQL •MySQL •MariaDB •SQL Server •SQLite

В этом учебном материале вы узнаете, как использовать, как создавать, обновлять и удалять Oracle VIEW

(представление) с синтаксисом и примерами.

Что такое VIEW в Oracle?

В Oracle VIEW в сущности, представляет собой виртуальную таблицу, которая физически не существует. Скорее всего, она создается с помощью запроса соединяющего одну или несколько таблиц.

CREATE VIEW

Синтаксис

Синтаксис CREATE VIEW в Oracle:

CREATE VIEW view_name AS
SELECT columns
FROM tables
[WHERE conditions];

Параметры или аргументы

view_name
Наименование Oracle VIEW, которое вы хотите создать.
WHERE conditions
Необязательный. Условия, которые должны быть выполнены для записей, которые будут включены в VIEW.

Пример

CREATE VIEW sup_orders AS SELECT suppliers.supplier_id, orders.quantity, orders.price FROM suppliers INNER JOIN orders ON suppliers.supplier_id = orders.supplier_id WHERE suppliers.supplier_name = ‘Microsoft’;

CREATE VIEW sup_orders AS

  SELECT suppliers.supplier_id, orders.quantity, orders.price

  FROM suppliers

  INNER JOIN orders

  ON suppliers.supplier_id = orders.supplier_id

  WHERE suppliers.supplier_name = ‘Microsoft’;

Этот пример Oracle CREATE VIEW создаст виртуальную таблицу на основе результирующего набора SELECT. Теперь вы можете запросить VIEW Oracle следующим образом:

SELECT *
FROM sup_orders;

Update VIEW

С помощью Oracle CREATE OR REPLACE VIEW вы можете изменить определенное в Oracle VIEW не удаляя его.

Синтаксис

CREATE OR REPLACE VIEW view_name AS
SELECT columns
FROM table
WHERE conditions;

view_name
Наименование представления Oracle, которое вы хотите создать или изменить.

Пример

CREATE or REPLACE VIEW sup_orders AS SELECT suppliers.supplier_id, orders.quantity, orders.price FROM suppliers INNER JOIN orders ON suppliers.supplier_id = orders.supplier_id WHERE suppliers.supplier_name = ‘Apple’;

CREATE or REPLACE VIEW sup_orders AS

  SELECT suppliers.supplier_id, orders.quantity, orders.price

  FROM suppliers

  INNER JOIN orders

  ON suppliers.supplier_id = orders.supplier_id

  WHERE suppliers.supplier_name = ‘Apple’;

Этот пример Oracle CREATE OR REPLACE VIEW обновит определенное в Oracle представление sup_orders без его удаления. Если Oracle VIEW еще не существовало, то представление будет создано впервые.

Drop VIEW

После того, как VIEW было создано, вы можете удалить его с помощью DROP VIEW.

Синтаксис

DROP VIEW view_name;

view_name
Наименование представления Oracle, который вы хотите создать или заменить.

Пример

Ниже приведен пример того, как использовать Oracle DROP VIEW:

Этот пример Oracle DROP VIEW удалит представление с названием sup_orders.

Часто задаваемые вопросы

Вопрос: Можно ли обновить данные в VIEW?
Ответ: Представление в Oracle создается путем объединения одной или нескольких таблиц. При обновлении записи (ей) в VIEW, обновляются записи в базовых таблицах, которые составляют VIEW.
Так что, да, вы можете обновить данные в Oracle VIEW при наличии у вас соответствующих привилегий в таблицах базы Oracle.

Вопрос: Будет ли существовать Oracle VIEW, если таблица удалится из базы данных?
Ответ: Да в Oracle VIEW продолжает существовать даже после того, как одна из таблиц (на которой основано VIEW) удаляется из базы данных. Тем не менее, если вы попытаетесь запросить VIEW Oracle после того, как таблица была удалена, вы получите сообщение о том, что Oracle VIEW содержит ошибку.
Если восстановить таблицу (таблицу которую удалили), то Oracle VIEW снова будет в порядке.

Как создать представление в SQL Server

В этой статье мы изучим основы концепции представления в SQL Server, а затем рассмотрим методы создания просматривать в SQL с помощью T-SQL и SQL Server Management Studio.

Определение

В большинстве случаев представления можно определить как «виртуальные или логические» таблицы, но если мы расширим это базовое определение, мы сможем понять представления более четко. Представление — это запрос, который хранится в базе данных и возвращает набор результатов запроса, в котором он определен.Запрос, определяющий представление, может состоять из одной или нескольких таблиц. Представление возвращает столбец или столбцы запроса, в котором на него есть ссылка. Тем не менее, мы должны подчеркнуть важный момент, связанный с представлениями: простое представление никогда не хранит данные, оно просто извлекает результаты запроса, в котором оно определено.

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

Как создать представление в SQL с одной таблицей

В этом разделе мы изучим синтаксис представлений. Следующий оператор определяет синтаксис представления:

CREATE VIEW view_name AS

SELECT column1, column2,…

FROM table_name

WHERE условие;

Сначала нам нужно указать CREATE VIEW оператор, а затем мы должны дать имя представлению. На втором этапе мы определяем оператор SELECT после ключевого слова AS . В В следующем примере будет создано представление с именем VProductSpecialList. VProductSpecialList Представление извлекает данные из таблицы Product и возвращает только ProductID , Name и ProductNumber столбцы продукта таблица:

СОЗДАТЬ ПРОСМОТР VProductSpecialList

AS

выберите стр.ProductID AS [ProductIdNumber],

p.Name AS [ProductName],

p.ProductNumber [ProductMainNumber] из [Production]. [Product] p

ГДЕ ProductID> 900

После создания представления мы можем получить данные с помощью простого оператора SELECT. В следующем примере показано как получить данные из представления VProductSpecialList :

ВЫБРАТЬ * ИЗ VProductSpecialList

Как вы можете видеть выше, имена столбцов были заменены псевдонимами, которые определены в определении запроса представления.Кроме того, данные, которые выбирает представление, фильтруются в соответствии с критериями WHERE заявление.

В зависимости от обстоятельств нам могут понадобиться определенные столбцы представления, для этого мы можем использовать только эти имена столбцов в операторе SELECT:

ВЫБЕРИТЕ ProductIdNumber, ProductName ИЗ VProductSpecialList

Как создать представление в SQL с несколькими таблицами

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

СОЗДАТЬ ПРОСМОТР VProductDetailList

AS

выберите p.ProductID AS [ProductIdNumber],

p.Name AS [ProductName],

p.ProductNumber [ProductMainName],

pm.Name как [ProductMainName],

pm. ]. [Продукт] p

INNER JOIN [Производство]. [ProductModel] pm

ON стр. [ProductModelID] = pm.[ProductModelID]

ГДЕ ProductID> 900

GO

ВЫБРАТЬ * ИЗ VProductDetailList ГДЕ ProductModelName = ‘LL Mountain Frame’

В приведенном выше примере показано, как создать представление из нескольких таблиц, а затем мы увидели, как мы получаем данные из это представление, и мы также отфильтровали полученные данные представления VProductDetailList.

Как создать представление в SQL через SSMS

SQL Server Management Studio AKA SSMS — самый популярный и мощный инструмент для управления, настройки, администрирования и выполнения других бесчисленных операций в SQL Server.Итак, мы можем создать представление через SSMS.

Мы запустим SSMS и войдем в базу данных с любым пользователем, который разрешил создание представления. Разверните базу данных, в которой мы хотим создать представление. Затем щелкните правой кнопкой мыши папку Views и выберите New Посмотреть вариант :

На экране появится диалоговое окно Добавить таблицу . На этом экране мы найдем, а затем выберем Product и ProductModel и нажмите Добавить :

Связи между таблицами автоматически обнаруживаются и создаются SSMS и одновременно запросом представления. будет автоматически сгенерирован во вкладке запроса:

На этом этапе мы отметим необходимые столбцы для представления.Если мы хотим выбрать все имена столбцов в таблицу, которую мы можем проверить в опции * (Все столбцы) . Мы проверим ProductId , Имя , ProductNumber столбцов в таблице Production и Имя столбца в таблице ProductModel . Мы можем наблюдать изменение запроса, когда проверяем в названиях столбцов таблиц:

Зададим псевдонимы столбцам:

Мы зададим критерии фильтра, и он будет автоматически добавлен в условие WHERE запроса:

Мы можем щелкнуть правой кнопкой мыши на панели таблицы, чтобы запустить представление.Данные результатов отображаются в нижней части экран:

Наконец, мы нажмем клавиши CTRL + S , чтобы сохранить представление и дать имя представлению и щелкнуть ОК :

Созданное представление можно найти в папке Views :

Как удалить представление в SQL

Чтобы удалить представление в базе данных, мы можем использовать оператор DROP VIEW .Тем не менее DROP VIEW Оператор может вернуть ошибку, если представление, которое мы хотим удалить, не существует в база данных. Чтобы решить эту проблему, мы можем использовать ключевое слово IF EXISTS с DROP. ПРОСМОТР заявление. Следующий сценарий удаляет vProductSpecialList из база данных:

УДАЛИТЬ ПРОСМОТР, ЕСЛИ СУЩЕСТВУЕТ [VProductSpecialList]

Заключение

В этой статье мы изучили понятие представления в SQL, а затем узнали, как создать представление в SQL двумя разными методами.В первом мы использовали метод T-SQL, а во втором — SQL Server Management. Студия.

Эсат Эркеч — специалист по SQL Server, который начал свою карьеру более 8 лет назад в качестве разработчика программного обеспечения. Он является сертифицированным экспертом по решениям Microsoft SQL Server.

Большая часть его карьеры была сосредоточена на администрировании и разработке баз данных SQL Server. В настоящее время он интересуется администрированием баз данных и бизнес-аналитикой. Вы можете найти его в LinkedIn.

Посмотреть все сообщения от Esat Erkec

Последние сообщения от Esat Erkec (посмотреть все) .

Создание представлений в SQL Server

Введение

В этой статье мы увидим, как использовать SQL-оператор CREATE VIEW для создания представления. Это первый статья из серии, которая будет посвящена программному подходу к созданию, изменению и работе с представлениями с использованием T-SQL. Если вы новичок и даже не знаете, что такое представление, не волнуйтесь. Мы начнем с определения, и затем переходите к некоторым основам, таким как синтаксис, примеры, варианты использования и т. д.

Представление — это просто виртуальная таблица. Думайте об этом как о просто запросе, который хранится на SQL Server и когда используется пользователем, он будет выглядеть и действовать как стол, но это не так. Это представление и не имеет определения или структуры Таблица. Его определение и структура — это просто запрос, который под капотом может получить доступ ко многим таблицам или части Таблица.

Представления можно использовать по нескольким причинам. Вот некоторые из основных причин:

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

При этом эти причины являются темой для разработки представлений, которую мы не будем касаться в этой серии.В этом В этой статье мы рассмотрим синтаксис CREATE VIEW SQL, посмотрим, что такое представления и что мы можем сделать. с ними.

Синтаксис

СОЗДАТЬ ИЛИ ИЗМЕНИТЬ ПРОСМОТР schema_name.view_name

WITH

AS select_statement

[WITH CHECK OPTION]

Мы все знаем, насколько сложным может быть синтаксис, но это не относится к представлениям.Представление можно создать, сказав СОЗДАТЬ ВИД, за которым следует имя С атрибутами просмотра:

  • ШИФРОВАНИЕ — Использование этого атрибута предотвращает публикацию представления как часть SQL Server. репликация
  • SCHEMABINDING — привязывает представление к схеме базовой таблицы. Мы будем использовать это в другая статья при индексировании просмотра
  • VIEW_METADATA — заставляет SQL Server возвращаться к API-интерфейсам DB-Library, ODBC и OLE DB. метаданные информация о представлении

После AS идет фактический оператор SELECT, определяющий запрос.Обычно это основная часть запроса AKA оператор DML, который будет создавать представление и его результаты.

Параметр WITH CHECK OPTION очень полезен при вставке данных через представление. Когда строка изменяется через представление, это Опция дает нам контроль над вставленными данными в таблицу, которая следует за предложением WHERE в определении представления. Подробнее об этом в следующей статье.

Оператор SQL CREATE VIEW

Без лишних слов запустим SQL Server Management Studio и приступим к работе с представлениями.Прежде чем использовать CREATE VIEW SQL-оператор, давайте создадим новую базу данных из Object Explorer с именем SQLShackDB , а затем создайте в нем несколько таблиц, запустив сценарий снизу:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

14

18

19

20

21

22

23

24

25

CREATE TABLE Сотрудники

(EmployeeID INT NOT NULL,

FirstName NVARCHAR (50) NOT NULL,

MiddleName NVARCHAR (50) NULL,

LastName NVARCHAR (75) NOT NULL,

Название NVARCH ,

HireDate DATETIME NOT NULL,

VacationHours SMALLINT NOT NULL,

Salary DECIMAL (19, 4) NOT NULL

);

GO

CREATE TABLE Products

(ProductID INT NOT NULL,

Имя NVARCHAR (255) NOT NULL,

Price DECIMAL (19, 4) NOT NULL

);

GO

CREATE TABLE Sales

(SalesID UNIQUEIDENTIFIER NOT NULL,

ProductID INT NOT NULL,

EmployeeID INT NOT NULL,

Quantity SMALLINT NOT NULL,

SaleDate

IME NOT NULL);

ГО

Теперь, когда у нас есть образец базы данных с таблицами, мы можем создать представление с именем vEmployeesWithSales , используя в качестве примера сценарий ниже:

ИСПОЛЬЗОВАТЬ SQLShackDB;

GO

СОЗДАТЬ ПРОСМОТР vEmployeesWithSales

AS

SELECT DISTINCT

сотрудников.*

ОТ сотрудников

ПРИСОЕДИНЯЙТЕСЬ к продажам НА сотрудников.EmployeeID = Sales.EmployeeID;

ГО

Это простое представление с простым оператором SELECT, которое возвращает список сотрудников, у которых есть продажа. Как важность Фактически, вы всегда можете протестировать запрос перед созданием представления, выполнив только часть SELECT команды CREATE VIEW SQL-запрос, и неплохо было бы посмотреть, вернет ли запрос что-нибудь.Убедитесь, что вы подключены к сначала выберите соответствующую базу данных, затем отметьте часть кода SELECT и нажмите Execute :

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

14

ИСПОЛЬЗОВАТЬ SQLShackDB;

GO

INSERT INTO Employees SELECT 1, «Ken», NULL, «Sánchez», «Торговый представитель», «01.01.2016», 2080, 45000;

ВСТАВИТЬ В сотрудников SELECT 2, «Дженис», NULL, «Галвин», «Торговый представитель», «11.12.2016», 2080, 45000;

ВСТАВИТЬ В продукты SELECT 1, ‘Джерси с длинным рукавом с логотипом, S’, 12.99;

INSERT INTO Products SELECT 2, ‘Джерси с длинным рукавом с логотипом, M’, 14,99;

INSERT INTO Products SELECT 3, ‘Джерси с длинным рукавом с логотипом, L’, 16,99;

INSERT INTO Products SELECT 4, ‘Джерси с длинным рукавом с логотипом, XL’, 18,99;

INSERT INTO Sales SELECT NEWID (), 1, 1, 4, ’04 / 15/2016 ‘;

INSERT INTO Sales SELECT NEWID (), 2, 1, 1, ’02 / 01/2016 ‘;

INSERT INTO Sales SELECT NEWID (), 3, 1, 2, ’03 / 12/2016 ‘;

INSERT INTO Sales SELECT NEWID (), 2, 2, 2, ’03 / 18/2016 ‘;

INSERT INTO Sales SELECT NEWID (), 3, 2, 1, ’04 / 16/2016 ‘;

INSERT INTO Sales SELECT NEWID (), 4, 2, 2, ’04 / 23/2016 ‘;

Чтобы убедиться, что данные успешно вставлены в наши таблицы, повторно выполните часть SELECT в CREATE VIEW. Оператор SQL, и он должен вернуть следующее:

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

Вернемся к нашему представлению и посмотрим, как он выглядит в нашей базе данных. Если мы перейдем к Object Explorer и разверните папку Views в нашей демонстрационной базе данных, мы найдем наше представление, которое выглядит точно так, как таблица, потому что в ней есть столбцы:

Это все столбцы, которые вернет это представление. Давайте посмотрим, что произойдет, если мы будем рассматривать это представление как таблицу. Написать SELECT, но вместо того, чтобы сказать: выберите все из, а затем имя таблицы, мы просто скажем из Посмотреть:

ВЫБРАТЬ * ИЗ vEmployeesWithSales

Как видно из рисунка выше, результат точно такой же, как и при запросе данных с использованием реальных таблиц.

Как и любой другой объект в SQL Server, представления тоже имеют свойства. В Object Explorer щелкните правой кнопкой мыши любой вид которого вы хотите просмотреть свойства и выберите Свойства :

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

  • ANSI NULL — указывает, был ли объект создан с опцией ANSI NULLs
  • Зашифровано — Указывает, зашифровано ли представление
  • Котируемый идентификатор — Показывает, был ли объект создан с опцией цитируемого идентификатора
  • Привязка схемы — Указывает, привязано ли представление к схеме

Заключение

В этой статье целью было только познакомиться с синтаксисом оператора CREATE VIEW SQL и создать базовое представление.Переход к более сложным вещам, таким как создание представления с агрегатами в нем, будет в центре внимания следующей статьи. Другими словами, мы собираемся использовать язык DLM (язык манипулирования данными) и напишем еще несколько продвинутых запросов SELECT.

Я надеюсь, что эта статья об операторе CREATE VIEW SQL была для вас информативной, и благодарю вас за ее чтение. Остаться настроен на следующий…

Содержание

Опытный инженер по обеспечению качества с подтвержденным опытом работы в индустрии компьютерного программного обеспечения.
Опытный специалист в области сетевых технологий, технической поддержки, Windows SQL Server и т. Д.
Сильный специалист в области информационных технологий с дипломом AP в области ИТ-технологий, со специализацией в сетях и электронных технологиях Копенгагенской школы дизайна и технологий.

Последние сообщения от Bojan Petrovic (посмотреть все) .

Вставка данных через представления в SQL Server

Это третья статья из цикла изучения оператора SQL CREATE VIEW. До сих пор я бы сказал, что мы хорошо знакомы с синтаксисом и научились создавать и изменять представления. В этой части мы продолжим работать с представлениями, используя образец базы данных и данные, которые мы создали.

Чтобы кратко резюмировать серию, в первой части о создании представлений в SQL Server идея заключалась в том, чтобы познакомиться с синтаксисом CREATE VIEW SQL, всеми различными вещами, которые мы можем делать с представлениями, и создать действительно базовое представление.

Во второй части, посвященной изменению представлений в SQL Server, мы немного повысили сложность и создали более сложное представление с агрегатами в нем. Кроме того, мы познакомились с оператором ALTER VIEW, используемым для изменения вывода путем изменения определения и структуры запроса.

Введение

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

Теперь пора начать использовать язык обработки данных (DML), который используется для управления самими данными, и посмотреть, как мы можем вставить данные в таблицу через представление.

Однако, прежде чем мы фактически вставим данные через представление, давайте посмотрим, как мы можем переименовать представление. Я также хочу показать вам одну изящную вещь, которую мы можем сделать с помощью CHECK OPTION, который является частью синтаксиса CREATE VIEW SQL. Этот параметр может быть полезен при вставке данных через представление, которое вы увидите позже в этой статье.

Переименование представлений

Представления переименовываются с помощью системной хранимой процедуры sp_rename. По определению, этот SP используется для изменения имени созданного пользователем объекта в текущей базе данных. При этом изменение любой части имени объекта, включая представления, может привести к нарушению скриптов и зависимостей, поэтому не рекомендуется использовать этот оператор для переименования представлений или любого другого объекта, созданного пользователем. Разумно было бы отбросить объект и воссоздать его с новым именем с помощью оператора CREATE VIEW SQL.

Переименование представлений с помощью стороннего программного обеспечения

Если вы хотите перестраховаться, я бы порекомендовал стороннее программное решение для безопасного переименования объектов SQL. Лично я использую бесплатные надстройки SQL Server Management Studio и Visual Studio для SQL Server под названием ApexSQL Search и ApexSQL Refactor. Обе надстройки имеют функцию Safe rename , которая переименовывает таблицы, процедуры, представления, функции и столбцы без нарушения зависимостей.

Подробные сведения о переименовании объектов SQL с помощью этой функции см. В следующих статьях:

Это серия статей об использовании T-SQL, поэтому мы собираемся сделать это с помощью упомянутой выше хранимой процедуры.Убедитесь, что вы подключены к базе данных SQLShackDB , или укажите имя базы данных в операторе USE, чтобы избежать ошибок от SQL Server. В приведенном ниже примере контекст базы данных изменяется на базу данных SQLShackDB и изменяется имя представления:

ИСПОЛЬЗОВАТЬ SQLShackDB;

GO

sp_rename

‘vEmployeesWithSales’,

‘vEmployees’;

Если мы перейдем к Object Explorer и обновим папку Views , мы должны увидеть, что имя изменилось на vEmployees .Также есть предупреждение от SQL Server об изменении любой части имени объекта, о котором я упоминал ранее:

Теперь давайте полностью изменим определение представления, выполнив приведенный ниже код:

ИСПОЛЬЗОВАТЬ SQLShackDB;

GO

ALTER VIEW vEmployees

AS

SELECT *

FROM Employees;

ГО

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

Не могу не заметить, что название вида подчеркнуто красным. Мы все когда-то это видели. Это указывает на ошибку в SSMS, в данном конкретном случае о недопустимом имени объекта, но это не так:

Это исходит от IntelliSense SSMS. Мы только что изменили имя представления, а метаданные еще не обновлены. То же самое произошло бы с оператором CREATE VIEW SQL. Сразу после создания объекта при запросе очень вероятно, что представление как источник будет подчеркнуто красным, пока кеш не будет обновлен.Простой способ исправить это, хотя это и не является фактической ошибкой (приведенный выше сценарий может быть выполнен без выдачи ошибки), — это обновить кеш IntelliSense вручную.

В SSMS перейдите к Изменить в главном меню. Разверните параметры Intellisense и выберите Обновить локальный кэш , как показано ниже:

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

Итак, давайте продолжим и выполним оператор ALTER VIEW , чтобы изменить определение представления на простой оператор SELECT , который извлекает все столбцы из таблицы Employees :

Итак, если мы сейчас запросим представление vEmployees , оно должно вернуть все столбцы из таблицы Employees , как показано ниже:

ИСПОЛЬЗОВАТЬ SQLShackDB;

GO

ВЫБРАТЬ * ОТ vEmployees;

Изменение данных с помощью просмотров

Наконец, давайте посмотрим, как мы можем изменять данные с помощью представления vEmployees .Это очень изящная вещь, которую мы можем сделать. Просто подумай об этом. Мы начали с SQL-оператора CREATE VIEW, затем создали очень простое представление, и теперь мы собираемся использовать это представление для вставки записи в нашу таблицу Employees .

Допустим, нам нужно вставить сотрудника через наше представление. Приведенный ниже код — это всего лишь пример вставки данных через представление с помощью оператора SELECT :

ИСПОЛЬЗОВАТЬ SQLShackDB;

GO

INSERT INTO vEmployees

SELECT 3,

‘Bojan’,

NULL,

‘Petrovic’,

‘Author’,

‘1/1/2017’, 20000 ,

‘100000.00 ‘;

Чтобы объяснить оператор INSERT INTO , я просто использую SELECT после имени нашего представления, что является очень простым способом вставки данных в таблицы, поскольку мы вставляем новые данные на основе результата SELECT. Заявление .

Представление vEmployees состоит из 8 столбцов. Мне нравится расширять папку Columns представления в Object Explorer просто для того, чтобы увидеть, какие столбцы не могут быть значениями, допускающими значение NULL, а также потому, что проще написать оператор SELECT и сопоставить все значения одно за другим.После выполнения вышеуказанного скрипта мы должны получить сообщение «1 строка затронута», означающее, что новая запись успешно вошла в таблицу:

Как, если мы проверим содержимое таблицы Employees , мы должны увидеть вновь вставленную запись, как показано ниже:

Как видно, мы можем изменять данные с помощью представлений. Довольно круто, правда? Теперь давайте продолжим наше путешествие и посмотрим, как мы можем использовать WITH CHECK OPTION, который является частью синтаксиса CREATE VIEW SQL.

Использование WITH CHECK OPTION в представлениях

Давайте посмотрим, как вступает в игру параметр WITH CHECK OPTION. Мы собираемся использовать тот же оператор ALTER VIEW из начала этой статьи, чтобы добавить этот параметр в наше представление, или вы можете просто отбросить его и использовать оператор SQL CREATE VIEW, чтобы воссоздать его с новым определением. Все зависит от вас. Все, что вы предпочитаете, нормально:

ИСПОЛЬЗОВАТЬ SQLShackDB;

GO

ALTER VIEW vEmployees

AS

SELECT *

FROM Employees

WHERE Title = «Торговый представитель»

WITH CHECK OPTION;

ГО

Как видите, мы также добавили предложение WHERE .После выполнения мы должны получить сообщение об успешном выполнении команды, что означает, что представление теперь имеет новое определение, включая WITH CHECK OPTION :

Итак, что делает параметр WITH CHECK OPTION в SQL Server, легко объяснить в следующем варианте использования. Допустим, мы хотим вставить еще одну запись, используя скрипт из предыдущего примера, когда только EmployeeID изменен на 4 :

ИСПОЛЬЗОВАТЬ SQLShackDB;

GO

INSERT INTO vEmployees

SELECT 4,

‘Bojan’,

NULL,

‘Petrovic’,

‘Author’,

‘1/1/2017’, 20000 ,

‘100000.00 ‘;

Давайте выполним эту команду и посмотрим, что произойдет. Вы увидите сообщение о том, что оператор был прерван, как показано ниже:

Вот полное ответное сообщение SQL Server, которое не видно на снимке выше:

Попытка вставить или обновить не удалась, потому что целевое представление либо указывает WITH CHECK OPTION, либо охватывает представление, которое указывает WITH CHECK OPTION, и одна или несколько строк, полученных в результате операции, не подпадают под ограничение CHECK OPTION.

Это сообщение об ошибке SQL Server означает, что любые вставленные данные через наше представление должны соответствовать условию в предложении WHERE . В этом конкретном случае были бы обновлены или вставлены только записи с условием Title = «Торговый представитель».

Итак, если мы изменим приведенный выше сценарий и поместим Торгового представителя вместо Автор для столбца Название , повторно выполните сценарий, он будет работать нормально.Теперь, если мы запросим таблицу Employees , она должна вернуть две идентичные записи:

Имейте в виду, что если мы запросим представление vEmployees , оно должно вернуть только запись торгового представителя из-за условия в предложении WHERE.

До сих пор, изучая SQL-оператор CREATE VIEW, мы также упоминали несколько интересных и полезных приемов, и, если вы спросите меня, это лишь некоторые действительно полезные вещи, которые нужно знать о представлении.

Удаление просмотров

Если вы спросите меня, удаление — это самое простое, что вы можете сделать в SQL Server. Теперь, когда я несколько раз упомянул об удалении и повторном создании представлений с помощью оператора CREATE VIEW SQL, давайте быстро пройдемся по нему и увидим синтаксис.

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

ИСПОЛЬЗОВАТЬ SQLShackDB;

GO

—Удалить представления из текущей базы данных

DROP VIEW vEmployees, vEmployeesWithSales;

ГО

После выполнения определение и другая информация о представлениях удаляется из системного каталога:

Заключение

В этой третьей части изучения оператора SQL CREATE VIEW мы увидели, как можно изменять данные с помощью представлений.При этом мы также узнали несколько интересных и полезных трюков, которые мы можем делать с представлениями, используя WITH CHECK OPTION. Мы также увидели, как переименовывать и удалять представления из текущей базы данных. В следующей статье мы рассмотрим индексированные представления и способы работы с ними. Мы изучим SCHEMABINDING, используемый для привязки представления к схеме базовой таблицы.

Я надеюсь, что эта статья была для вас информативной, и благодарю вас за ее прочтение. Следите за новостями…

Содержание

Опытный инженер по обеспечению качества с подтвержденным опытом работы в индустрии компьютерного программного обеспечения.
Опытный специалист в области сетевых технологий, технической поддержки, Windows SQL Server и т. Д.
Сильный специалист в области информационных технологий с дипломом AP в области ИТ-технологий, со специализацией «Сети и электронные технологии» Копенгагенской школы дизайна и технологий.

Последние сообщения Bojan Petrovic (посмотреть все) .

SQL: ПРОСМОТР


В этом руководстве по SQL объясняется, как создавать, обновлять и удалять SQL VIEWS с синтаксисом и примерами.

Описание

SQL VIEW — это, по сути, виртуальная таблица, которая не существует физически. Скорее, он создается оператором SQL, который объединяет одну или несколько таблиц.

Создание представления SQL

Синтаксис

Синтаксис оператора CREATE VIEW в SQL:

 СОЗДАТЬ ПРОСМОТР имя_представления AS
  ВЫБРАТЬ столбцы
  ИЗ столов
  [ГДЕ условия]; 
имя_представления
Имя представления SQL, которое вы хотите создать.
ГДЕ условия
Необязательно. Условия, которые должны быть выполнены для включения записей в ПРОСМОТР.

Пример

Вот пример использования SQL CREATE VIEW:

 СОЗДАТЬ ПРОСМОТР sup_orders AS
  ВЫБЕРИТЕ поставщиков.supplier_id, orders.quantity, orders.price
  ОТ поставщиков
  INNER JOIN заказы
  ВКЛ. Vendors.supplier_id = orders.supplier_id
  ГДЕ vendors.supplier_name = 'IBM'; 

В этом примере SQL CREATE VIEW будет создана виртуальная таблица на основе набора результатов оператора select.Теперь вы можете запросить SQL VIEW следующим образом:

 ВЫБРАТЬ *
ОТ sup_orders; 

Обновление SQL VIEW

Вы можете изменить определение SQL VIEW, не удаляя его, используя оператор SQL CREATE OR REPLACE VIEW.

Синтаксис

Синтаксис оператора SQL CREATE OR REPLACE VIEW:

 СОЗДАТЬ ИЛИ ЗАМЕНИТЬ ВИД view_name AS
  ВЫБРАТЬ столбцы
  ИЗ таблицы
  [ГДЕ условия]; 

Пример

Вот пример использования оператора SQL CREATE OR REPLACE VIEW:

 СОЗДАТЬ ИЛИ ЗАМЕНИТЬ ВИД sup_orders AS
  ВЫБЕРИТЕ поставщиков.поставщик_id, orders.quantity, orders.price
  ОТ поставщиков
  INNER JOIN заказы
  ВКЛ. Vendors.supplier_id = orders.supplier_id
  ГДЕ vendors.supplier_name = 'Microsoft'; 

Этот пример SQL CREATE OR REPLACE VIEW обновит определение SQL VIEW под названием sup_orders , не отбрасывая его. Если бы SQL VIEW еще не существовал, SQL VIEW был бы просто создан в первый раз.

Drop SQL VIEW

После создания SQL VIEW его можно отбросить с помощью оператора SQL DROP VIEW.

Синтаксис

Синтаксис оператора SQL DROP VIEW:

 DROP VIEW view_name; 
имя_представления
Имя представления, которое вы хотите удалить.

Пример

Вот пример использования оператора SQL DROP VIEW:

 ПРОСМОТР sup_orders; 

Этот пример SQL DROP VIEW отбрасывает / удаляет SQL VIEW с именем sup_orders .

Часто задаваемые вопросы

Вопрос: Можете ли вы обновить данные в SQL VIEW?

Ответ: ВИД в SQL создается путем объединения одной или нескольких таблиц.Когда вы обновляете записи в представлении, он обновляет записи в базовых таблицах, составляющих представление SQL.

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


Вопрос: существует ли представление SQL, если таблица удаляется из базы данных?

Ответ: Да, в Oracle SQL VIEW продолжает существовать даже после того, как одна из таблиц (на которой основан SQL VIEW) удаляется из базы данных.Однако, если вы попытаетесь запросить SQL VIEW после того, как таблица была отброшена, вы получите сообщение, указывающее, что в SQL VIEW есть ошибки.

Если вы воссоздадите таблицу (таблицу, которую вы отбросили), SQL VIEW снова будет в порядке.

.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *