用Trigger规范iert, update的值_SQL SERVER数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

用Trigger规范iert, update的值

作者:黑客防线网安SQL维护基地 来源:黑客防线网安SQL维护基地 浏览次数:0

本篇关键词:sql数据库sql教程
黑客防线网安网讯:假设有表 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, Reta...

假设有表 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 行受影响)

即做了两次操作。。。

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

    黑客防线网安服务器维护方案本篇连接:http://www.rongsen.com.cn/show-10330-1.html
网站维护教程更新时间:2012-03-21 02:32:21  【打印此页】  【关闭
我要申请本站N点 | 黑客防线官网 |  
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479

footer  footer  footer  footer