SqlServer系列之视图的创建与使用:


什么是视图?

视图的概述

在数据查询中,可以看到数据表设计过程中,考虑到数据的冗余度低、数据一致性等问题,通常对数据表的设计要满足范式的要求,因此也会造成一个实体的所有信息保存在多个表中。

当检索数据时,往往在一个表中不能够得到想要的所有信息。 为了解决这种矛盾,在SQL Server中提供了视图。

视图的概念

视图是一种数据库对象,是从一个或者多个数据表或视图中导出的虚表,视图的结构和数据是对数据表进行查询的结果,只存放视图的定义,不存放视图对应的数据;

其结构和和数据是建立在对表的查询基础上,故表中的数据发生变化,从视图中查询出的数据也随之改变。

视图的使用,跟对普通的表的查询使用完全一样。

视图的特点

1. 视图能够简化用户的操作,从而简化查询语句

2. 视图使用户能以多种角度看待同一数据,增加可读性

3. 视图对重构数据库提供了一定程度的逻辑独立性;

4. 视图能够对机密数据提供安全保护;

5. 适当的利用视图可以更清晰的表达查询。

使用视图的注意事项

1、只能在当前数据库中创建视图;

2、视图的命名必须遵循标识符命名规则,不可与表同名;

4、如果视图中某一列是函数、数学表达式、常量或者来自多个表的列名相同,则必须为列定义名称。

5、当视图引用基表或视图被删除,该视图也不能再被使用。

6、不能在视图上创建全文索引,不能在规则、默认的定义中引用视图。

7、一个视图最多可以引用1024个列。

8、视图最多可以嵌套32层。

视图的用途

1、筛选表中的行;

2、防止未经许可的用户访问敏感数据。降低数据库的复杂程度;

3、将多个物理数据库抽象为一个逻辑数据库。


手动创建视图

按照下面操作保存后创建成功;


代码创建视图

使用T-SQL语句创建视图

  1. CREATE VIEW view_StudentInfo
  2. AS
  3. SELECT语句

使用T-SQL语句删除视图

  1. --判断:如果存在指定视图则删除
  2. IF EXISTS (SELECT * FROM sysobjects WHERE name='view_StudentInfo') --单引号里面为视图名称
  3. DROP VIEW view_StudentInfo --视图名称

使用T-SQL语句查看视图

  1. SELECT * FROM view_StudentInfo

案例代码

  1. --判断:如果存在指定视图则删除
  2. IF EXISTS (SELECT * FROM sysobjects WHERE name='view_StudentInfo') --单引号里面为视图名称
  3. DROP VIEW view_StudentInfo --视图名称
  4. go
  5.  
  6. --创建成绩查询视图
  7. CREATE VIEW view_StudentInfo
  8. AS
  9. SELECT a.Number,a.NAME,c.ClassName,
  10. b.C#,b.SqlDB,b.Java,b.Python FROM a_Students a
  11. INNER JOIN a_StudentsScore b ON a.Number=b.Number
  12. INNER JOIN a_StudentClass c ON c.ClassId=a.ClassId
  13. go
  14.  
  15. --查询成绩视图
  16. SELECT * FROM view_StudentInfo

效果展示

欢迎关注订阅我的微信公众平台【熊泽有话说】,更多好玩易学知识等你来取

作者:熊泽-学习中的苦与乐
公众号:熊泽有话说


出处:https://www.cnblogs.com/xiongze520/p/14566646.html



创作不易,任何人或团体、机构全部转载或者部分转载、摘录,请在文章明显位置注明作者和原文链接。

SqlServer视图的创建与使用的更多相关文章

  1. SqlServer触发器的创建与使用

    前言 上期我们介绍了SqlServer的视图和存储过程创建与使用,这期我们介绍一下触发器. 有需要回顾的可以电梯直达看一下: SqlServer视图的创建与使用 SqlServer存储过程的创建与使用 ...

  2. SqlServer游标的创建与使用

    前言 大家都对SqlServer视图.存储过程.触发器的创建与使用有一定的了解了,我们来看下什么是游标,怎么使用,什么时候用. SqlServer视图的创建与使用 SqlServer存储过程的创建与使 ...

  3. SqlServer在视图上创建索引

    在视图上创建索引需要三个条件: 一.视图必须绑定到架构. 要做到这点,在 CREATE VIEW 语句中,必须加上 WITH SCHEMABINDING,如果是使用企业管理器,则在设计界面的空白处点击 ...

  4. SqlServer视图介绍以及创建方式

    1.,视图的介绍: (ps:学sqlServer视图是在面试问到之后学的,答不上来太low了,然后就去各种搜索操作对视图也有了自己的理解) 其实视图就是一张表,是一张表中或者多张表中经过某种筛选后显示 ...

  5. sqlserver查询所有表名、字段名、类型、长度和存储过程、视图的创建语句

    -- 获得存储过程创建语句 select o.xtype,o.name,cm.text from syscomments cm inner join sysobjects o on o.id=cm.i ...

  6. SqlServer 使用脚本创建分发服务及事务复制的可更新订阅

    原文:SqlServer 使用脚本创建分发服务及事务复制的可更新订阅 [创建使用本地分发服务器] /************************[使用本地分发服务器配置发布]*********** ...

  7. oracle 视图的创建,游标,left join

    视图的创建: create or replace view dmv_mat_contract_stock_in_bill as select csib.*, sib.STOCK_IO_, sib.CO ...

  8. SQLServer视图

    视图简介:通过定义 SELECT 语句以检索将在视图中显示的数据来创建视图.SELECT 语句引用的数据表称为视图的基表.在SQL Server 2005系统中,可以把视图分为3种类型,即标准视图,索 ...

  9. sqlserver 视图能否有变量

    不能,sqlserver 视图一般不能有变量,也不能带存储过程

随机推荐

  1. js coverage testing

    js coverage testing 测试覆盖率 istanbul 伊斯坦堡/伊斯坦布尔 https://istanbul.js.org/ jest coverage https://jestjs. ...

  2. CSS transition & shorthand property order

    CSS transition & shorthand property order shorthand property https://developer.mozilla.org/en-US ...

  3. PWA & TWA

    PWA & TWA https://www.bilibili.com/video/av68082979/ Service Worker workbox.js https://developer ...

  4. eui & search select

    eui & search select https://element.eleme.io/#/zh-CN/component/select demo <template> < ...

  5. jenkins+docker+nginx+tomcat实现vue项目部署

    一.项目准备 1.新建一个vue的项目,确保能在浏览器正常访问.然后在项目的根目录下新建一个Dockerfile的文件,内容如下 FROM nginx COPY dist /usr/share/ngi ...

  6. Vue脚手架中默认的margin怎么清除

    问题情景:开发中发现我的项目四周有白边,但是并没有设置样式 问题原因:vue脚手架中静态文件夹public中的index.html造成的 解决方案:找到vue脚手架中index.html页面,设置ma ...

  7. Spring @Transactional注解和ReentrantLock同步锁同时使用不能同步的问题

    结论:如果在service层的方法上同时使用事务和同步锁无法保证数据同步. 1 @Service 2 public class ServiceImpl{ 3 4 private static Lock ...

  8. Spring-03 依赖注入(DI)

    Spring-03 依赖注入(DI) 依赖注入(DI) 依赖注入(Dependency Injection,DI). 依赖 : 指Bean对象的创建依赖于容器,Bean对象的依赖资源. 注入 : 指B ...

  9. 转: 微信已支持发送最大 200MB 的视频了,并且不会被压缩 来自腾讯微信团队的视频消息,目前 iOS 版本的微信已支持发送最大 200MB 的视频与图片了,并且不会被压缩.安卓版本未来一段时间会支 ...

  10. 译文《全新首发JDK 16全部新特性》

    封面:洛小汐 译者:潘潘 JDK 8 的新特性都还没摸透,JDK 16 的新特性就提着刀来了. 郑重申明: 第一次冒险翻译专业领域的文献,可想而知,效果特别糟糕.一般翻译文献特别是 技术专业领域 的内 ...