数据库设计与优化.doc_第1页
数据库设计与优化.doc_第2页
数据库设计与优化.doc_第3页
数据库设计与优化.doc_第4页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

数据库设计与优化1.char(2) = tinyint(2) UNSIGNED ZEROFILL 如:category_id、number172.char(3) = tinyint(3) UNSIGNED ZEROFILL 如:game_(1)= tinyint(1) UNSIGNED4.字符型变长改定长 1)config_misc中 type varchar(4) NOT NULL COMMENT 功能类型, 修改为:type char(4) 2)member和sys_user中 password varchar(32)改为char(32)5.member_order_hash表1)version_number int(11) NOT NULL DEFAULT 0 COMMENT 版本号改为:version_number mediumint(8) UNSIGNED注:MEDIUMINT(M) UNSIGNED ZEROFILL中等大小的整数。带符号的范围是-8388608到8388607。无符号的范围是0到16777215。2)order_time int(11) NOT NULL DEFAULT 0 COMMENT 注单时间,时间戳, 改为 order_time timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP 3)去除字段:order_hash_value char(32) NOT NULL DEFAULT COMMENT 注单信息的HASH值 ,6.物理临时表换成内存临时表 在创建临时表时,使用TEMPORARY关键词。只有在当前连接情况下,TEMPORARY表才是可见的。当连接关闭时,TEMPORARY表被自动取消。这意味着两个不同的连接可以使用相同的临时表名称,同时两个临时表不会互相冲突,也不与原有的同名的非临时表冲突。(原有的表被隐藏,直到临时表被取消时为止。)您必须拥有CREATE TEMPORARY TABLES权限,才能创建临时表。7.关于非中文字符列的字符集设置 例:category_name varchar(64) character set latin1 collate latin1_general_ci NOT NULL comment 玩法类别名称 将非中文字符列的字符集设置为 latin1,可以节省存储空间8.session表改成redis存储,统计在线人数时有性能优势,也可缓解DB压力 taiwan9.将history表、副本表使用表分区合并。/doc/refman/5.1/zh/partitioning.html涉及的表:member_share_sum_20110809order_20110809order_detail_20110809short_covering_corp_20110809short_covering_user_20110809user_discount_20110809user_share_sum_20110809LIST分区MySQL中的LIST分区在很多方面类似于RANGE分区。和按照RANGE分区一样,每个分区必须明确定义。它们的主要区别在于,LIST分区中每个分区的定义和选择是基于某列的值从属于一个值列表集中的一个值,而RANGE分区是从属于一个连续区间值的集合。LIST分区通过使用“PARTITION BY LIST(expr)”来实现,其中“expr” 是某列值或一个基于某个列值、并返回一个整数值的表达式,然后通过“VALUES IN (value_list)”的方式来定义每个分区,其中“value_list”是一个通过逗号分隔的整数列表。5.待讨论:关于MySql里的字段:/s/blog_3f56d7800100bj34.html 1)decimal(15,5) 换成整型存储,提高效率。如12345678.55555,存储为1234567855555,在PHP中处理:1234567855555/10000; 2)datetime换成timestamp/62575/280284-1、TIMESTAMP列必须有默认值,默认值可以为“0000-00-00 00:00:00”,但不能为null。2、TIMESTAMP列不可以设置值,只能由数据库自动去修改。3、一个表可以存在多个TIMESTAMP列,但只有一个列会根据数据更新而改变为数据库系统当前值。因此,一个表中有多个TIMESTAMP列是没有意义,实际上一个表只设定一个TIMESTAMP列。4、TIMESTAMP列的默认值是CURRENT_TIMESTAMP常量值。当纪录数据发生变化的时候,TIMESTAMP列会自动将其值设定为CURRENT_TIMESTAMP。5、TIMESTAMP列创建后的格式是:a timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,这个语句含义,a字段的默认值是CURRENT_TIMESTAMP,当纪录更新时候,自动将a字段的值设置为CURRENT_TIMESTAMP。6、另外,下面的定义从语法角度是对的,但是没有意义,因为该字段的值不可更改,永远只能为默认值。b timestamp NOT NULL DEFAULT 0000-00-00 00:00:00,-ALTER TABLE tbl1 CHANGE update_time update_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP =/blog/static/318196972011230113645715/储存TIMESTAMP1.4个字节储存(Time stamp value is stored in 4 bytes)2.值以UTC格式保存( it stores the number of milliseconds)3.时区转化 ,存储时对当前的时区进行转换,检索时再转换回当前的时区。datetime1.8个字节储存(8 bytes storage)2.实际格式储存(Just stores what you have stored and retrieves the same thing which you have stored.)3.与时区无关(It has nothing to deal with the TIMEZONE and Conversion.)=order表一、删除字段:1.loss_result2.deal_start_time3.win_count二、变长字段居末大事务拆分成两

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论