多版面论坛数据库表结构优化设计的讨论_PHP教程
近一直在脑子里构思一个全新的论坛。想与大家讨论一下“多版面论坛数据库表结构的优化设计”问题。
问题的提出:
作为一个综合性的论坛,必然会遇到论坛分类的问题。常见的单层次多版面的结构太简单了点,在分类的问题上力不从心,无法实现比较复杂的分类。而像phorum那样的多层次多版面的结构固然能够实现任意复杂的分类(可以实现无限层次的目录分类结构),但是存在的难题就是导航不直观也不方便。所以我觉得,目前网上常见的双层多版面的结构是比较合理的,基本上满足了综合性论坛分类的要求,又能比较方便地实现直观、方便的论坛导航界面,例子有www.chinaasp.com目前的论坛。这种结构有两层目录,上面一层是大类,下面一层是分类,即具体的论坛版面。如何利用数据库的表来比较高效地实现这种结构呢?
方案一:
不管论坛将来有多少个版面,都把所有的帖子存放到一个表中,这个表中记录一个帖子的所有信息和该帖子所属的小类ID号码,假设这个表称为T_articles,用表T_columns1纪录大类信息(大类名和该大类的ID号码),用表T_columns2纪录小类信息(小类名、小类ID号码和该小类所属的大类ID号码)
方案二:
给每一个小类新建一个表,把属于该类的帖子都存放到这个表中,这个表中仅纪录一个帖子的自身信息(主题、正文等),此类表都用T_articles1、T_articles2等表示。用表T_columns1纪录大类信息(大类名和该大类的ID号码),用表T_columns2纪录小类信息(小类名、小类ID号码和改小类所属的大类ID号码)
要求:
1、要求无论大类小类都便于将来的扩充;
2、要求设计出来的表结构能提高数据库检索效率;
比较:
方案一与方案二哪一种好一些?
大家不妨来讨论一下?
转载“江南论坛”中一位朋友的回复
cach 于 2001-1-18 23:51:59 加贴在 编程大本营
方案一比较好扩充版面,但是不足的是随着贴子的增多,数据量会越来越大,
做一次查询会比较费时间,而且万一数据表出了问题就麻烦了。
不过好处是编程要容易的多。现在很多论坛都是用这个方案的!
而方案二相比来说会速度快些,不过编程时可能要多费一些时间!
我觉得方案二中还应该加一些内容,就是T_columns2中加上一个字段,用来
放新建的小类的表名(因为方案二是一个讨论区建一个表的,这些表因该都是
动态添加的,所以有必要加一个字段存放表名,到时可以通过这个字段做参数
来生成相应的讨论区),优点是速度快,一个讨论区的表出了问题并不影响
其它的讨论区,所以我还是觉得方案二更好些!
以上是个人观点!
版权声明: 本帖版权归提交者cach所有,其它网站转载或转贴须注明出处,传统媒体转载
须事先与原作者和江西热线联系,本帖提交者发言纯属个人意见,与本网站立场无关。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

7月12日消息,荣耀MagicV3系列今日正式发布,搭载全新荣耀视力舒缓绿洲护眼屏,在屏幕本身具备高规格和高素质的同时,还开创性的引入AI主动式护眼技术。据悉,传统的缓解近视的方式是“近视镜”,近视眼镜度数均匀分布,保证了视线中心区域成像在视网膜之上,但周边区域成像在视网膜后,视网膜感应到成像在后,促进眼轴向后生长,从而使度数加深。目前主要的缓解近视发展的方式之一是“离焦镜”,其中心区域度数正常,周边区域通过光学设计分区调整,从而使周边区域成像落在视网膜前,

7月29日消息,荣耀X60i手机今日正式开售,首发1399元。设计上,荣耀X60i手机采用居中挖孔直屏设计,四边近乎无界的超窄边框,极大地拓宽了视野边界。荣耀X60i参数显示屏:6.7英寸高清显示屏电池:5000mAh大容量电池处理器:天玑6080处理器(台积电6nm,2x2.4G的A76+6×2G的A55)系统:MagicOS8.0系统其他功能:5G信号增强灵动胶囊屏下指纹双MIC降噪知识问答摄影能力:后置双摄系统:5000万像素主摄200万像素辅助镜头前置自拍镜头:800万像素价格:8GB

5月13日消息,vivoX100s今晚正式发布,除了出色的影像,新机在信号方面表现也十分强悍。据vivo官方介绍,vivoX100s采用了创新的寰宇信号放大系统,该系统配备了高达21根天线。这一设计基于直屏进行了重新优化,以平衡5G、4G、Wi-Fi、GPS以及NFC等众多信号需求。这使得vivoX100s成为了vivo有史以来信号接收能力最强的手机。新款手机还采用了独特的360°环绕设计,天线分布在机身周围。这一设计不仅增强了信号的强度,还针对日常各种握持姿势进行了优化,避免了因握持方式不当导

时间复杂度衡量算法执行时间与输入规模的关系。降低C++程序时间复杂度的技巧包括:选择合适的容器(如vector、list)以优化数据存储和管理。利用高效算法(如快速排序)以减少计算时间。消除多重运算以减少重复计算。利用条件分支以避免不必要的计算。通过使用更快的算法(如二分搜索)来优化线性搜索。

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

7月19日消息,小米MIXFold4首旗舰折叠新机今晚正式发布,首次搭载“立体异形电池”。据介绍,小米MIXFold4在电池技术上实现了重大突破,专为折叠屏设计了创新的“立体异形电池”。传统折叠屏设备多采用常规方形电池,空间利用效率较低。为解决这一问题,小米没有采用常见的卷绕式电芯,而是全新开发叠片工艺,打造全新形态的电池,大幅提升了空间利用率。电池技术创新为了实现精确交替堆叠正负极片,确保锂离子安全嵌入,小米开发了新型超声焊接机和叠片机,提高了焊接和裁切精

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())
