sql 视图2005 视图

SQL SERVER 2005中对视图进行增删改操作技巧_西西软件资讯
西西软件园多重安全检测下载网站、值得信赖的软件下载站!
→ SQL SERVER 2005中对视图进行增删改操作技巧
V1.5.7.0 英文绿色免费版
类型:编程辅助大小:92KB语言:英文 评分:3.3
Lesktop开源IM发布以后,有一些网友问及如何在嵌入IM后与自己网站的用户系统整合(即如何让嵌入的IM直接使用网站原有的用户,而不需要将已有的用户数据导入到IM的数据库中)。Lesktop对Users表(存储用户登录名,昵称,密码等信息的表)都是在存储过程中进行增删改的,显然,如果直接去改Users表相关的存储过程是比较麻烦的,本文将介绍一种较为简单的方法,在不需要修改存储过程和源代码的情况下整合用户系统。
为实现这个目的,先介绍一下在SQL SERVER中,如何对视图进行增删改。假使用户有Name,Remark两项信息,但是没有存放在同一张表中,而是分开存储在两个表UserBase(ID, Name),UserExtent(ID, Remark)中。
为使用方便,建立一个视图Users,用于表示用户的完整信息,其定义如下:
CREATE VIEW [dbo].[Users]
SELECT b.ID as ID, b.Name as Name, e.Remark as Remark
FROM UserBase b, UserExtent e
WHERE b.ID = e.ID;.csharpcode, .csharpcode pre { font-size: color: font-family: consolas, "Courier New", courier, background-color: # /*white-space:*/ } .csharpcode pre { margin: 0 } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000 } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0 } .csharpcode .lnum { color: #606060; }
现在,我们希望通过Users视图进行增删改实现对UserBase,UserExtent表进行修改。显然,如果对Users直接执行insert,update,delete是不可能的,执行时会发生以下错误:
在SQL Server中,对视图增删改可以通过触发器来实现,例如我们可以创建一个INSERT触发器,当在视图Users上执行INSERT时,在触发器中实现对UserBase,UserExtent的INSERT操作。在触发器中,可以通过名称为inserted的表,获取到新插入的行,具体代码如下:
CREATE TRIGGER [dbo].[Users_Insert] ON [dbo].[Users] INSTEAD OF INSERT
declare @name nvarchar(32), @remark nvarchar(32)
declare ins_cursor cursor
select Name, Remark from inserted
open ins_cursor
fetch next from ins_cursor into @name, @
while(@@fetch_status = 0)
--读取所有行,并插入
insert into UserBase (Name) values (@name);
insert into UserExtent(ID, Remark) values (@@identity, @remark);
fetch next from ins_cursor into @name, @
close ins_cursor
下面我们通过插入两行数据测试触发器:
--清空所有数据
delete from UserE
delete from UserB
create table #temp(
name nvarchar(32),
remark nvarchar(32)
insert #temp (name,remark) values (N'user1', N'1');
insert #temp (name,remark) values (N'user2', N'2');
--插入两行数据
insert Users(name, remark)
select name,remark from #temp
drop table #temp
select * from U
select * from UserB
select * from UserE
执行结果如下:
创建更新触发器,与INSERT触发器类似,受影响的行会保存在inserted中,可以从inserted表中获取受影响的行,并更新UserBase,UserExtent,具体代码如下:
CREATE TRIGGER [dbo].[Users_Update] ON [dbo].[Users] INSTEAD OF UPDATE
update UserExtent
set UserExtent.Remark=ins.Remark
from inserted ins
where UserExtent.ID = ins.ID;
update UserBase
set UserBase.Name=ins.Name
from inserted ins
where UserBase.ID = ins.ID;
测试代码:
--清空所有数据
delete from UserE
delete from UserB
--插入两行数据
insert Users (name,remark) values (N'user1', N'1');
insert Users (name,remark) values (N'user2', N'2');
insert Users (name,remark) values (N'user3', N'2');
--修改后两行数据
UPDATE Users set Remark = N'3' where Remark = N'2'
--输出数据
select * from U
select * from UserB
select * from UserE.csharpcode, .csharpcode pre { font-size: color: font-family: consolas, "Courier New", courier, background-color: # /*white-space:*/ } .csharpcode pre { margin: 0 } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000 } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0 } .csharpcode .lnum { color: #606060; }
测试结果:
创建删除触发器,在删除的触发器中,可以通过deleted表,获取被删除的行,具体代码如下:
CREATE TRIGGER [dbo].[Users_Delete] ON [dbo].[Users] INSTEAD OF DELETE
delete from UserExtent where ID in (select ID from deleted)
delete from UserBase where ID in (select ID from deleted)
测试代码:
--清空所有数据
delete from UserE
delete from UserB
--插入两行数据
insert Users (name,remark) values (N'user1', N'1');
insert Users (name,remark) values (N'user2', N'2');
insert Users (name,remark) values (N'user3', N'2');
--删除后两行数据
delete from Users where Remark = N'2'
--输出数据
select * from U
select * from UserB
select * from UserE.csharpcode, .csharpcode pre { font-size: color: font-family: consolas, "Courier New", courier, background-color: # /*white-space:*/ } .csharpcode pre { margin: 0 } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000 } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0 } .csharpcode .lnum { color: #606060; }
运行结果:
上文已介绍了如何对视图进行增删改,接下来将介绍如何通过建立视图并添加增删改触发器实现Lesktop开源IM用户系统的整合。首先介绍一下Lesktop开源IM数据库中Users表的结构:
假使您的网站的用户表(假使名称为MyUserTable)只有Name,Nickname:
那么,您可以建立一张扩展表(假使名称为UserExtentIM),用于存储其他信息:
接下来,您只需要把Users表删掉,重新建立一个名称为Users的视图,然后用上文处理Users,UserBase,UserExtent的方法,在Users视图上建好触发器,在触发器中对MyUserTable,UserExtentIM表进行增删改即可,Lesktop的存储过程对User进行读取和增删改时,将通过触发器自动转换成对MyUserTable,UserExtentIM的操作,因此不需要修改任何存储过程和源代码,当然也不会对你原有的数据库造成影响。
01-2801-2701-2701-2401-2201-2101-1301-1201-1201-12
阅读本文后您有什么感想? 已有23人给出评价!
名称大小下载其他回答(2)
这个问题问得好!十天之内不要采纳答案。
关于视图我知道一点。在数据更新的时候视图也会一起更新,也就是说视图在数据更新的时候已经执行了查询(如果更新多的话。。。),在select 的时候不花查询时间。如果一个查询sql的一部分用视图来代替那这部分的查询时间就省掉了(读取与传输的时间当然还是要的)。所以总的来说视图是浪费了时间的(因为与视图相关的数据更新的时候都要执行一次查询)。但使用视图进行查询的时间是缩短了的。视图用在更新操作少而查询多的地方比较好。
问题1 视图和sql语句效率差在哪儿在sql中的视图一种是可以建立索引的,这儿的显然不是讨论这种的,如果视图没有建索引,这种视图和用sql语句查询的效率,相差无几,执行过的sql语句都会缓存预编译的结果,不管是在视图中inner join,还是在语句中inner join效果几乎没有差别。用视图有一个好处是使查询变的简单了(这很有意义),性能上我不认为会有什么提升。
问题2 在存储过程里面拼语句和直接拼sql语句执行效率差异在哪儿?
这种情况,个人认为没有什么差异,存储过程预编译,也不会预编译那些拼成的sql。如果说有效率差异,那在从客户端往服务器端传sql语句时,存储过程只需要传递少量的字节就可以了,这儿可能会有性能差异,但是也不是对存储过程预编译的差异。
园豆:8807
我们的DBA也建议我不要用存储过程,而是拼sql,不过他考虑的是数据库服务器的问题,而不只是两者性能之间的差距..
园豆:1200
&&&您需要以后才能回答,未注册用户请先。sql server
判断存储过程、触发器、视图是否存在并删除
1、判断是否存在addOneArticle这个存储过程&if Exists(select name from sysobjects where NAME = 'addOneArticle' and type='P')&& & drop procedure addOneArticle&2、判断是否存在countAr这个触发器&if exists(select * from dbo.sysobjects where id = object_id(N'[dbo].[countAr]') and OBJECTPROPERTY(id, N'IsTrigger') = 1)&& &drop trigger countAr&3、判断是否存在View_1这个视图&IF EXISTS (SELECT TABLE_NAME FROM INFORMATION_SCHEMA.VIEWS WHERE TABLE_NAME = N'View_1')&& & DROP View View_1&4、判断是否存在USER_Fun这个用户函数
(注意此处的type 有两种,分别是'TF'-Table-valued Function 表值函数 或'FN'-Scalar-valued Function 标量值函数)&if exists(select * from dbo.sysobjects where id = object_id(N'[dbo].[USER_Fun]') and (type = 'FN' or type = 'TF'))&& & DROP FUNCTION USER_Fun&
5、判断表'Tb'是否存在&if (exists (SELECT * FROM dbo.sysobjects where id = object_id(N'Tb')and OBJECTPROPERTY(id, N'IsUserTable') = 1))&DROP TABLE Tb
6、判断数据库是否存在
if exists( select * from master.dbo.sysdatabases where dbid=db_ID( 'scbjdb' ) )
drop database scbjdb
print 'no exist scbjdb'
原文链接:  视图是数据库中的一种虚拟表,与真实的表一样,视图包含一系列带有名称的行和列数据。行和列数据用来自定义视图的查询所引用的表,并且在引用视图时动态生成。
1. 视图的概念
  视图是从一个或者多个表中导出的,其行为与表相似,但视图是一个虚拟表。视图可以在已经存在的视图的基础上定义。在视图上用户可以使用SELECT语句查询数据库,使用INSERT、UPDATE和DELETE语句修改记录。对于视图的操作最终转化为对基本数据表的操作。
2. 创建视图
  使用T-SQL创建视图语法:
CREATE VIEW [ schema_name . ] view_name [ (column [ ,...n ] ) ]
[ WITH &view_attribute& [ ,...n ] ]
AS select_statement
[ WITH CHECK OPTION ]
  实例:
  单表视图
CREATE VIEW [dbo].[V_Product]
SELECT [ProductID],[ProductName]
FROM [dbo].[Product]
  多表视图
CREATE VIEW [dbo].[V_ProductCategory]
SELECT [ProductID],[CategoryName],[ProductName]
FROM [dbo].[Product] INNER JOIN [dbo].[Category]
ON [dbo].[Product].[CategoryID] = [dbo].[Category].[CategoryID]
  创建排序视图
CREATE VIEW [dbo].[V_Product]
SELECT TOP 100 PERCENT [ProductID],[ProductName]
FROM [dbo].[Product]
ORDER BY [UnitPrice]
3. 修改视图
  使用T-SQL修改视图语法:
ALTER VIEW [ schema_name . ] view_name [ ( column [ ,...n ] ) ]
[ WITH &view_attribute& [ ,...n ] ]
AS select_statement
[ WITH CHECK OPTION ] [ ; ]
4. 查看视图
  查看视图结构:
EXEC sp_help [V_Product]
  查看视图文本:
EXEC sp_helptext [V_Product]
5. 删除视图
  T-SQL删除视图语法:
DROP VIEW [ schema_name . ] view_name [ ...,n ] [ ; ]
  删除单个视图:
DROP VIEW [V_Product]
  删除多个视图:
DROP VIEW [V_Product],[V_ProductCategory]
阅读(...) 评论()

我要回帖

更多关于 sql 视图 的文章

 

随机推荐