十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
增加一条学生记录时,会自动检查年龄是否符合范围要求。每当删除一条学生信息时,自动删除其成绩表上的对应记录。
站在用户的角度思考问题,与客户深入沟通,找到博白网站设计与博白网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:做网站、网站制作、企业官网、英文网站、手机端网站、网站推广、域名与空间、虚拟空间、企业邮箱。业务覆盖博白地区。
触发器是与表有关的数据库对象,指在insert/updateldelete之前或之后,触发并执行触发器中定义的SQL语句集合。
创建两个表,目的是在一个表里删除一条记录,另一个表也删除一条记录。
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
-- ----------------------------
-- Table structure for `rules`
-- ----------------------------
DROP TABLE IF EXISTS `rules`;
CREATE TABLE `rules` (
`id` smallint(6) NOT NULL AUTO_INCREMENT,
`pid` smallint(6) DEFAULT '0',
`std` varchar(50) DEFAULT NULL,
`status` smallint(6) DEFAULT '1',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of rules
-- ----------------------------
INSERT INTO `rules` VALUES ('1', '0', 'A', '1');
INSERT INTO `rules` VALUES ('2', '1', 'B', '1');
INSERT INTO `rules` VALUES ('3', '2', 'C',
mysql用触发器禁止某条记录的删除、修改:
delimiter //
CREATE TRIGGER xx_company_agent_update BEFORE UPDATE ON xx_company_agent
FOR EACH ROW
BEGIN
IF OLD.bank_card is not null THEN
SET NEW.bank_card = OLD.bank_card,NEW.money= OLD.money,NEW.real_money=OLD.real_money,NEW.bank_name=OLD.bank_name;
END IF;
END;//
delimiter ;
扩展资料
mysql触发器的使用
用户记录用户的预期事件(schema是特殊用户的数据库对象集合。这些对象包括:表,索引,视图,存储程序等。在Oracle里, schema要求创建一个用户。但是也可以创建一个没有schema的用户(根本没有对象)。
所以在Oracle-中,用户就是一个帐户而schema就是对象。可能在其他的数据库平台上可以创建一个没有用户的schema。LOGOFF不能是AFTER LOGOFF,将会重新操作,这里应该是BEFORE,否则就会报错:替换可以插入不能有AFTER。创建或替换触发器MYLOGOFFTRIGGER。
参考资料来源:百度百科—mySQL
修改:alter trigger trigger_name on table_name
删除: drop trigger trigger_name
你的数据库访问层是不是用Hibernate的?如果是Hibernate的话,可以再hbm.xml文件里设置cascade=“delete”就可以进行级联操作了。
如果不是Hibernate,而是用JdBC的话,且使用触发器的话,就要按照MySQL的触发器的编写规范来写了,你的这个触发器像是Oracle的。