读书频道 > 网站 > 网页设计 > MySQL入门很简单
18.3.1 将字段很多的表分解成多个表
12-07-31    叶孤城
收藏    我要投稿   

本文所属图书 > MySQL入门很简单

本书从初学者的角度出发,由浅入深,循序渐进地介绍了MySQL数据库应用与开发的相关知识。书中提供了大量操作MySQL数据库的示例,还提供了大量实例和上机实践内容,供读者演练。本书共分5篇。第1篇介绍数据库的基...立即去当当网订购
18.3  优化数据库结构
 
数据库结构是否合理,需要考虑是否存在冗余、对表的查询和更新的速度、表中字段的数据类型是否合理等多方面的内容。本节将为读者介绍优化数据库结构的方法。
 
18.3.1  将字段很多的表分解成多个表
 
有些表在设计时设置了很多的字段。这个表中有些字段的使用频率很低。当这个表的数据量很大时,查询数据的速度就会很慢。本小节将为读者介绍优化这种表的方法。
 
对于这种字段特别多且有些字段的使用频率很低的表,可以将其分解成多个表。
 
【示例18-6】 下面的学生表中有很多字段,其中在extra字段中存储着学生的备注信息。有些备注信息的内容特别多。但是,备注信息很少使用。这样就可以分解出另外一个表。将这个取名叫student_extra。表中存储两个字段,分别为id和extra。其中,id字段为学生的学号,extra字段存储备注信息。student_extra表的结构如下:
 
mysql> DESC student_extra ; 
+-------+-----------+--------+-------+--------------+---------+ 
| Field | Type   | Null  | Key  | Default   | Extra | 
+-------+-----------+--------+-------+--------------+---------+ 
| id    | int(11) | NO   | PRI  | NULL    |       | 
| extra | text    | YES  |     | NULL    |       | 
+-------+-----------+--------+-------+--------------+---------+ 
2 rows in set (0.00 sec)
如果需要查询某个学生的备注信息,可以用学号(id)来查询。如果需要将学生的学籍信息与备注信息同时显示时,可以将student表和student_extra表进行联表查询,查询语句如下:
 
SELECT * FROM student, student_extra WHERE
student.id=student_extra.id ;
通过这种分解,可以提高student表的查询效率。因此,遇到这种字段很多,而且有些字段使用不频繁的,可以通过这种分解的方式来优化数据库的性能。
点击复制链接 与好友分享!回本站首页
分享到: 更多
您对本文章有什么意见或着疑问吗?请到论坛讨论您的关注和建议是我们前行的参考和动力  
上一篇:1.3 功能
下一篇:1.5 小结
相关文章
图文推荐
JavaScript网页动画设
1.9 响应式
1.8 登陆页式
1.7 主题式
排行
热门
文章
下载
读书

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训
版权所有: 红黑联盟--致力于做最好的IT技术学习网站