CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
IBM Rational 系统开发最佳实践工具包 WebSphere MQ 最佳实践 TOP 15
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  MS-SQL Server >  基础类

主键约束问题

楼主panjinfu80(天蓝水晶)2006-03-07 12:31:27 在 MS-SQL Server / 基础类 提问

我在触发器里有先INSERT   INTO   A表,然而A表上有主键约束,当然会中断插入数据,弹出主楗约束信息,会不会中止触发器?INSERT下面还有一堆程序,还能执行吗?如果能让它执行,该如何做的?(有主键约束时跳过不插入数据,执行下面程序) 问题点数:50、回复次数:6Top

1 楼wgsasd311(自强不息)回复于 2006-03-07 12:39:25 得分 20

我在触发器里有先INSERT   INTO   A表,然而A表上有主键约束,当然会中断插入数据,弹出主楗约束信息,会不会中止触发器?INSERT下面还有一堆程序,还能执行吗?  
  ==>当触发器(for类型)中代码执行报错,会回滚此次触发的操作(INSERT   ,UPDATE   ,DELETE).  
  如果能让它执行,该如何做的?(有主键约束时跳过不插入数据,执行下面程序)  
  ==>  
  CREATE   TRIGGER   TI_TB   ON   TB   FOR   INSERT  
  AS  
  IF   not   EXISTS(select   1   from   ta   where   主键='你插入的主键值')  
  insert   into   ta  
  ....  
   
  goTop

2 楼panjinfu80(天蓝水晶)回复于 2006-03-07 12:49:11 得分 0

IF   not   EXISTS(select   1   from   ta   where   主键='你插入的主键值')  
  如果表中有大量数据时这个查询很慢的,就因为用这样的语句,触发器执行很慢的。  
  IF   not   EXISTS(select   *   from   ta   where   主键='你插入的主键值')两个语句有什么区别?那个速度快?Top

3 楼panjinfu80(天蓝水晶)回复于 2006-03-08 21:10:52 得分 0

??Top

4 楼ReViSion(和尚)回复于 2006-03-08 23:45:19 得分 20

IF   not   EXISTS(select   1   from   ta   where   主键='你插入的主键值')  
  如果表中有大量数据时这个查询很慢的,就因为用这样的语句,触发器执行很慢的。  
  IF   not   EXISTS(select   *   from   ta   where   主键='你插入的主键值')两个语句有什么区别?那个速度快?  
   
  --------------------------------------------------------------  
  显然是上面要快的多,理由嘛,用看的  
  执行计划上很明显Top

5 楼panjinfu80(天蓝水晶)回复于 2006-03-12 23:17:34 得分 0

!Top

6 楼aniude(重返荣耀)回复于 2006-03-12 23:59:27 得分 10

1   返回一个列,*返回N个列,你说呢?Top

相关问题

  • 关于主键外键的约束问题
  • 对主键,外键和约束都没什么概念啊?
  • 带有外键约束的主表为啥不能truncate?
  • 怎么用sql语句为表增加一个主键约束
  • .net下 如何处理主键约束错误
  • 列与现存的主键或UNIQUE约束不匹配
  • 关于外键约束。
  • 外键约束问题
  • 关于外键约束
  • 外键约束问题

关键词

  • 执行
  • 语句
  • 数据
  • 触发器
  • 插入
  • 主键值
  • 很慢
  • 主键约束
  • a表
  • 程序

得分解答快速导航

  • 帖主:panjinfu80
  • wgsasd311
  • ReViSion
  • aniude

相关链接

  • SQL Server类图书

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo