位置: 编程技术 - 正文

MySQL 建表的优化策略 小结(mysql建表的完整步骤)

编辑:rootadmin
目录 1. 字符集的选择 1 2. 主键 1 3. 外键 2 4. 索引 2 4.1. 以下情况适合于创建索引 2 4.2. 以下的情况下不适合创建索引 3 4.3. 联合索引 3 4.4. 索引长度 4 5. 特殊字段 4 5.1. 冗余字段 4 5.2. 分割字段 4 5.3. BLOB和CLOB 5 6. 特殊 5 6.1. 表格分割 5 6.2. 使用非事务表类型 5 1. 字符集的选择 如果确认全部是中文,不会使用多语言以及中文无法表示的字符,那么GBK是首选。 采用UTF-8编码会占用3个字节,而GBK只需要2个字节。 2. 主键 尽可能使用长度短的主键 系统的自增类型AUTO_INCREMEN, 而不是使用类似uuid()等类型。如果可以使用外键做主键,则更好。比如1:1的关系,使用主表的id作为从表的主键。 主键的字段长度需要根据需要指定。 tinyint 从 2的7次方-1 :- 到 smallint 从 2的次方-1 :- 到 mediumint 表示为 2的次方-1: 从 - 到 int 表示为 2的次方-1 bigint 表示为 2的次方-1 在主键上无需建单独的索引,因为系统内部为主键建立了聚簇索引。 允许在其它索引上包含主键列。 3. 外键 外键会影响插入和更新性能,对于批量可靠数据的插入,建议先屏蔽外键检查。 对于数据量大的表,建议去掉外键,改由应用程序进行数据完整性检查。 尽可能用选用对应主表的主键作作为外键,避免选择长度很大的主表唯一键作为外键。 外键是默认加上索引的 4. 索引 创建索引,要在适当的表,适当的列创建适当数量的适当索引。在查询优先和更新优先之间做平衡。 4.1. 以下情况适合于创建索引 在经常需要搜索的列上,可以加快搜索的速度 在作为主键的列上,强制该列的唯一性和组织表中数据的排列结构 在经常用在连接的列上,这些列主要是一些外键,可以加快连接的速度 在经常需要根据范围进行搜索的列上创建索引,因为索引已经排序,其指定的范围是连续的 在经常需要排序的列上创建索引,因为索引已经排序,这样查询可以利用索引的排序,加快排序查询时间 在经常使用在WHERE子句中的列上面创建索引,加快条件的判断速度。 4.2. 以下的情况下不适合创建索引 对于那些在查询中很少使用或者参考的列不应该创建索引。这是因为,既然这些列很少使用到,因此有索引或者无索引,并不能提高查询速度。相反,由于增加了索引,反而降低了系统的维护速度和增大了空间需求。 对于那些只有很少数据值的列也不应该增加索引。这是因为,由于这些列的取值很少,例如人事表的性别列,在查询的结果中,结果集的数据行占了表中数据行的很大比例,即需要在表中搜索的数据行的比例很大。增加索引,并不能明显加快检索速度。 对于那些定义为text, image和bit数据类型的列不应该增加索引。这是因为,这些列的数据量要么相当大,要么取值很少。 当修改性能远远大于检索性能时,不应该创建索引。这是因为,修改性能和检索性能是互相矛盾的。 如果表数据很少,比如每个省按市做汇总的表,一般低于,且数据量基本没有变化。此时增加索引无助于查询性能,却会极大的影响更新性能。 当增加索引时,会提高检索性能,但是会降低修改性能。当减少索引时,会提高修改性能,降低检索性能。因此,当对修改性能的要求远远大于检索性能时,不应该创建索引。 4.3. 联合索引 在特定查询里,联合索引的效果高于多个单一索引,因为当有多个索引可以使用时,MySQL只能使用其中一个。 在查询里,同时用到了联合索引包含的前几个列名,都会使用到联合索引,否则将部分或不会用到。比如我们有一个firstname、 lastname、age列上的多列索引,我们称这个索引为fname_lname_age。当搜索条件是以下各种列的组合时,MySQL将使用 fname_lname_age索引: firstname,lastname,age firstname,lastname firstname 从另一方面理解,它相当于我们创建了(firstname,lastname,age)、(firstname,lastname)以及(firstname)这些列组合上的索引。 4.4. 索引长度 对于CHAR或者Varchar的列,索引可以根据数据的分布情况,用列的一部分参与创建索引。 create index idx_t_main on t_main(name(3)); 这里就是指定name的前三个字符参与索引,而不是全部 最大允许的长度为个字节,对已GBK编码则是个汉字 5. 特殊字段 5.1. 冗余字段 就是用空间换取时间。如果大表查询里经常要join某个基础表,且这个数据基本不变,比如人的姓名,城市的名字等。一旦基础表发生变动,则需要更新所有涉及到的冗余表。 5.2. 分割字段 如果经常出现以某个字段的某个局部进行检索和汇总(substring()),可以考虑将这一部分独立出来。 比如统计姓名里,每种姓氏的人数,可以考虑实现就按照姓和名分别保存,而不是一个字段。 还有就是某些上下级结构的实现,也可以考虑将不同的级别放在不同的字段里。 5.3. BLOB和CLOB 此类字段一般数据量很大,建议设计上数据库可以只保存其外部连接,而数据以其它方式保存,比如系统文件。 6. 特殊 6.1. 表格分割 如果一个表有许多的列,但平时参与查询和汇总的列却并不是很多,此时可以考虑将表格拆分成2个表,一个是常用的字段,另一个是很少用到的字段。 6.2. 使用非事务表类型 MySQL支持多种表类型,其中InnoDB类型是支持事物的,而MyISAM类型是不支持的,但MyISAM速度更快。对于某些数据,比如地理行政划分,民族等不可能参与事务的数据,可以考虑用MyISAM类型的表格。 但InnoDB的表,将无法用MyISAM表数据做外键约束了。 MyISAM表参与的事务,其InnoDB表可以正常的提交和回滚,但不影响MyISAM表。

推荐整理分享MySQL 建表的优化策略 小结(mysql建表的完整步骤),希望有所帮助,仅作参考,欢迎阅读内容。

MySQL 建表的优化策略 小结(mysql建表的完整步骤)

文章相关热门搜索词:mysql建表问题,mysql建表的完整步骤,mysql建表问题,mysql优化表结构,mysql建表问题,mysql 建表语句 及完整案例,mysql优化表结构,mysql建表问题,内容如对您有帮助,希望把文章链接给更多的朋友!

批量替换 MySQL 指定字段中的字符串 批量替换的具体语法是:UPDATE表名SET指定字段=replace(指定字段,'要替换的字符串','想要的字符串')WHERE条件;如果你想把article表中ID小于的记录,content

mysql4.0升级到mysql5(4.1),解决字符集问题 1、从4.0中导出表mysqldump?no-data-uroot-pdatabasestruct.sql2、导出数据mysqldump?no-create-info=true?extended-insert=false-uroot-pdatabasedata.sql3、用vi编辑struct.sql,使用最末行

MySQL 随机密码生成代码 DELIMITER$$CREATEFUNCTION`t_girl`.`func_rand_string`(f_numtinyintunsigned,f_typetinyintunsigned)RETURNSvarchar()BEGIN--Translatethenumbertoletter.--No1standsforstringonly.--No2standsfornumberonly.--

标签: mysql建表的完整步骤

本文链接地址:https://www.jiuchutong.com/biancheng/312507.html 转载请保留说明!

上一篇:mysql 发生系统错误1067的解决方法(MySQL发生系统错误2和5)

下一篇:批量替换 MySQL 指定字段中的字符串(批量替换多个word文档的同一内容)

  • 集体房屋出租管理办法
  • 公司注册实缴资金能取出吗
  • 物业公司代收电费怎么开票
  • 暂估收入的必要条件
  • 金税盘地区编号淄博
  • 新会计准则中资产减值论文
  • 企业所得税年报错了怎么更正
  • 旅行社支付导游费怎么算
  • 案例分析建筑业差额征税如何进行账务处理?
  • 一般纳税人小型微利企业印花税
  • 待认证税额是几级科目
  • 基建人员工资计入哪个科目
  • 非企业单位有税收吗
  • 存货占比小有什么影响
  • 开发票冲销
  • 车辆完税证明怎么弄
  • 小程序交易需要什么条件
  • 进货折让会计分录
  • 公司食堂支出计入什么科目
  • 游乐场门票收入发票品目
  • 产值和营业收入差距大
  • 其他应收账款怎么算
  • 技术开发免征增值税怎么开票
  • 职工福利费的会计科目是什么
  • os x yosemite dp5下载地址 os x 10.10 dp5更新内容
  • scvc8.exe是什么
  • php零基础入门
  • 普通发票主营业务怎么填
  • 落枕怎么办怎么治疗
  • framework怎么用
  • 出口免抵增值税是什么意思
  • 交易性金融资产公允价值变动计入
  • 塔河流域
  • php的运算符主要包括哪些?
  • 缴纳社保的时候工资填写多少
  • 二元运算例子
  • 前端es2020
  • 保险公司发票能在异开吗
  • 电汇收款的会计分录
  • 收到快递赔款分录怎么做
  • python byte数组
  • Windows上PostgreSQL安装配置教程
  • 还款利息
  • 购买的优惠卷到期后退款
  • 销售收入未及时入账
  • 社保缴费基数怎么算
  • 制造费用账户在月末一般没有余额
  • 研发支出的费用化支出计入
  • 资本公积怎么计提
  • 企业未开票收入怎么入账
  • 预支差旅费怎么记账
  • 企业召开会议的目的
  • 联营企业子公司是否构成关联方
  • 辅助生产成本如何结转
  • sqlserver的基本语句
  • win10系统回收站在哪
  • win7禁用administrator登录
  • windows虚拟内存设置
  • xp系统改win7系统设置
  • 怎么删除windows7
  • redhat无法启动
  • win7怎么修改开始菜单样式
  • win10系统中断怎么解除
  • win10电脑补丁 kb5000802
  • win10系统怎么添加ip地址
  • Jquery Ajax Error 调试错误的技巧
  • angular.js
  • 激发灵感的三种方式是什么
  • js时间比较大小的方法
  • python的pip安装命令
  • vue路由跳转的钩子函数什么时候会用到
  • windows、linux
  • ubuntu修改默认桌面环境
  • js引用传递
  • js页面点击怎么随机生成图片
  • javascript tab切换
  • genymotion-unable to load virtualbox engine
  • 地址变更去税务局办理
  • 衡阳地税局的地理位置
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设