首页 > 数据库 > mysql教程 > 用Trigger规范insert, update的值._MySQL

用Trigger规范insert, update的值._MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-06-01 14:01:57
原创
990 人浏览过

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

即做了两次操作。。。

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

相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
表格内部的表单
来自于 1970-01-01 08:00:00
0
0
0
数据表
来自于 1970-01-01 08:00:00
0
0
0
php - mysql 表字段问题
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板