在SQL Server中对视图进行增删改
原文:在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的操作,因此不需要修改任何存储过程和源代码,当然也不会对你原有的数据库造成影响。

posted on 2018-05-30 23:55 NET未来之路 阅读(...) 评论(...) 编辑 收藏

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

在SQL Server中对视图进行增删改相关推荐

  1. 细说Sql Server中的视图(下)转载

    原文:细说Sql Server中的视图(下)http://www.cnblogs.com/xbf321/archive/2009/06/19/view_two_in_sqlserver.html 1, ...

  2. 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 ...

  3. 创建视图SQL:在SQL Server中创建视图

    介绍 (Introduction) In this article, we are going to see how to use the CREATE VIEW SQL statement to c ...

  4. 如何在SQL Server中创建视图

    In this article, we will learn the basics of the view concept in SQL Server and then explore methods ...

  5. SQL Server 中系统视图sysobjects中type字段的说明

    对象类型: AF = 聚合函数 (CLR) C = CHECK 约束 D = DEFAULT(约束或独立) F = FOREIGN KEY 约束 FN = SQL 标量函数 FS = 程序集 (CLR ...

  6. 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 ...

  7. Sql server中 如何用sql语句创建视图 及 视图的作用

    1.视图的作用 视图的作用: 第一点:使用视图,可以定制用户数据,聚焦特定的数据. 解释: 在实际过程中,公司有不同角色的工作人员,我们以销售公司为例的话, 采购人员,可以需要一些与其有关的数据,而与 ...

  8. sql server中如何修改视图中的数据?

    原文地址::https://www.cnblogs.com/xielong/p/10516975.html 相关文章 1.MYSQL 视图的不可以更改数据----https://blog.csdn.n ...

  9. sql server 中 create or replace 视图方法

    sql server 中没有  create or replace 语法,可以用下面的语句: IF EXISTS(SELECT 1 FROM sys.views WHERE name = '视图名称' ...

  10. SQL Server中视图,存储过程,注入

    文章目录 一.视图 1.视图的概念 (1)视图的数据 (2)表视图的多样性 (3)视图的用途 2.视图的使用 1>视图的创建 (1)使用图文创建视图 (2)使用T-SQL创建视图 2> 删 ...

最新文章

  1. 微软todo使用教程_Todo教程可能很有趣-但是,这是从头开始构建自己的项目的方法...
  2. 数据中心机房工程建设需要注意的重大问题
  3. FinTech:一个单体系统足以撑起银行持续交付全球大项目
  4. python大气校正_Python 处理遥感图像:光谱辐射定标、大气校正和计算反射率
  5. Linux下NTP时间同步客户端配置
  6. PhoneGap开发环境搭建
  7. Apache虚拟机和访问控制
  8. android-Handler
  9. 【Android开发】高级组件-选项卡
  10. c#的const可以用于引用类型吗
  11. 【浅谈】样本方差的分母“n”为什么要改为“n-1”
  12. 计算机技能是啥,简历中的IT技能是什么意思?
  13. 有道云笔记分享_原来分享可以更美的 有道云笔记分享功能优雅变身
  14. php中的时间戳_php时间戳是什么
  15. 微生物16S测序数据的正确打开方式
  16. 【Dash搭建可视化网站】项目5: 利用Dash 实现动态图表
  17. 灰色关联分析(清风建模学习笔记)
  18. html导出excel换行,javascript导出excel或者csv如何让单元格内容换行?
  19. chrome网上应用商店支付注册金纪实
  20. 仿360手机卫士之查询号码归属地

热门文章

  1. 【渝粤教育】国家开放大学2019年春季 242机械制图 参考试题
  2. 各种排序算法稳定性的探讨
  3. 计算机网络基础系列(三)网络应用
  4. 整个社会总嫌自己不够“快”,为啥?
  5. 路由器配置 之 PAP与CHAP认证
  6. linq group by 多个字段取值以及取出重复的数据
  7. 【bzoj1194】 HNOI2006—潘多拉的盒子
  8. 使用Angular4手把手构建符合企业实际的项目管理系统----【npm】工具的使用
  9. Java操作文件夹的工具类
  10. iOS 使用UIView的一种有效方法