innodb表正好相反;行级锁表 互联网服务,不算支付性的服务外,互动产品,新闻系统等等一般都是读多,写少。用myisam表比较合适。 表的设计 定长表:所有列的字段长度都是定长的。可以去查mysql的手册不定长字段是VARCHAR、BLOB或TEXT。int char都是定长的,定长表占用空间会大。 动态表:就是字段不是都定长的。 定长表要比动态表检索速度快。 软件系统的设计习惯是把每张表都分清很明确的功能,比如用户表都是用户信息,如果需要同时从留言表取数据,又从用户表取用户信息的时候,就会采用联合查 询,有的时候一些操作还会用left,join等各种复杂sql语句,没准还要用mysql的函数。如果是针对访问量,读取量很大的互联网服务时,同时并 发去读,数据量又大,很可怕。最好是如果数据不会修改,在常用的表上有冗余字段,能够做到一次读,把数据都拿到;可以有冗余的写操作,但减少复杂的查询操 作。 在设计表的时候要将这个表的所有字段类型占用的字节数求和,并乘以你的预期(如:存储W数据量),就是整张表未来会占用容量。 拆表 拆库 拆表就是将一张表复制N多张,里面分别存放不用内容的数据,数据的存放是用HASH算法来决定放入哪张表。 例如用户表user,传统情况就是一张表,拆表就是将表复制为user_,user_等里面都存放了格式一样的不同用户数据。 拆库和拆表类似,就是库的复制。 拆表或拆库有很多的HASH算法,主要目的就是减少表的数据量,用算法保证每个表的数据量平均,请求,读写操作被分摊降低压力,而且安全,出了问题最多是一部分用户受影响。缺点就是检索不方便,需要另想办法。 很多网站为了前期省事都会采用discuz的产品,如bbs,blog等,网上有不少关于这个产品的介绍和优化方法,没细研究过,听过一些网站介绍他们的 优化方法时,对于数据库主要是采用主从的方法,将数据库的读写分离来提高性能,但是个人觉得这种办法在数据量到了规模的时候就OVER了,并发和读写操作 没提升,数据也是会逐渐累计超过限制。 互联网服务由于要应对大数据量,大请求量,所以在设计开发的时候就不要太学院派,不要力图达到数据库、程序的设计“优美”,性能是最要紧的。
推荐整理分享mysql 数据库设计(mysql数据库的设计与实现),希望有所帮助,仅作参考,欢迎阅读内容。
![mysql 数据库设计(mysql数据库的设计与实现)](https://www.jiuchutong.com/image/20240129/1706495048.jpg)
文章相关热门搜索词:MySQL数据库设计,MYSQL数据库设计与应用答案,MySQL数据库设计与应用,MYSQL数据库设计师招聘,MYSQL数据库设计师招聘,mysql 数据库设计范式,MySQL数据库设计,mysql数据库设计步骤,内容如对您有帮助,希望把文章链接给更多的朋友!
mysql 中文乱码 解决方法集锦 第一个方法:MySQL4.1中文乱码的问题最近要将MySQL4.0升级到MySQL4.1,发现了中文乱码的问题,希望以下见解对大家有用。1.MySQL4.1在文字上有很大改进,它
MYSQL 没有完全卸载将导致其安装不成功 如遇到MYSQL启动不了的下列情况:无论双击mysqld.exe还是使用命令行,都没反映。查看我的电脑-管理-服务与应用程序-服务-mysql-启动,得到的结果为路径
mysql 教程 存储过程 不过在网上找了一些,发现都有一个特点——就是不能传出总记录数,干脆自己研究吧。终于,算是搞出来了,效率可能不是很好,但是我也觉得不错