位置: 编程技术 - 正文

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

  • 湖南省增值税发票图片
  • 小规模纳税人印花税怎样计算
  • 印花税应交税费
  • 收到股东投资款怎么做账
  • 固定资产盘盈影响所有者权益吗
  • 企业所得税多缴退税规定
  • 简易计税开的发票可以抵扣吗
  • 残保金退回属于什么业务
  • 个体户每个月开10万会查吗
  • 小规模能开劳务费吗
  • 没有及时取得发票可以入成本么
  • 两笔不同业务能做一个凭证吗
  • 公司支付倒垃圾费怎么做会计分录
  • 企业购进材料的会计分录
  • 免税农产品转出进项税税率
  • 税负率的计算公式excel
  • 如何区分纳税人和小规模纳税人
  • 购入增值税税控系统专用设备为什么全额计入固定资产
  • 技术服务费怎么开票
  • 发票拍照打印出来不清晰
  • 小微企业增值税减免政策
  • 投资性房地产的后续计量从成本模式转为公允价值模式的
  • 个税起征点是
  • win10新建文件夹快捷键ctrl加什么
  • 企业生产过程中的一个安全问题必须
  • 委外加工费用会计分录
  • 如何安装电脑系统程序
  • php中strstr
  • 代垫运费会计分录怎么写
  • php使用内置函数的过程
  • windows未能正常启动
  • php改编码
  • php零基础入门
  • 短期投资取得的收益
  • 今天中秋节
  • vue3props用法
  • 生产型企业出口退税计算案例
  • 最优化模型的优点
  • 发票复核和收款人未填写
  • 20年电赛c题
  • 收购企业如何看报表
  • 金税盘减免税款借方余额
  • 弃置费用预计负债的摊余成本
  • 收到一分钱的红包表情包
  • 出资比例不等于100%
  • phpipam使用
  • vue使用高德地图闪白屏
  • 企业所得税太高怎么合理规避
  • 科技型中小微企业贷款贴息贴保项目入库
  • 政府补助的范围
  • 到期无法收回的银行承兑汇票计入什么科目
  • 年底做账流程
  • 哪些支出可以在出国公杂费中扣除
  • 汇算清缴退税分录
  • 商业劳务费是什么意思
  • 一季度存款
  • 发票冲红的会计怎么处理
  • 应收账款记账凭证怎么写
  • 应付票据贴现借款
  • 注册资本实缴后钱怎么出来
  • 材料暂估分录
  • 坏账准备转回是什么意思
  • 工业企业增值税纳税义务发生时间
  • sqlserver怎么用
  • xp系统安装版如何安装
  • ubuntu支持软件
  • 设置u盘为只读
  • putty怎么连接linux
  • 看视频出现弹幕怎么处理
  • linux用root登录
  • nodejs 异步
  • Android 让EditText失去焦点避免自动弹出输入法
  • 用nodejs做的项目
  • threejs入门教程
  • 发票代码如何查询公司
  • 湖北税务报税系统官网
  • 地税是什么税种
  • 关于公司纳税
  • 每个省几个市
  • 代理记账公司有什么风险吗?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设