用Trigger规范insert,update的值._MySQL
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了用Trigger规范insert,update的值._MySQL,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1157字,纯文字阅读大概需要2分钟。
内容图文
假设有表 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 行受影响)
即做了两次操作。。。
不知道还有没有其它方法没有。
内容总结
以上是互联网集市为您收集整理的用Trigger规范insert,update的值._MySQL全部内容,希望文章能够帮你解决用Trigger规范insert,update的值._MySQL所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。