本文章为 SQL Server 的详细学习大纲 里面的一个子章节的详细介绍,如果想了解相关的其他内容,可以从这里面查看,或者查看SQL Server专栏,里面有些文章可能并不在 SQL Server 的详细学习大纲 里面,是一些补充内容。
以下将详细介绍 SQL Server 中视图的创建和使用方法,包含创建简单视图和复杂视图,以及视图的查询、更新操作,还有视图在数据安全性和简化复杂查询方面的作用。
创建视图
创建简单视图
简单视图通常基于单个表,只进行基本的列选择和条件过滤。
-- 创建一个名为 EmployeeInfo 的简单视图,从 Employees 表中选择部分列
CREATE VIEW EmployeeInfo AS
SELECT EmployeeID, FirstName, LastName, HireDate
FROM Employees
WHERE Department = 'Sales';
在这个例子中,EmployeeInfo
视图从 Employees
表中选取 EmployeeID
、FirstName
、LastName
和 HireDate
列,并且只包含 Department
为 Sales
的员工记录。
创建复杂视图
复杂视图可能涉及多个表的连接和更复杂的条件。
-- 创建一个名为 OrderSummary 的复杂视图,连接 Employees 和 Orders 表
CREATE VIEW OrderSummary AS
SELECT e.EmployeeID, e.FirstName, e.LastName, COUNT(o.OrderID) AS OrderCount
FROM Employees e
JOIN Orders o ON e.EmployeeID = o.EmployeeID
GROUP BY e.EmployeeID, e.FirstName, e.LastName;
此视图将 Employees
表和 Orders
表进行连接,统计每个员工的订单数量。
使用视图
查询视图
创建好视图后,可像查询普通表一样查询视图。
-- 查询 EmployeeInfo 视图
SELECT * FROM EmployeeInfo;
-- 查询 OrderSummary 视图,只显示订单数量大于 10 的员工
SELECT * FROM OrderSummary WHERE OrderCount > 10;
通过视图更新基本表的数据
在满足一定条件下,可以通过视图更新基本表的数据。
-- 通过 EmployeeInfo 视图更新员工的雇佣日期
UPDATE EmployeeInfo
SET HireDate = '2023-01-01'
WHERE EmployeeID = 1;
需要注意的是,不是所有视图都支持更新操作,例如包含聚合函数、GROUP BY
子句、DISTINCT
关键字等的视图通常不支持更新。
视图在数据安全性和简化复杂查询方面的作用
数据安全性
视图可以限制用户对数据的访问,只让用户看到他们有权限访问的数据。例如,创建一个只包含员工部分信息的视图,不包含敏感信息(如工资、身份证号等)。
-- 创建一个名为 EmployeePublicInfo 的视图,只包含员工的公共信息
CREATE VIEW EmployeePublicInfo AS
SELECT EmployeeID, FirstName, LastName
FROM Employees;
简化复杂查询
当查询涉及多个表的连接和复杂的筛选条件时,可将查询定义为视图,之后直接查询视图,从而简化查询语句。
-- 创建一个名为 ProductSalesSummary 的视图,简化复杂的销售统计查询
CREATE VIEW ProductSalesSummary AS
SELECT p.ProductName, SUM(od.Quantity) AS TotalQuantity, SUM(od.Quantity * od.UnitPrice) AS TotalSales
FROM Products p
JOIN [Order Details] od ON p.ProductID = od.ProductID
JOIN Orders o ON od.OrderID = o.OrderID
GROUP BY p.ProductName;
-- 查询 ProductSalesSummary 视图,获取产品销售汇总信息
SELECT * FROM ProductSalesSummary;
通过以上示例,你可以了解如何在 SQL Server 中创建和使用视图,以及视图在数据安全性和简化复杂查询方面的重要作用。