php discuz 主题表和回帖表的设计

 更新时间:2009年03月13日 00:14:07   作者:  
看看网上优秀程序的源码,分析优缺点,快速提高我们的水平。
以下内容仅摘录部分:
如果由我们来设计主题表和回帖表,通常的做法是如下。

       这样在获取主题列表时,直接使用分页算法提取Topics;查看某一帖子时,还需要对Topics,Posts进行jion链接。

此种设计的缺陷为:
1. Topics表存储Content的内容,其体积将会很大,对大体积表进行分页,性能很慢。
2. 显示Posts内容时将进行join操作,损耗性能

而Discuz的做法是进行如下设计。

       将Topics里的Content拆分到Posts中去,同时Topics的主题帖也作为回帖放置到Posts里面,这样就解决了上面我们提出的两个问题。这是典型的违反数据库设计范式以换取更好性能的示例。

相关文章

  • Godaddy空间Zend Optimizer升级方法

    Godaddy空间Zend Optimizer升级方法

    虽然购买了godaddy的空间,期间也遇到很多的问题,在慢慢的额摸索中,也有的一些解决的方法。
    2010-05-05
  • 10条PHP高级技巧[修正版]

    10条PHP高级技巧[修正版]

    10条PHP高级技巧,让你提高php效率。
    2011-08-08
  • 如何从防护角度看Thinkphp历史漏洞

    如何从防护角度看Thinkphp历史漏洞

    19年初,网上公开了2个Thinkphp5的RCE漏洞,漏洞非常好用,导致有很多攻击者用扫描器进行全网扫描。我们通过ips设备持续观察到大量利用这几个漏洞进行批量getshell的攻击流量,本文主要从流量角度简要分析和利用thinkphp进行攻击的全网扫描和getshell流量痕迹。
    2021-05-05
  • php addslashes及其他清除空格的方法是不安全的

    php addslashes及其他清除空格的方法是不安全的

    清除空格的方法是不安全的,部分原因是因为字符中的空格非常多,例如 addslashes的问题在 于黑客 可以用0xbf27来代替单引号
    2012-01-01
  • PHP实现的MD5结合RSA签名算法实例

    PHP实现的MD5结合RSA签名算法实例

    这篇文章主要介绍了PHP实现的MD5结合RSA签名算法,结合实例形式分析了php使用md5结合RSA实现的签名算法相关操作技巧,并附带了RSA公钥与私钥的相关说明,需要的朋友可以参考下
    2017-10-10
  • 用缓存实现静态页面的测试

    用缓存实现静态页面的测试

    用缓存实现静态页面的测试...
    2006-12-12
  • Swoole实现异步投递task任务案例详解

    Swoole实现异步投递task任务案例详解

    这篇文章主要介绍了Swoole实现异步投递task任务案例,结合实例形式详细分析了Swoole异步投递task任务的原理、实现方法及操作注意事项,需要的朋友可以参考下
    2019-04-04
  • PHP实现的支付宝支付功能示例

    PHP实现的支付宝支付功能示例

    这篇文章主要介绍了PHP实现的支付宝支付功能,结合实例形式分析了php使用支付宝接口实现支付功能相关操作技巧,需要的朋友可以参考下
    2019-03-03
  • 解析thinkphp中的导入文件标签

    解析thinkphp中的导入文件标签

    本篇文章是对thinkphp中的导入文件标签进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • PHP实现的折半查询算法示例

    PHP实现的折半查询算法示例

    这篇文章主要介绍了PHP实现的折半查询算法,结合完整实例形式分析了php使用递归与非递归实现折半查询的算法操作步骤与使用方法,需要的朋友可以参考下
    2017-10-10

最新评论