位置: 编程技术 - 正文

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文档的同一内容)

  • 增值税认证发票平台可以导出发票明细吗?
  • 补缴以前年度附加税如何入账
  • 企业为自然人什么意思
  • 企业转出多交增值税吗
  • 发票系统口令锁定
  • 生产性资金是生产资料吗
  • 财务费用属于什么科目借贷方向
  • 工资单上的retro
  • 收票据计息利息为什么要红字冲账?
  • 销售使用过未抵扣进项税额的货运汽车
  • 个人独资企业服务中心是干嘛的
  • 原材料呆滞物料处理方法
  • 委托加工产品月末结转成本
  • 计提业务招待费和办公费需要附件吗?
  • 药企常见税务风险及措施
  • 在境外施工由国家承担吗
  • 固定资产提前报废
  • 最新消费税税目顺口溜
  • 财产清查中固定资产盘亏
  • 抵扣发票勾选到哪个科目
  • 向关联企业借款债资比
  • 企业非独立法人是什么意思
  • 结转电费成本会计分录
  • 竣工决算调整入库流程
  • 进口货物完税价格名词解释
  • 租房税收缴款书在哪里打印
  • 账套没有以前年度调整
  • 商誉减值会计准则
  • 反避税的意义
  • 以前年度原材料调出怎么做会计分录
  • wind10画图在哪
  • PHP:getallheaders()的用法_Apache函数
  • 如何获取openai api
  • linux子网掩码自动变成24
  • 应付职工薪酬账户期末余额可能是
  • 补收入的会计分录
  • 缴纳房产税需要扣除折旧吗
  • pytorch自动编码器
  • 怎么调试vue项目
  • 刚刚学完小车可以学摩托车吗
  • 数据挖掘技术介绍
  • php 验证类
  • php虚拟主机
  • 企业购买的土地出买后无法收回资金属国有资产流失吗?
  • 递延所得税什么时候交
  • 涉税金额是指金额还是税额
  • mysql临时表什么时候销毁
  • 零税率与免税有何区别
  • 个税跨月更正申报怎么做
  • 跨年银行回单怎么入账
  • 伙食堂是什么意思
  • 对公账户转账给法人怎么做账
  • 小规模纳税人残保金减免政策
  • 去年管理费用多支三万元怎么办
  • 哪些工资属于社会福利
  • 新准则委托代建会计处理
  • 数据库更新数据
  • 5分钟了解环保币gec
  • cf游戏初始化失败是因为什么
  • win7桌面和win10桌面
  • debian系统如何安装软件
  • linux 删除重复文件
  • xp系统如何清除所有盘的东西
  • windows 7的用户类型
  • win8怎么一开机就进入桌面
  • 安装win8.1一直卡着不动
  • 64位Win7环境下vs2013配置opengl
  • opengl教程48讲
  • parentElement,srcElement的使用小结
  • 批处理截取字符串
  • jquery 图片预览
  • vue list清空
  • jquery仿淘宝商品详情页
  • 基于python的
  • android PopupWindow显示位置设置
  • 什么是城建税的纳税义务人
  • 发票专用章和公章编码一样吗
  • 小规模纳税人销售额怎么算
  • 如何理解新时代新征程党的使命任务
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设