在SQL Server中对视图进行增删改
Lesktop开源IM发布以后,有一些网友问及如何在嵌入IM后与自己网站的用户系统整合(即如何让嵌入的IM直接使用网站原有的用户数据库,而不需要将已有的用户数据导入到IM的数据库中)。Lesktop对Users表(存储用户登录名,昵称,密码等信息的表)都是在存储过程中进行增删改的,显然,如果直接去改Users表相关的存储过程是比较麻烦的,本文将介绍一种较为简单的方法,在不需要修改存储过程和源代码的情况下整合用户系统。
为实现这个目的,先介绍一下在SQL SERVER中,如何对视图进行增删改。假使用户有Name,Remark两项信息,但是没有存放在同一张表中,而是分开存储在两个表UserBase(ID, Name),UserExtent(ID, Remark)中。
为使用方便,建立一个视图Users,用于表示用户的完整信息,其定义如下:
CREATE VIEW [dbo].[Users]
as
SELECT b.ID as ID, b.Name as Name, e.Remark as Remark
FROM UserBase b, UserExtent e
WHERE b.ID = e.ID;
现在,我们希望通过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
as
declare @name nvarchar(32), @remark nvarchar(32)
declare ins_cursor cursor
for
select Name, Remark from inserted
open ins_cursor
fetch next from ins_cursor into @name, @remark;
while(@@fetch_status = 0)
begininsert into UserBase (Name) values (@name);insert into UserExtent(ID, Remark) values (@@identity, @remark);fetch next from ins_cursor into @name, @remark;
end
close ins_cursor
下面我们通过插入两行数据测试触发器:
delete from UserExtent;
delete from UserBase;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 #tempdrop table #tempselect * from Users;
select * from UserBase;
select * from UserExtent;
执行结果如下:
创建更新触发器,与INSERT触发器类似,受影响的行会保存在inserted中,可以从inserted表中获取受影响的行,并更新UserBase,UserExtent,具体代码如下:
CREATE TRIGGER [dbo].[Users_Update] ON [dbo].[Users] INSTEAD OF UPDATE
as
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 UserExtent;
delete from UserBase;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 Users;
select * from UserBase;
select * from UserExtent;
测试结果:
创建删除触发器,在删除的触发器中,可以通过deleted表,获取被删除的行,具体代码如下:
CREATE TRIGGER [dbo].[Users_Delete] ON [dbo].[Users] INSTEAD OF DELETE
as
delete from UserExtent where ID in (select ID from deleted)
delete from UserBase where ID in (select ID from deleted)
测试代码:
delete from UserExtent;
delete from UserBase;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 Users;
select * from UserBase;
select * from UserExtent;
运行结果:
上文已介绍了如何对视图进行增删改,接下来将介绍如何通过建立视图并添加增删改触发器实现Lesktop开源IM用户系统的整合。首先介绍一下Lesktop开源IM数据库中Users表的结构:
假使您的网站的用户表(假使名称为MyUserTable)只有Name,Nickname:
那么,您可以建立一张扩展表(假使名称为UserExtentIM),用于存储其他信息:
接下来,您只需要把Users表删掉,重新建立一个名称为Users的视图,然后用上文处理Users, UserBase, UserExtent的方法,在Users视图上建好触发器,在触发器中对MyUserTable,UserExtentIM表进行增删改即可,Lesktop的存储过程对User进行读取和增删改时,将通过触发器自动转换成对MyUserTable,UserExtentIM的操作,因此不需要修改任何存储过程和源代码,当然也不会对你原有的数据库造成影响。
转载于:https://www.cnblogs.com/lonelyxmas/p/9114414.html
在SQL Server中对视图进行增删改相关推荐
- 细说Sql Server中的视图(下)转载
原文:细说Sql Server中的视图(下)http://www.cnblogs.com/xbf321/archive/2009/06/19/view_two_in_sqlserver.html 1, ...
- CREATE VIEW SQL:通过SQL Server中的视图插入数据
This is the third article in a series of learning the CREATE VIEW SQL statement. So far, I'd say tha ...
- 创建视图SQL:在SQL Server中创建视图
介绍 (Introduction) In this article, we are going to see how to use the CREATE VIEW SQL statement to c ...
- 如何在SQL Server中创建视图
In this article, we will learn the basics of the view concept in SQL Server and then explore methods ...
- SQL Server 中系统视图sysobjects中type字段的说明
对象类型: AF = 聚合函数 (CLR) C = CHECK 约束 D = DEFAULT(约束或独立) F = FOREIGN KEY 约束 FN = SQL 标量函数 FS = 程序集 (CLR ...
- CREATE VIEW SQL:在SQL Server中使用索引视图
This is the fourth article in a series of learning the CREATE VIEW SQL statement. So far, we have do ...
- Sql server中 如何用sql语句创建视图 及 视图的作用
1.视图的作用 视图的作用: 第一点:使用视图,可以定制用户数据,聚焦特定的数据. 解释: 在实际过程中,公司有不同角色的工作人员,我们以销售公司为例的话, 采购人员,可以需要一些与其有关的数据,而与 ...
- sql server中如何修改视图中的数据?
原文地址::https://www.cnblogs.com/xielong/p/10516975.html 相关文章 1.MYSQL 视图的不可以更改数据----https://blog.csdn.n ...
- sql server 中 create or replace 视图方法
sql server 中没有 create or replace 语法,可以用下面的语句: IF EXISTS(SELECT 1 FROM sys.views WHERE name = '视图名称' ...
- SQL Server中视图,存储过程,注入
文章目录 一.视图 1.视图的概念 (1)视图的数据 (2)表视图的多样性 (3)视图的用途 2.视图的使用 1>视图的创建 (1)使用图文创建视图 (2)使用T-SQL创建视图 2> 删 ...
最新文章
- 微软todo使用教程_Todo教程可能很有趣-但是,这是从头开始构建自己的项目的方法...
- 数据中心机房工程建设需要注意的重大问题
- FinTech:一个单体系统足以撑起银行持续交付全球大项目
- python大气校正_Python 处理遥感图像:光谱辐射定标、大气校正和计算反射率
- Linux下NTP时间同步客户端配置
- PhoneGap开发环境搭建
- Apache虚拟机和访问控制
- android-Handler
- 【Android开发】高级组件-选项卡
- c#的const可以用于引用类型吗
- 【浅谈】样本方差的分母“n”为什么要改为“n-1”
- 计算机技能是啥,简历中的IT技能是什么意思?
- 有道云笔记分享_原来分享可以更美的 有道云笔记分享功能优雅变身
- php中的时间戳_php时间戳是什么
- 微生物16S测序数据的正确打开方式
- 【Dash搭建可视化网站】项目5: 利用Dash 实现动态图表
- 灰色关联分析(清风建模学习笔记)
- html导出excel换行,javascript导出excel或者csv如何让单元格内容换行?
- chrome网上应用商店支付注册金纪实
- 仿360手机卫士之查询号码归属地