热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MySQL触发器统计子表数量

关键词MySQL触发器统计摘要本文介绍MySQL使用触发器来统计关联的子表的记录条数。zaho_account表是账户总表,zaho_tihuo_code是关联的子表。在zaho_

关键词
MySQL 触发器 统计

摘要

本文介绍MySQL使用触发器来统计关联的子表的记录条数。

zaho_account表是账户总表,zaho_tihuo_code是关联的子表。在zaho_account表中有一个字段:a_code_used,表示该账号下有多少条code记录。

触发器代码如下:

— 插入
DELIMITER //

DROP TRIGGER IF EXISTS `tihuo_code_insert`;
CREATE TRIGGER `tihuo_code_insert` AFTER INSERT ON `zaho_tihuo_code`
FOR EACH ROW BEGIN
UPDATE `zaho_account` SET a_code_used=a_code_used+1 WHERE a_id=NEW.account_id;
END//

— 删除
DELIMITER //

DROP TRIGGER IF EXISTS `tihuo_code_delete`;
CREATE TRIGGER `tihuo_code_delete` AFTER DELETE ON `zaho_tihuo_code`
FOR EACH ROW BEGIN
UPDATE `zaho_account` SET a_code_used=a_code_used-1 WHERE a_id=OLD.account_id;
END//

— 附赠一个把历史数据更新到a_code_used字段的SQL
UPDATE zaho_account a SET a_code_used=(select count(1) from zaho_tihuo_code where account_id=a.a_id)
关于MySQL触发器统计子表数量,本文就介绍这么多,希望对您有所帮助!



推荐阅读
author-avatar
NOYOKI要跑偏
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有