社区
MS-SQL Server
帖子详情
sql_server中触发器使用一例。。。
lanble
2001-03-26 01:16:00
如何创建一触发器他的功能如下:
表中字段有 userno,userName,address,
如果对表进行插入操作时,判断username字段的内容是否存在如果存在则取消插入操作,谢谢各位大虾帮助!1
...全文
157
8
打赏
收藏
sql_server中触发器使用一例。。。
如何创建一触发器他的功能如下: 表中字段有 userno,userName,address, 如果对表进行插入操作时,判断username字段的内容是否存在如果存在则取消插入操作,谢谢各位大虾帮助!1
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
8 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
nononono
2001-04-04
打赏
举报
回复
Create Trigger xxx on table for insert
as
if exists (select * from inserted as a inner join table as b on a.username=b.username)
rollback transaction
return
pjy
2001-04-04
打赏
举报
回复
在触发器中使用
begin tran
if ...
rollback tran
else
commit tran
但限制同楼上所说一样,你的注意增加语句的写法!
lanble
2001-03-26
打赏
举报
回复
我是指对插入的USERNAEM的内容判断是否重复,也就是该字段的内容已经在表内存在时,然后则取消该插入操作,否则继续!!!
renzhm
2001-03-26
打赏
举报
回复
触发器当然可以创建:如yangzi(笨笨)create trigger name for update
但这种机制很没有'科学道理'
你不妨这样解决:
1.把该字段设为非空.
2.在插入这条记录之前判断username是否为空
yangzi
2001-03-26
打赏
举报
回复
这样写
create trigger xxx
as
delete from your_table where username in (select username from inserted where username is null or username ='')
可能效率不会很高。
不过,你既然不允许它空,那么为什么不设该字段非空呢?
格兰特杨
2001-03-26
打赏
举报
回复
但只能处理一条一条的insert,若用了
insert into table
select * form table1
这种做法,我想我无能为力。
:(
格兰特杨
2001-03-26
打赏
举报
回复
Create Trigger xxx on table for insert
as
if (select count(*) from table
where
username = (select username from inserted)) > 1
rollback transaction
go
It will be ok.
格兰特杨
2001-03-26
打赏
举报
回复
Create Trigger xxx on table for insert
as
if (select count(*) from table
where
username = (select username from inserted)) > 1
rollback transaction
go
It will be ok.
利用
SQL
Server
触发器
实现表的历史修改痕迹记录
在很多应用程序开发
中
,需要记录某些数据表的历史记录或修改痕迹,以便日后出现数据错误时进行数据排查。这种业务需求,我们可以通过数据库的
触发器
来轻松实现历史记录功能。 本文以
SQL
Server
2005数据库
中
的
触发器
为例(因为手
中
的项目用的就是这个数据库) 先简单描述一下
SQL
Server
触发器
。
SQL
Server
触发器
的inserted和deleted
SQL
Server
为每个
触发器
都创建了两个专用虚拟表:inserted表和deleted表。这两个表由系统来维护,他们存在于内存
中
,而不是在数据库
中
。这两个表的结构总是与被该
触发器
作用的表结构相同。
触发器
执行完成后,与该
触发器
相关的两
Microsoft
SQL
Server
2005技术内幕: T-SQ程序设计.pdf
SQL
Server
2005微软官方权威参考手册 是Inside Microsoft
SQL
Server
2005系列书
中
的第一本,
SQL
Server
类的顶尖之作 全球公认
SQL
Server
2005经典著作,囊括大量鲜为人知的技术内幕,大师智慧、专家经验尽览无余。 本系列图书
中
文版得到了微软总部
SQL
Server
组专家的高度重视,同时也得到了微软
中
国上海
SQL
Server
全球技术支持
中
心的高度关注。 本书详细介绍了T-
SQL
的内部构造,包含了非常全面的编程参考。数据库开发人员和DBA可以通过书
中
的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的问题。本书涵盖了T-
SQL
程序设计的方方面面,如基于集合的编程技术、日期和时间相关的XML和CLR数据类型的
使用
、临时对象、T-
SQL
和CLR用户自定义函数、存储过程、
触发器
、事务和新的错误处理结构、应用并发模型支持并发用户、
使用
Service Broker来控制数据库应用程序
中
的异步处理等。 内容简介 本书是Inside Microsoft
SQL
Server
2005系列四本著作
中
的一本。它详细介绍了T-
SQL
的内部构造,包含了非常全面的编程参考。它提供了
使用
Transact-
SQL
(T-
SQL
)的专家级指导,T-
SQL
是用于
SQL
Server
的最常见的也是功能最强大的编程语言。该书由Itzik Ben-Gan权威执笔,重点关注语言特性以及它们如何被
SQL
Server
引擎解释和处理。 通过本书,你将深入了解T-
SQL
的高级用法,包括
触发器
、用户自定义函数、异常处理等。该书解释并比较了
SQL
Server
2000和
SQL
Server
2005在数据库开发相关问题上的解决方案,深入讨论了
SQL
Server
2005
中
新增的T-
SQL
编程特性,包含了大量的代码示例、表示例和逻辑难题以帮助数据库开发人员和管理员理解复杂的逻辑并掌握T-
SQL
。 本书适合于专业数据库开发者、BI开发者、DBA和以
SQL
Server
作为后台数据库的一般应用程序开发者,读者可以通过书
中
的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的实际问题。 作者简介 Itzik Ben-Gan是Solid Quality Learning的导师和创始人。从1999年开始,他一直是Microsoft
SQL
Server
MVP(最有价值专家),并在全世界已经开展过无数次T-
SQL
查询、T-
SQL
优化和编程方面的培训。Itzik是Microsoft
SQL
Server
方面几本著作的作者。他在
SQL
Server
Magazine和MSDN上发表了许多文章和白皮书。Itzik被邀请在许多会议上做报告,包括TechEd、DevWeek、世界各地的各种
SQL
用户组、PASS、
SQL
server
Magazine Connections和Solid Quality Learning的会议。 从1992年开始,Itzik就一直致力于涉及各种数据库和计算机系统相关技术的多个课题。除了帮助顾客处理紧迫的要求、修复问题、优化数据库、教学和担任顾问以外,他还帮助开发人员和数据库管理员转变关系/基于集合的理念,改善他们编写代码的性能和可维护性。Itzik擅长T-
SQL
查询、查询优化、编程和内部原理,此外他还精通其他的数据库领域。1999年,Itzik创立以色列
SQL
Server
和OLAP用户组,一直管理至今。 目录 序 前言 致谢 引言 第1章 数据类型相关的问题,XML和CLR UDT 1.1 DATETIME数据类型 DATETIME的存储格式 时间处理 Datetime相关的查询问题 1.2 与字符相关的问题 模式匹配 区分大小写(Case-Sensitive)的筛选器 1.3 大型对象(Large Object,LOB) MAX 说明符 BULK行集提供程序 1.4 隐式转换(Implicit Conversion) 标量表达式 筛选表达式 1.5 基于CLR的用户定义类型 UDT理论简介 开发UDT 1.6 XML数据类型 关系数据库
中
的XML支持 什么时候应该
使用
XML代替关系表现形式? 数据库
中
的XML序列化对象
使用
开放架构(Open Schema)的XML 作为存储过程参数的XML数据类型 Xquery修改语句 1.7 结论 第2章 临时表和表变量 2.1 临时表 局部临时表 全局临时表 2.2 表变量 限制条件 tempdb 范围和可见性 事务上下文 统计信息 2.3 tempdb相关的注意事项 2.4 表表达式 2.5 比较临时对象 2.6 综合练习——关系分区(Relational Division) 2.7 结论 第3章 游标 3.1
使用
游标 3.2 游标开销 3.3 单独处理每一行 3.4 按顺序访问 自定义聚合 连续聚合 最大并发会话 匹配问题 3.5 结论 第4章 动态
SQL
第5章 视图 第6章 用户定义函数 第7章 存储过程 第8章
触发器
第9章 事务 第10章 错误处理 第11章 Service Broker 附录A CLR程序指南 A.1 创建CLRUtilities数据库:
SQL
Server
A.2 部署:Visual Studio A.3 部署和测试:Visual Studio 和
SQL
Server
索引
中
英文术语对照表
SQL
Server
中
触发器
的简单
使用
示例
1、定义
触发器
CREATE TRIGGER <
触发器
名> ON <表名> FOR|AFTER|INSTEAD OF <触发事件> AS <触发动作体> 注: AFTER表示只有执行了指定的操作(DELETE,UPDATE,INSERT)之后,
触发器
才被激活,执行
触发器
中
的
sql
语句; FOR表示为AFTER
触发器
,并且该触发...
my
sql
查看
触发器
定义_
SQL
Server
查看
触发器
定义
在本教程
中
,将学习查看
SQL
Server
触发器
定义的各种方法。1. 通过从系统视图查询获取
触发器
定义可以通过查询sys.
sql
_modules视图
中
的数据来获取
触发器
的定义:SELECTdefinitionFROMsys.
sql
_modulesWHEREobject_id = OBJECT_ID('sales.trg_members_delete');执行上面查询语句,得到以下结果:在此查询
中
,...
sql
server
用
触发器
取另外一台电脑的my
sql
数据_
SQL
Server
如何创建
触发器
实现一张表数据更新时,同步增加、删除、修改另一张表的数据。...
一、
触发器
知识点摘要:实际应用
中
,我们经常会遇到在对
SQL
Server
的某一张表进行增加、删除、修改操作时,需同步更新同一数据库或不同数据库的另一张表,此时我们可以
使用
SQL
Server
的表
触发器
来实现。
使用
触发器
时,我们会用到
触发器
的两个临时虚拟表:Deleted表、Inserted表,它们用于存储【创建
触发器
表】的记录变动信息,即发生触发事件时对应的【一条旧记录】和【一条新记录】,各触发...
MS-SQL Server
34,873
社区成员
254,640
社区内容
发帖
与我相关
我的任务
MS-SQL Server
MS-SQL Server相关内容讨论专区
复制链接
扫一扫
分享
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章