当前位置: 首页 > 图文教程 > 网络编程 > PHP > php discuz 主题表和回帖表的设计

PHP
PHP程序员的优化调试技术和技巧
PHP实现简单线性回归之数学库的重要性
用PHP读取和编写XML DOM
PHP实现简单线性回归之数据研究工具
在PHP中开发XML应用程序之基础篇
PHP加密文本文件并限制特定页面的存取
PHP强制对象类型之instanceof操作符
通过PHP和Sajax使用Ajax之JavaScript
WAP与PHP程序设计之基础篇
PHP5 OOP编程之代理与定制异常
PHP5 OOP编程中的代理与异常定制
PHP+MySQL应用中使用XOR运算加密算法
使用PHP和AJAX的XML编程
利用PHP+JavaScript打造AJAX搜索窗
结合AJAX进行PHP开发之入门
结合AJAX的PHP开发之后退、前进和刷新
用PHP控制您的浏览器cache
五个常见 PHP 数据库问题
深入探讨PHP中的内存管理问题
用PHP构建一个简易监视引擎

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-12   浏览: 147 ::
收藏到网摘: n/a

看看网上优秀程序的源码,分析优缺点,快速提高我们的水平。 以下内容仅摘录部分:
如果由我们来设计主题表和回帖表,通常的做法是如下。

这样在获取主题列表时,直接使用分页算法提取Topics;查看某一帖子时,还需要对Topics,Posts进行jion链接。
此种设计的缺陷为:
1. Topics表存储Content的内容,其体积将会很大,对大体积表进行分页,性能很慢。
2. 显示Posts内容时将进行join操作,损耗性能
而Discuz的做法是进行如下设计。

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