Sql语法高级应用之二:视图

Posted Jacky

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Sql语法高级应用之二:视图相关的知识,希望对你有一定的参考价值。

SQL CREATE VIEW 语句

什么是视图?

在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表。

视图包含行和列,就像一个真实的表。视图中的字段就是来自一个或多个数据库中的真实的表中的字段。我们可以向视图添加 SQL 函数、WHERE 以及 JOIN 语句,我们也可以提交数据,就像这些来自于某个单一的表。

注释:数据库的设计和结构不会受到视图中的函数、where 或 join 语句的影响。

SQL CREATE VIEW 语法

CREATE VIEW view_name AS
SELECT column_name(s)
FROM table_name
WHERE condition

注释:视图总是显示最近的数据。每当用户查询视图时,数据库引擎通过使用 SQL 语句来重建数据。

 

SQL 更新视图

您可以使用下面的语法来更新视图:

SQL CREATE OR REPLACE VIEW Syntax
CREATE OR REPLACE VIEW view_name AS
SELECT column_name(s)
FROM table_name
WHERE condition

 

SQL 撤销视图

您可以通过 DROP VIEW 命令来删除视图。

SQL DROP VIEW Syntax
DROP VIEW view_name

 

视图实际应用

在EF框架中,涉及多表联合查询的明细列表来说,使用视图是优化查询速度最有效的方法之一。

新建视图的方式有两种:

一种是界面可视化创建,一种是使用SQL脚本创建。

下面我分享一个创建视图的通用脚本,对于刚入行的小白,可以保存下来,以备不时之需

USE Wot_Inventory
GO
IF EXISTS (SELECT 1 FROM sys.views WHERE Name = \'InvoiceSearchListView\')
    DROP VIEW InvoiceSearchListView;
GO
CREATE VIEW InvoiceSearchListView 
AS 
--替换掉视图名称,此处写你的查询即可

GO

 

 

PS:欢迎扫描下方二维码或点击链接,加入QQ群

一群用代码改变世界的

 

以上是关于Sql语法高级应用之二:视图的主要内容,如果未能解决你的问题,请参考以下文章

Sql语法高级应用之三:存储过程

Sql语法高级应用之六:如何在Sql语句中如何使用TRY...CATCH

SQL进阶篇之高级应用

MyBatis高级特性

Sql语法高级应用之五:使用存储过程实现对明细多层次统计

Vue.js系列之二Vue实例