首页 / MYSQL / MySQL计数器表的设计
MySQL计数器表的设计
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL计数器表的设计,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1711字,纯文字阅读大概需要3分钟。
内容图文
TABLE hit_counter( cnt int unsigned not null ) ENGINE=InnoDB;网站的每次点击都会导致对计数器的更新:
UPDATE hit_counter SET cnt = cnt + 1;
那么问题出现了,对于任何想要更新这一行的事务来说,这条记录上都有全局的互斥锁。这会使得这些事务只能串行执行。要活的跟高的冰法更新性能,我们可以这样解决:
将技术其保存在多行中,每次随机选择一行进行更新,这样需要对计数器表作如下修改:
CREATE TABLE hit_counter( slot tinyint unsigned not null primary key, cnt int unsigned not null ) ENGINE = InnoDB;
然后在这张数据表中增加100条数据。现在选择一个随机的槽(slot)进行更新:
UPDATE hit_counter SET cnt = cnt + 1 where slot = RAND() * 100;
要获得统计结果,使用具和函数sum()进行查询:
SELECT SUM( cnt ) FROM hit_counter;
但是还有一种常见的需求是每隔一段时间开始一个新的计数器(如每天一个)。想要实现这个,我们继续修改计数器表啊:
CREATE TABLE daily_hit_counter( day date not null, slot tinyint unsigned not null, cnt int unsigned not null, primary( day , slot ) ) ENGINE=InnoDB;
在这个场景里,可以不用像前面那样,预先生成行,而是用 ON DUPLICATE KEY UPDATE代替:
INSERT INTO daily_hit_counter( day , slot , cnt ) values( CURRENT_DATE , RAND() * 100 , 1 ) ON DUPLICATE KEY UPDATE cnt = cnt + 1;
如果希望减少表的行数,以避免表变得太大,可以写一个周期执行的任务,合并所有结果到0号槽,并且删除所有其他的槽:
UPDATE daily_hit_counter as c INNER JION( SEKECT day , SUM( cnt ) AS cnt , MIN( slot ) AS mslot FROM daily_hit_counter GROUP BY day ) AS x USING( day ) SET c.cnt = IF( c.slot = x.mslot , x.cnt , 0 ), c.slot = IF( c.slot = x.mslot , 0 , c.slot );
DELETE FROM daily_hit_counter WHERE slot <> 0 AND cnt = 0;
MySQL计数器表的设计
标签:
本文系统来源:http://www.cnblogs.com/phpcoder/p/4665850.html
内容总结
以上是互联网集市为您收集整理的MySQL计数器表的设计全部内容,希望文章能够帮你解决MySQL计数器表的设计所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。