位置: 编程技术 - 正文

mysql数据库常见的优化操作总结(经验分享)(MySQL数据库常见的几种约束有哪些)

编辑:rootadmin

推荐整理分享mysql数据库常见的优化操作总结(经验分享)(MySQL数据库常见的几种约束有哪些),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql 数据库有哪些常用的数据类型?,MySQL数据库常见的约束有哪些作用,MySQL数据库常见的几种约束有哪些,mysql数据库有哪几种,MySQL数据库常见的约束有哪些作用,MySQL数据库常见的几种约束有哪些,mysql数据库常见问题,mysql数据库常见问题,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

对于一个以数据为中心的应用,数据库的好坏直接影响到程序的性能,因此数据库性能至关重要。所以mysql数据库的优化操作大家都要有所了解,本文就主要总结了mysql数据库中常见的优化操作,下面话不多说了,来看看详细的介绍吧。

一、Index索引

将Index放第一位,不用说,这种优化方式我们一直都在悄悄使用,那便是主键索引。有时候我们可能并不在意,如果定义适合的索引,数据库查询性能(速度)将提高几倍甚至几十倍。

普通索引

作用是提高查询速度。

建表,创建索引

创建索引

删除索引

查看索引

主键索引

作用是加速查询和唯一约束

建表,创建索引

创建索引

删除索引

唯一索引

作用是加速查询和唯一约束

建表,创建索引

创建索引

删除索引

二、少用SELECT*

可能有的人查询数据库时,遇到要查询的都会select,这是不恰当的行为。我们应该取我们要用的数据,而不是全取,因为当我们select时,会增加web服务器的负担,增加网络传输的负载,查询速度自然就下降 。

三、EXPLAIN SELECT

mysql数据库常见的优化操作总结(经验分享)(MySQL数据库常见的几种约束有哪些)

对于这个功能估计很多人都没见过,但是这里强烈推荐使用。explain显示了mysql如何使用索引来处理select语句以及连接表。可以帮助选择更好的索引和写出更优化的查询语句。主要用发就是在select前加上explain即可。

四、开启查询缓存

大多数的MySQL服务器都开启了查询缓存。这是提高性最有效的方法之一,而且这是被MySQL的数据库引擎处理的。当有很多相同的查询被执行了多次的时候,这些查询结果会被放到一个缓存中,这样,后续的相同的查询就不用操作表而直接访问缓存结果了。

第一步把query_cache_type设置为ON,然后查询系统变量have_query_cache是否可用:

之后,分配内存大小给查询缓存,控制缓存查询结果的最大值。相关操作在配置文件中进行修改。

五、使用NOT NULL

很多表都包含可为 NULL (空值) 的列,即使应用程序井不需要保存 NULL 也是如此 ,这是因为可为 NULL 是列的默认属性。通常情况下最好指定列为 NOT NULL,除非真 的需要存储 NULL 值。

如果查询中包含可为 NULL 的列,对 MySQL 来说更难优化 ,因为可为 NULL 的列使 得索引、索引统计和值比较都更复杂 。可为NULL 的列会使用更多的存储空间 ,在 MySQL 里也需要特殊处理 。当可为NULL 的列被索引肘,每个索引记录需要一个额 外的字节,在 MyISAM 里甚至还可能导致固定大小 的索引 (例如只有一个整数列的 索引) 变成可变大小的索引。

通常把可为 NULL 的列改为 NOT NULL 带来的性能提升比较小 ,所以 (调优时) 没有 必要首先在现有schema中查找井修改掉这种情况 ,除非确定这会导致问题。但是, 如果计划在列上建索引 ,就应该尽量避免设计成可为 NULL 的列。当然也有例外 ,例如值得一提的是,InnoDB 使用单独的位 (bit ) 存储 NULL 值 ,所 以对于稀疏数据由有很好的空间效率 。但这一点不适用于MyISAM 。

六、存储引擎的选择

对于如何选择MyISAM和InnoDB,如果你需要事务处理或是外键,那么InnoDB可能是比较好的方式。如果你需要全文索引,那么通常来说MyISAM是好的选择,因为这是系统内建的,然而,我们其实并不会经常地去测试两百万行记录。所以,就算是慢一点,我们可以通过使用Sphinx从InnoDB中获得全文索引。

数据的大小,是一个影响你选择什么样存储引擎的重要因素,大尺寸的数据集趋向于选择InnoDB方式,因为其支持事务处理和故障恢复。数据库的在小决定了故障恢复的时间长短,InnoDB可以利用事务日志进行数据恢复,这会比较快。而MyISAM可能会需要

几个小时甚至几天来干这些事,InnoDB只需要几分钟。

您操作数据库表的习惯可能也会是一个对性能影响很大的因素。比如: COUNT() 在 MyISAM表中会非常快,而在InnoDB表下可能会很痛苦。而主键查询则在InnoDB下会相当相当的快,但需要小心的是如果我们的主键太长了也会导致性能问题。大批的inserts语句在MyISAM下会快一些,但是updates在InnoDB 下会更快一些——尤其在并发量大的时候。

所以,到底你检使用哪一个呢?根据经验来看,如果是一些小型的应用或项目,那么MyISAM也许会更适合。当然,在大型的环境下使用MyISAM也会有很大成功的时候,但却不总是这样的。如果你正在计划使用一个超大数据量的项目,而且需要事务处理或外键支持,那么你真的应该直接使用InnoDB方式。但需要记住InnoDB的表需要更多的内存和存储,转换GB的MyISAM 表到InnoDB 表可能会让你有非常坏的体验。

七、避免在 where 子句中使用 or 来连接

如果一个字段有索引,一个字段没有索引,将导致引擎放弃使用索引而进行全表扫描,如:

可以这样查询:

八、多使用varchar/nvarchar

使用varchar/nvarchar代替 char/nchar ,因为首先变长字段存储空间小,可以节省存储空间,其次对于查询来说,在一个相对较小的字段内搜索效率显然要高些。

九、避免大数据量返回

这里要考虑使用limit,来限制返回的数据量,如果每次返回大量自己不需要的数据,也会降低查询速度。

十、where子句优化

where 子句中使用参数,会导致全表扫描,因为SQL只有在运行时才会解析局部变量,但优化程序不能将访问计划的选择推迟到运行时;它必须在编译时进行选择。然 而,如果在编译时建立访问计划,变量的值还是未知的,因而无法作为索引选择的输入项。

应尽量避免在 where 子句中对字段进行表达式操作,避免在where子句中对字段进行函数操作这将导致引擎放弃使用索引而进行全表扫描。不要在 where 子句中的“=”左边进行函数、算术运算或其他表达式运算,否则系统将可能无法正确使用索引。

总结

标签: MySQL数据库常见的几种约束有哪些

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

上一篇:Mysql中Join的使用实例详解(mysql join实现原理)

下一篇:详解Mysql中的视图(mysql数据库视频)

  • 城市维护建设税计算公式
  • 应纳税额减征额包括哪些内容
  • 应收留抵税额退税款属于哪类科目
  • 电子承兑凭证
  • 工会经费如何申报?
  • 出纳个人账户转公户
  • 金蝶未结账是否可以重新起账
  • 进销存明细账怎么填写
  • 广告策划费会计分录
  • 有发票无明细能报销吗
  • 建筑行业未收款先开发票如何做账?
  • 提取法定盈余公积比例
  • 企业销售矿产是否需要缴纳资源税呢?
  • 体检合同属于什么合同
  • 酒店怎么缴纳增值税费用
  • 应计入增值税一般纳税人认定标准的“年应税销售额”
  • 商业企业成本核算内容包括
  • 房地产企业闲置土地怎么处理
  • 生产企业的免抵退纳税申报,在财务做销售收入账务后
  • 委托代销商品账簿模板
  • 移动网速测试软件
  • 呆账催讨原则是谁提出的
  • 核定征收没有收入要交税吗
  • php怎么把图片存入mysql
  • 邮件远程控制
  • 银行存款的明细科目怎么写
  • 增值税发票怎么抵税
  • php生成php文件
  • 其他业务成本的意思
  • 专票认证后可以不抵扣吗
  • 代垫运费算收入吗
  • 关系抽取系统的要求
  • 层层剖析的近义词
  • php 微信公众号自定义菜单
  • 小轿车折旧年限
  • 增值税普通发票需要交税吗
  • 股东分红缴税期限
  • php判断useragent
  • 投资进来的钱怎么取出来
  • 企业为员工承担个人部分的五险 一金可以税前扣除?
  • 金税四期介绍 王军
  • 工程服务费税率是多少2023
  • 收到加油
  • 营改增行业销售额的确定
  • 职工薪酬纳税调整明细表税收金额
  • 滴滴打车老板起源故事
  • 会计事务所给的发票
  • 会计处理的相关知识点
  • 实收资本可以做现金吗
  • 支付的劳务派遣服务费计入什么科目
  • 预计负债 负债 区别
  • 2019年新政府会计准则解读
  • 固定资产确认条件最新
  • 给法人交社保,不发工资可以吗
  • 预付购买设备款
  • 跨年冲红发票账务处理需要调整申报表吗
  • 账簿按账页格式排序
  • mybatis特殊字符查询出来编码了
  • ubuntu 手动安装
  • win8.1电脑设置在哪里
  • ubuntu系统安装程序
  • Win7 64位操作系统怎么使用DVD刻录光驱复制软件
  • myfastupdate.exe - myfastupdate是什么进程文件 有什么用
  • win8系统远程桌面在哪里
  • Win10 Mobile RedStone 14283已修复与已知问题汇总
  • 游戏开发之二维码怎么弄
  • Android: Receiving Data from the Send Intent,将自己的app注册系统分享
  • opengl learn
  • windows 10一
  • python内置函数什么用来返回序列中的最大元素
  • js字符串编码解码
  • javascript怎么设置字体大小
  • android系统虚拟机
  • 人事科负责人是否必须是党员?
  • 江苏省发票查询电话
  • 拆迁补偿的房子是什么性质
  • 银行缴纳印花税存在问题和建议
  • 税务风险管理指引
  • 土地增值税扣除项目金额怎么计算
  • 法治税务示范基地枫桥
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设