mysql垂直拆分数据表

php中文网
发布: 2016-09-15 11:30:59
原创
1296人浏览过

在开发过程中,我遇见这么一个问题:在数据库中有一张文章表,用以保存文章的相关信息(如:标题、内容、作者、创作时间、收藏数等),还有另外一张表用以保存用户和文章的收藏关系(主要字段有:用户id、文章id),在有初次查看该文章时从数据库获取到文章数据后会将数据缓存到redis中,由此提高性能。
但现在因为每次收藏或取消收藏文章时都会更新文章表的收藏数这一字段,并且都会清空该文章的缓存(之所以选择清空而不是更新缓存,是为了避免产生脏数据),下次访问该文章时又会查询数据库并缓存数据,因此会对性能造成一定影响!

因此我决定将文章表的收藏数拆分出来新建一张文章收藏数表(主要字段有:主键id,文章ID,收藏数),并且缓存文章数据时将收藏数分开缓存,这样,每次收藏或取消收藏文章时文章表不用更新,只更新文章收藏数表,更新文章收藏数表后,直接更新缓存(这儿之所以不怕产生脏数据是因为收藏数不是特别重要的数据,就算有一定误差也不会造成恶劣影响)。

来画数字人直播
来画数字人直播

来画数字人自动化直播,无需请真人主播,即可实现24小时直播,无缝衔接各大直播平台。

来画数字人直播 0
查看详情 来画数字人直播

使用以上方案,由此产生两个疑问,希望得到大家的解答:

  1. 因为文章收藏数中主键ID和文章ID两个字段都是唯一不重复的字段,是否可以不要主键ID字段,直接将文章ID当做主键?

  2. 因为如果每次新增一条文章数据时没有同步新增一条对应文章ID的文章收藏数数据,那么每次收藏与取消收藏文章时更新文章收藏数,都会需要先查询文章收藏数表中是否已经存在对应文章ID的收藏数,如果没有就新增一条文章收藏数数据,如果有就直接更新该文章的收藏数,所以,为了简便,我决定每次新增一条文章数据时都同步新增一条对应文章ID的文章收藏数数据,以后更新文章收藏数时就不需要先判断数据是否存在,而可以直接更新数据,在这种情况下,要怎么避免新增文章数据和新增文章收藏数数据之间出现异常导致新增文章数据成功而新增文章收藏数数据失败的情况?我知道可以使用事务来避免,可以有没有更简单的方法呢?MySQL可不可以新增一条数据的同时自动在另一张表里新增一条数据?(数据库渣~)

以上,致谢!

回复内容:

在开发过程中,我遇见这么一个问题:在数据库中有一张文章表,用以保存文章的相关信息(如:标题、内容、作者、创作时间、收藏数等),还有另外一张表用以保存用户和文章的收藏关系(主要字段有:用户id、文章id),在有初次查看该文章时从数据库获取到文章数据后会将数据缓存到redis中,由此提高性能。
但现在因为每次收藏或取消收藏文章时都会更新文章表的收藏数这一字段,并且都会清空该文章的缓存(之所以选择清空而不是更新缓存,是为了避免产生脏数据),下次访问该文章时又会查询数据库并缓存数据,因此会对性能造成一定影响!

因此我决定将文章表的收藏数拆分出来新建一张文章收藏数表(主要字段有:主键id,文章ID,收藏数),并且缓存文章数据时将收藏数分开缓存,这样,每次收藏或取消收藏文章时文章表不用更新,只更新文章收藏数表,更新文章收藏数表后,直接更新缓存(这儿之所以不怕产生脏数据是因为收藏数不是特别重要的数据,就算有一定误差也不会造成恶劣影响)。

使用以上方案,由此产生两个疑问,希望得到大家的解答:

  1. 因为文章收藏数中主键ID和文章ID两个字段都是唯一不重复的字段,是否可以不要主键ID字段,直接将文章ID当做主键?

  2. 因为如果每次新增一条文章数据时没有同步新增一条对应文章ID的文章收藏数数据,那么每次收藏与取消收藏文章时更新文章收藏数,都会需要先查询文章收藏数表中是否已经存在对应文章ID的收藏数,如果没有就新增一条文章收藏数数据,如果有就直接更新该文章的收藏数,所以,为了简便,我决定每次新增一条文章数据时都同步新增一条对应文章ID的文章收藏数数据,以后更新文章收藏数时就不需要先判断数据是否存在,而可以直接更新数据,在这种情况下,要怎么避免新增文章数据和新增文章收藏数数据之间出现异常导致新增文章数据成功而新增文章收藏数数据失败的情况?我知道可以使用事务来避免,可以有没有更简单的方法呢?MySQL可不可以新增一条数据的同时自动在另一张表里新增一条数据?(数据库渣~)

以上,致谢!

1.可以,但这里你需要做一个联动就是在增删文章的时候也要对文章收藏数表进行操作

2使用mysql的udf,详情请看MySQL :: MySQL 5.1 Reference Manual :: 22.3 Adding New Functions to MySQL 然后通过trigger在文章表deleteinsert之后进行函数的调用,写入到文章收藏数表中去。大致是这个样子。

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号