视图 view
1. 什么是视图
视图是一种查看数据库中一个或多个表中的数据的方法。
视图是一种虚拟表。 通常是作为来自一个或多个表中的行或列的子集创建的,当然他也可以包含全部的行和列。
视图并不是数据库中存储的数据值的集合,它的行和列来自查询中引用的表。在执行时,他直接显示来自表中的数据。
2. 为什么使用视图
1) 提高数据的安全型,不同权限的用户可以查看数据的不同。
2) 符合用户日常业务逻辑
3. 视图的作用
筛选表中的行
防止未经许可的用户访问敏感数据
将多个物理数据表抽象为一个逻辑数据表
4.如何创建视图
视图语法整理:
1) 创建视图
create view view_name
as
<select 语句>
2) 修改视图
alter view view_name
as
<select 语句>
3)删除视图
drop view view_name
4)修改视图名称
exec sp_rename v_oldname,v_newname
5) 查看视图
select 列名 from view_name
5.视图的优缺点
优点: 简单、 安全、逻辑数据独立
缺点: 性能,修改限制
如果视图中存在函数或涉及复杂的多表查询,那么用户在查询视图的过程中会花费一定的时间。
对于简单的视图可以使用update 语句更新,如果对于复杂的视图可能就不能使用了。删除亦是如此。所以对于视图的用法最好只停留到查询上面。
表变量和临时表
表变量:表变量在SQLserver2000引入。表变量的具体定义包括列定义,列名,数据类型和约束。而在表变量中可以使用的约束包括主键约束,唯一约束,NULL约束和CHECK约束(外键约束不能在表变量中使用)。
临时表:
- 临时表的名称不能超过116个字符
- 局部临时表(以"#"开头命名的)作用域仅仅在当前的连接内
- 全局临时表(以"##"开头命名的)在所有的会话session内可见,所以在创建全局临时表之前首先检查其是否存在,否则如果已经存在,你将会得到重复创建对象的错误。
- 不能对临时表进行分区。
- 不能对临时表进行外键约束
数据库分页
数据库异常处理
Try...Catch是Sql Server 2005/2008令人印象深刻的新特性.提高了开发人员异常处理能力。
* TRY 块 - 包含可能产生异常的代码或脚本
* CATCH 块 - 如果TRY块出现异常,代码处理流将被路由到CATCH块.在这里你可以处理异常,记录日志等.
函数 | 描述 |
ERROR_NUMBER() | 返回导致运行 CATCH 块的错误消息的错误号 |
ERROR_SEVERITY() | 返回导致 CATCH 块运行的错误消息的严重级别 |
ERROR_STATE() | 返回导致 CATCH 块运行的错误消息的状态号 |
ERROR_PROCEDURE() | 返回出现错误的存储过程名称 |
ERROR_LINE() | 返回发生错误的行号 |
ERROR_MESSAGE() | 返回导致 CATCH 块运行的错误消息的完整文本 |