博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在SQL Server中对视图进行增删改
阅读量:5105 次
发布时间:2019-06-13

本文共 3321 字,大约阅读时间需要 11 分钟。

原文:

发布以后,有一些网友问及如何在嵌入IM后与自己网站的用户系统整合(即如何让嵌入的IM直接使用网站原有的用户数据库,而不需要将已有的用户数据导入到IM的数据库中)。Lesktop对Users表(存储用户登录名,昵称,密码等信息的表)都是在存储过程中进行增删改的,显然,如果直接去改Users表相关的存储过程是比较麻烦的,本文将介绍一种较为简单的方法,在不需要修改存储过程和源代码的情况下整合用户系统

为实现这个目的,先介绍一下在SQL SERVER中,如何对视图进行增删改。假使用户有Name,Remark两项信息,但是没有存放在同一张表中,而是分开存储在两个表UserBase(ID, Name),UserExtent(ID, Remark)中。

image

为使用方便,建立一个视图Users,用于表示用户的完整信息,其定义如下:

CREATE VIEW [dbo].[Users]asSELECT 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是不可能的,执行时会发生以下错误:

image

在SQL Server中,对视图增删改可以通过触发器来实现,例如我们可以创建一个INSERT触发器,当在视图Users上执行INSERT时,在触发器中实现对UserBase,UserExtent的INSERT操作。在触发器中,可以通过名称为inserted的表,获取到新插入的行,具体代码如下:

CREATE TRIGGER [dbo].[Users_Insert] ON [dbo].[Users] INSTEAD OF INSERTasdeclare @name nvarchar(32), @remark nvarchar(32)declare ins_cursor cursorforselect Name, Remark from insertedopen ins_cursorfetch next from ins_cursor into @name, @remark;while(@@fetch_status = 0)begin        insert into UserBase (Name) values (@name);    insert into UserExtent(ID, Remark) values (@@identity, @remark);    fetch next from ins_cursor into @name, @remark;endclose 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;

执行结果如下:

image

创建更新触发器,与INSERT触发器类似,受影响的行会保存在inserted中,可以从inserted表中获取受影响的行,并更新UserBase,UserExtent,具体代码如下:

CREATE TRIGGER [dbo].[Users_Update] ON [dbo].[Users] INSTEAD OF UPDATEasupdate UserExtentset UserExtent.Remark=ins.Remarkfrom inserted inswhere UserExtent.ID = ins.ID;update UserBaseset UserBase.Name=ins.Namefrom inserted inswhere 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;

测试结果:

image

创建删除触发器,在删除的触发器中,可以通过deleted表,获取被删除的行,具体代码如下:

CREATE TRIGGER [dbo].[Users_Delete] ON [dbo].[Users] INSTEAD OF DELETEasdelete 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;

运行结果:

image

上文已介绍了如何对视图进行增删改,接下来将介绍如何通过建立视图并添加增删改触发器实现Lesktop开源IM用户系统的整合。首先介绍一下Lesktop开源IM数据库中Users表的结构:

image

假使您的网站的用户表(假使名称为MyUserTable)只有Name,Nickname:

image

那么,您可以建立一张扩展表(假使名称为UserExtentIM),用于存储其他信息:

image

接下来,您只需要把Users表删掉,重新建立一个名称为Users的视图,然后用上文处理Users, UserBase, UserExtent的方法,在Users视图上建好触发器,在触发器中对MyUserTable,UserExtentIM表进行增删改即可,Lesktop的存储过程对User进行读取和增删改时,将通过触发器自动转换成对MyUserTable,UserExtentIM的操作,因此不需要修改任何存储过程和源代码,当然也不会对你原有的数据库造成影响。

posted on
2018-05-30 23:55 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/lonelyxmas/p/9114414.html

你可能感兴趣的文章
linux中启动与终止lnmp的脚本
查看>>
gdb中信号的处理[转]
查看>>
学习Javascript闭包(Closure)
查看>>
LeetCode【709. 转换成小写字母】
查看>>
如何在Access2007中使用日期类型查询数据
查看>>
Jzoj4757 树上摩托
查看>>
CF992E Nastya and King-Shamans(线段树二分+思维)
查看>>
基于docker的spark-hadoop分布式集群之一: 环境搭建
查看>>
oracle 几个时间函数探究
查看>>
第一个Java Web程序
查看>>
Atomic
查看>>
div 显示滚动条与div显示隐藏的CSS代码
查看>>
Redis-1-安装
查看>>
Access denied for user ''@'localhost' to database 'mysql'
查看>>
微信公众号里面使用地图导航
查看>>
部署支持 https 的 Nginx 服务
查看>>
‘Cordova/CDVPlugin.h’ file not found
查看>>
WebAssembly是什么?
查看>>
C# 实现自动化打开和关闭可执行文件(或 关闭停止与系统交互的可执行文件)...
查看>>
20151214--JSTL
查看>>