当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 用Trigger规范insert, update的值

MSSQL
SQL Server中选出指定范围行的SQL语句写法
Microsoft SQL Server 2000安装问题集锦
修改SQL Server 2005 sa用户密码的方法
SQL Server数据库查询优化的常用方法总结
两种与SQL Server数据库交换数据的方法
Sun正式发布MySQL 5.1版 简化数据库应用
使用SQL Server 2008中对象相关性
SQL注入防御:用三种策略应对SQL注入攻击
SQL Server 2005 SP3正式版
MySQL数据库中使用GRANT语句增添新用户
讲解数据库加密技术的功能特性与实现方法
如何在SQL Server数据库中加密数据
30步检查SQL Server安全列表
在SQL Server数据库开发中的十大问题
向外扩展SQL Server 实现更高扩展性
SQL Server 2005 五个动态管理对象
从算法入手讲解SQL Server的典型示例
如何解决SQLServer占内存过多的问题
SQL指令植入式攻击的危害及其防范措施
SQL游标原理和使用方法

MSSQL 中的 用Trigger规范insert, update的值


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-30   浏览: 573 ::
收藏到网摘: n/a

假设有表 A,

CREATE TABLE A(

ID INT NOT NULL IDENTITY(1,1),

ProductID INT NOT NULL,

RetailerID INT NOT NULL,

Date DATETIME NOT NULL

 

CONSTRAINT A_PK PRIMARY KEY (ProductID, RetailerID, Date)

);

我的意思是想让 ProductID, RetailerID 和 Date(不包括小时,分钟等)成为主键。

即:某一天里, retailerID 和 ProductID 是唯一的。

SQLServer 里,DateTime 是可以存储 小时、分钟等的,如果程序只有我自己写,我会规范输入的日期,让其只包含日期部分。但要是直接改数据库,就只有通过触发器来规范了。

 

Oracle 和 MySQL 的触发器都有两个对象: NEW 和 OLD ,但 SQLServer 没有,SQLServer 有 INSTERED 和 DELETED 这两个逻辑表,具体可参考SQLServer 的帮助。

在Oracle 和 MySQL 里,只要用:

NEW.FieldName = XXX;

就可以更改 INSERT 或UPDATE 的值了,在SQLServer 里,目前,我只知道用 UPDATE, 用着很不方便:

CREATE TRIGGER A_T ON A FOR INSERT, UPDATE AS

BEGIN

UPDATE A

SET Date = SUBSTRING(CONVERT(VARCHAR, I.Date ,20),1,10)

FROM INSERTED I

WHERE I.ID = A.ID

END;

好了,INSERT 一条试试:

INSERT INTO A (ProductID, RetailerID, Date) VALUES (1,2,'2009-11-16 12:57:43');

可以看到:

(1 行受影响)

(1 行受影响)

即做了两次操作。。。

不知道还有没有其它方法没有。