位置: 编程技术 - 正文

Sql Server触发器的使用(sql server触发器实验)

编辑:rootadmin
Sql Server为每个触发器都创建了两个专用表:Inserted表和Deleted表。这两个表由系统来维护,它们存在于内存中而不是数据库中。这两个表的结构总是与被该触发器作用的表的结构相同,触发器执行完成后,与该触发器相关的这两个表也被删除。

推荐整理分享Sql Server触发器的使用(sql server触发器实验),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql server触发器创建,sql server触发器的创建和使用,sqlserver触发器语法,sql server触发器的作用,sql server触发器在哪里?,sql server触发器的创建和使用,sql server触发器主要针对下列语句创建,sql server触发器的编写与使用,内容如对您有帮助,希望把文章链接给更多的朋友!

对表的操作

Inserted逻辑表

Deleted逻辑表

增加记录(insert)

存放增加的记录

Sql Server触发器的使用(sql server触发器实验)

删除记录(delete)

存放被删除的记录

修改记录(update)

存放更新后的记录

存放更新前的记录

三、for、after、instead of触发器

after:触发器在触发它们的语句完成后执行。如果该语句因错误而失败,触发器将不会执行。不能为视图指定after触发器,只能为表指定该触发器。可以为每个触发操作(insert、update、delete)指定多个after触发器。如果表有多个after触发器,可使用sp_settriggerorder定义哪个after触发器最先激发,哪个最后激发。除第一个和最后一个触发器外,所有其他的after触发器的激发顺序不确定,并且无法控制。

for:等同于after

instead of:该触发器代替触发操作执行。可在表和视图上指定instead of触发器。只能为每个触发操作(insert、update、delete)定义一个instead of触发器。instead of触发器可用于对insert和update语句中提供的数据值执行增强的完整性检查。

四、 触发器的使用

1、创建触发器:

create trigger trigger_name

on {table_name | view_name}

{for| After | Instead of }

[ insert, update,delete ]

as

sql_statement

2、删除触发器:

drop trigger trigger_name

3、查看数据库中已有的触发器:

select * from sysobjects where xtype='TR'

4、查看单个触发器:

exec sp_helptext '触发器名'

5、修改触发器:

alter trigger trigger_name

on {table_name | view_name}

{for| After | Instead of }

[ insert, update,delete ]

as

sql_statement

五、触发器的实例

1、在Orders表中建立触发器,当向Orders表中插入一条记录时,检查goods表的货品状态status是否为1。是,则不能往Orders表加入该订单。

if (object_id('tgr_orders_insert', 'tr') is not null) drop trigger [tgr_orders_insert];gocreate trigger [tgr_orders_insert]on [orders]after insertas if (select [status] from [goods],[inserted] where [goods].name=[inserted].name)=1begin print 'the goods is being processed' print 'the order cannot be committed' rollback transaction --回滚?避免加入

end

sqlldr装载数据实现代码 这里用excel数据做个最简单的测试。1)把excel数据存为t.txt文件,注意文件后缀名为.txt1jhchen//::--:jhchen//::--:jhchen

sql server字符串非空判断实现方法 CREATEfunctiongetcolor(@井号varchar(),@层位varchar())returnsvarchar()asbegindeclare@sqlvarchar();set@sql=''--distinctselect@sql=@sql+颜色+','from(selectdistinct颜色fromyourtablename

使用xp_cmdshell注销Windows登录用户(终端服务器超出最大连接数) 公司日常项目更新使用TFP,服务器一般维护用远程桌面管理,所以经常登录到服务器,但有时由于某种原因,登录到服务器后,帐号没有及时注销,致使后面无

标签: sql server触发器实验

本文链接地址:https://www.jiuchutong.com/biancheng/348136.html 转载请保留说明!

上一篇:jdbc连接sql server数据库问题分析(jdbc连接sqlserver数据库查询数据画饼图)

下一篇:sqlldr装载数据实现代码(sql*loader-309)

  • 增值税销项进项什么意思
  • 基础设施道路建设
  • 营业执照注销对商标有影响吗
  • 签三方协议需要什么资料
  • 形式发票需要签字盖章吗
  • 企业法人网上可以注销吗
  • 增值税专用发票和普通发票的区别
  • 其他应收款有哪些情况
  • 私募合伙企业收到投资款后退回,支付利息的会计处理
  • 员工离职补偿需要计提吗
  • 递延收益为什么是非流动负债
  • 注册商标怎么做账
  • 复利现值和复利终值的计算
  • 认购私募股权基金
  • 银行手续费要纳进去吗
  • 科目余额表期初借贷一定要相等吗
  • 公司收生育津贴怎么入账
  • 发票最大限额999元,超过了怎么办
  • 计提本月工资记账凭证怎么填
  • 合同资产减值准备对应科目
  • 出口企业免抵增值税
  • 建安企业结转成本如何计算
  • 销售折让发票如何处理?
  • 结转出租设备的会计分录
  • 何为民办非企业
  • 旅游开发企业会计账务处理
  • 无法连接到移动网络小米
  • 备份计算机需要多久
  • win10点击网络属性没反应
  • win7系统修改
  • php伪静态规则写法
  • 车辆赔偿款收条怎么写
  • 借方为什么是减少额?
  • 怎么启用framework3.5
  • laravel自带队列效率
  • thinkphp try catch
  • 贝尔纳贝
  • 非货币性资产投资的会计处理
  • 彩钢板房税点
  • python如何合并字典
  • 买轿车产生的服务费用
  • 生产企业出口转内销增值税申报表怎么填
  • 外来原始凭证审核内容
  • 应收账款收不回来做坏账处理分录
  • sql递减
  • 航空运输电子客票行程单查验
  • 开普票需要公对公吗
  • 金税四期上线企业还活吗
  • 营业执照办理税务登记需要什么资料
  • 以前年度损益调整结转到哪里
  • 劳务公司账务处理实例
  • 什么情况填an
  • 投资折价会计处理
  • 暂估成本的账务怎么处理
  • 小规模收入不超过多少不用交税
  • 个人如何进行股票交易
  • mac电脑连wifi总是断开
  • 彻底关闭windows10自动更新工具
  • win7系统IE浏览器一点就闪退
  • mac与windows的使用区别
  • win7系统本身会占用多少空间
  • linux怎么禁用用户
  • Win10计算机管理该文件没有与之关联的应用
  • vsftpd 配置限制用户目录
  • 两台没联网的电脑怎么创建局域网
  • bat命令详解
  • k mean python
  • 如何使用jquery插件
  • jquery移动div到另一个div中
  • 浅谈如何培养孩子的注意力
  • 举例详解民法典第502条
  • 用python发邮件
  • html css js 实战案例
  • unity3d基础教程
  • python如何入门
  • 重大税务违法案件一案双查标准
  • 税务编号是什么 个人
  • 个人所得税网上报税流程
  • 浙江省网上税务局总分机构变更流程
  • 车辆报废补贴怎么拿
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设