Sql Server的艺术(一) 视图的增删查改
视图是从一个或者多个表中查询数据的另一种方式。利用视图可以集中、简化定制数据库,同时还能保障安全。
视图其结构和数据是建立在对应的查询基础上的。和表一样,视图也是包括几个被定义的数据列和多个数据行,但本质而言,这些数据列和数据行来源于他所引用的表。所以试图不是真是存在的基础表,而是一张虚表。我们也可以对师徒中的数据进行增删查改(有一定限制)。
当然视图也有一定的优缺点:
● 简单性。视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使用户不必为以后的操作每次都指定全部的条件。
● 安全性。通过视图用户只能查询和修改他们所能见到的数据。数据库中的其他数据则既看不见也取不到。数据库授权命令可以使每个用户对数据库的检索限制到特定的数据库对象上,但不能授权到数据库特定行和特定的列上。通过视图,用户可以被限制在数据的不同子集上。
● 逻辑数据独立性。视图可以使应用程序和数据库表在一定程度上独立。如果没有视图,应用一定是建立在表上的。有了视图之后,程序可以建立在视图之上,从而程序与数据库表被视图分割开来。
视图也存在一些缺点,主要如下。
● 性能:SQL Server必须把视图的查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,即使是视图的一个简单查询,SQL Server也把它变成一个复杂的结合体,需要花费一定的时间。
● 修改限制:当用户试图修改视图的某些行时,SQL Server必须把它转化为对基本表的某些行的修改。对于简单视图来说,这是很方便的,但是,对于比较复杂的视图,可能是不可修改的。
一、为整表创建视图并查看其信息
--------创建一个与Student表对应的视图
CREATE VIEW Student_view
AS
select * from Student --------查询这个视图
select * from student_view

二、为视图创建视图并查看其信息
--------为Student_view视图创建一个所有男同学的视图Boy_View
create view Boy_View
as
select * from Student_view where Ssex='男' --------查询这个视图
select * from Boy_View

三、为列创建视图并查看其信息
--------为列创建视图并查看其信息
create view NameAge_View
as
select Sname,Sage from Student --------查询这个视图
select * from NameAge_View

四、为表创建具有不同字段名的视图并查看其信息
--------为表创建具有不同字段名的视图并查看其信息
--------Student表中所有男同学的姓名和性别
CREATE VIEW NewCloumnName_View(Name,Age)
AS
select Sname,Ssex from Student
where Ssex='男' --------查询这个视图
select * from NewCloumnName_View

五、为表创建具有不同字段名的视图并查看其信息
--------利用视图简化表的链接
--------Student,Teacher,Course表关联显示,学生的语文成绩
CREATE VIEW join_View(XM,KC,CJ)
AS
select Sname,Cname,score from Student,Course,Sc
where Sc.S#=Student.S#
and Sc.C#=Course.C# and Course.Cname='语文' --------查询这个视图
select * from join_View

六、修改视图
-------修改join_View视图中的数据
---------将王五同学的成绩改成999999
update join_View set CJ='' where XM='王五' --------查询这个视图
select * from join_View -----数据已经变为999999
--------查询原表数据
select Sname,Cname,score from Student,Course,Sc
where Sc.S#=Student.S#
and Sc.C#=Course.C# and Course.Cname='语文' -----数据已经变为999999

网上有些人说,视图只能查看删除,不能修改,但是个人实际操作发现,修改后,原表数据会跟着修改。
对于以上就是对视图的讲解基本操作,其中AS 后面的SQL语句是可以添加任意条件查询的,复杂查询就不做操作了,可以自行扩展。
七、删除销毁视图
DROP VIEW join_View
删除视图对实际表中的数据是不会有影响的。
八、视图的存放位置

九、注意事项

使用视图的几点原则:
- 和表一样,视图也有唯一的名字。不仅视图之间不允许 有相同的名字,并且视图与表业不允许拥有相同的名字。
- 视图的创建 个数不受限制,用户可以创建任意多个视图。
- 用户要创建试图,必须从数据库管理员那里得到权限。
- 视图可以嵌套,即可以创建视图的视图。(也就是第二条)
- 一些数据库管理系统(SQL Service)禁止用户在查询语句中使用Order By字句。(也就是第九条)
Sql Server的艺术(一) 视图的增删查改的更多相关文章
- CATransition:视图替换动画:子视图的增删查改
CATransition通常用于通过CALayer控制UIView内子控件的过渡动画,比如删除子控件,添加子控件,切换两个子控件等. 用于子视图的增删查改:
- SQL Server索引 - 索引(物化)视图 <第九篇>
一.索引视图基本概念 索引视图实际上是一种将一组唯一值“物化”为群集索引形式的视图,所为物化就是几乎和表一样,其数据也是会存储一份的(会占用硬盘空间,但是查询速度快,例如可以将count(),sum( ...
- SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)
SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)-DML 1.SQL INSERT INTO 语句(在表中插入) INSERT INTO 语句用于向表中插入新记录. SQL I ...
- SQL Server 表的管理_关于表的操作增删查改的操作的详解(案例代码)
SQL Server 表的管理_关于表的操作增删查改的操作的详解(案例代码) 概述: 表由行和列组成,每个表都必须有个表名. SQL CREATE TABLE 语法 CREATE TABLE tabl ...
- sql server中如何修改视图中的数据?
sql server中如何修改视图中的数据? 我做个测试,视图的数据有标记字段时,如果是这种方式(0 as FlagState),是无法修改的 --创建视图语句 --- create view V_E ...
- SQL Server跨服务器建立视图
create view View_AppCus as select dwmch,zjm from ksoa.dbo.mchk SQL Server跨服务器操作经常需要用到,下面就为你介绍的是SQL S ...
- 常用SQL语句(增删查改、合并统计、模糊搜索)
转自:http://www.cnblogs.com/ljianhui/archive/2012/08/13/2695906.html 常用SQL语句 首行当然是最基本的增删查改啦,其中最重要的是查. ...
- EF各版本增删查改及执行Sql语句
自从我开始使用Visual Studio 也已经经历了好几个版本了,而且这中间EF等框架的改变也算是比较多的.本篇文章记录下各个版本EF执行Sql语句和直接进行增删查改操作的区别,方便自己随时切换版本 ...
- EF增删查改加执行存储过程和sql语句,多种方法汇总
ActionUrl c = new ActionUrl() { ActionName="test", RequestUrl="/123/123", SubTim ...
随机推荐
- 积累jquery一些有意思的函数
$("#btn").unbind("click"); // 让btn这个元素的点击事件失效 $("#btn").unbind(); // 让 ...
- inline函数不能在for循环中使用的原因
inline函数的作用继承了宏定义的优点,没有了参数压栈,代码生成等一部分操作,并且摒弃了没有检查编译规则的缺点: 另外要注意,内联函数一般只会用在函数内容非常简单的时候,这是因为,内联函数的代码会在 ...
- Effective Java 第三版—— 20. 接口优于抽象类
Tips <Effective Java, Third Edition>一书英文版已经出版,这本书的第二版想必很多人都读过,号称Java四大名著之一,不过第二版2009年出版,到现在已经将 ...
- IE6的兼容性以及处理方法
1. 当我们写了一段正确的代码,但是在不同浏览器下,产生一些不正确的解析,这叫做兼容性问题 2. 在IE6下 ,标准盒模型: width/height = content; 可视宽/高 = conte ...
- spring 多线程 写入数据库 和 写入 xml文件
最近工作中遇到一个需求 多线程先爬取页面 然后将爬取的结果持久化到数据库中 ,一些大文本的内容需要持久化到 xml文件中; 下面是运行后的结果: xml 文件写入结果: 数据库写入结果: 再来张项目结 ...
- 存储库-MongoDB简单的操作
简介: MongoDB是一款强大.灵活.且易于扩展的通用型数据库 1.易用性 MongoDB是一个面向文档的数据库,而不是关系型的数据库: 不采用关系型主要是为了可扩展性 2.易扩展性 存储在Mong ...
- 连接WiFi工具类
public class WifiConnect { WifiManager wifiManager; // 构造函数 public WifiConnect(WifiManager wifiManag ...
- Java DB 访问之 mybatis mapper xml 配置方式
1 项目说明 项目采用 maven 组织 ,jdbc 唯一的依赖就是 mysql-connector-java pom 依赖如下: mysql 数据连接 : mysql-connector-java ...
- 个人整理方幂和公式(∑i^k 公式)
有个Oier小学妹问了我一个Σi^k,i<=1e8 ,k<=1e6的问题,我认为这个用伯努利数列可能可以解决他的问题,所以整理了以下文章,给学弟学习学习~~~本人水平有限,也只能帮到这里了 ...
- NowCoderWannafly挑战赛3-B.遇见
遇见 时间限制:C/C++ 1秒,其他语言2秒空间限制:C/C++ 65536K,其他语言131072K64bit IO Format: %lld 题目描述 A和B在同一条路上,他们之间的距离为 k ...
