知识大全 详解MySQL数据库提升性能的八种方法[2]
Posted 索引
篇首语:只会幻想而不行动的人,永远也体会不到收获果实时的喜悦。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 详解MySQL数据库提升性能的八种方法[2]相关的知识,希望对你有一定的参考价值。
详解MySQL数据库提升性能的八种方法[2] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
使用外键
锁定表的方法可以维护数据的完整性 但是它却不能保证数据的关联性 这个时候我们就可以使用外键 例如 外键可以保证每一条销售记录都指向某一个存在的客户 在这里 外键可以把customerinfo 表中的CustomerID映射到salesinfo表中CustomerID 任何一条没有合法CustomerID的记录都不会被更新或插入到salesinfo中
CREATE TABLE customerinfo(CustomerID INT NOT NULL PRIMARY KEY ( CustomerID )) TYPE = INNODB;CREATE TABLE salesinfo(SalesID INT NOT NULL CustomerID INT NOT NULL PRIMARY KEY(CustomerID SalesID) FOREIGN KEY (CustomerID) REFERENCES customerinfo(CustomerID) ON DELETECASCADE) TYPE = INNODB;
注意例子中的参数 ON DELETE CASCADE 该参数保证当 customerinfo 表中的一条客户记录被删除的时候 salesinfo 表中所有与该客户相关的记录也会被自动删除 如果要在 MySQL 中使用外键 一定要记住在创建表的时候将表的类型定义为事务安全表 InnoDB类型 该类型不是 MySQL 表的默认类型 定义的方法是在 CREATE TABLE 语句中加上 TYPE=INNODB 如例中所示
使用索引
索引是提高数据库性能的常用方法 它可以令数据库服务器以比没有索引快得多的速度检索特定的行 尤其是在查询语句当中包含有MAX() MIN()和ORDERBY这些命令的时候 性能提高更为明显 那该对哪些字段建立索引呢?一般说来 索引应建立在那些将用于JOIN WHERE判断和ORDER BY排序的字段上 尽量不要对数据库中某个含有大量重复的值的字段建立索引 对于一个ENUM类型的字段来说 出现大量重复值是很有可能的情况 例如customerinfo中的 province 字段 在这样的字段上建立索引将不会有什么帮助;相反 还有可能降低数据库的性能
我们在创建表的时候可以同时创建合适的索引 也可以使用ALTER TABLE或CREATE INDEX在以后创建索引 此外 MySQL从版本 开始支持全文索引和搜索 全文索引在MySQL 中是一个FULLTEXT类型索引 但仅能用于MyISAM 类型的表 对于一个大的数据库 将数据装载到一个没有FULLTEXT索引的表中 然后再使用ALTER TABLE或CREATE INDEX创建索引 将是非常快的 但如果将数据装载到一个已经有FULLTEXT索引的表中 执行过程将会非常慢
优化的查询语句
绝大多数情况下 使用索引可以提高查询的速度 但如果SQL语句使用不恰当的话 索引将无法发挥它应有的作用 下面是应该注意的几个方面 首先 最好是在相同类型的字段间进行比较的操作 在MySQL 版之前 这甚至是一个必须的条件 例如不能将一个建有索引的INT字段和BIGINT字段进行比较;但是作为特殊的情况 在CHAR类型的字段和VARCHAR类型字段的字段大小相同的时候 可以将它们进行比较 其次 在建有索引的字段上尽量不要使用函数进行操作
例如 在一个DATE类型的字段上使用YEAE()函数时 将会使索引不能发挥应有的作用 所以 下面的两个查询虽然返回的结果一样 但后者要比前者快得多
SELECT * FROM order WHERE YEAR(OrderDate)< ;SELECT * FROM order WHERE OrderDate< ;同样的情形也会发生在对数值型字段进行计算的时候 SELECT * FROM inventory WHERE Amount/ < ;SELECT * FROM inventory WHERE Amount< * ;上面的两个查询也是返回相同的结果 但后面的查询将比前面的一个快很多 第三 在搜索字符型字段时 我们有时会使用 LIKE 关键字和通配符 这种做法虽然简单 但却也是以牺牲系统性能为代价的 例如下面的查询将会比较表中的每一条记录
SELECT * FROM booksWHERE name like MySQL%但是如果换用下面的查询 返回的结果一样 但速度就要快上很多
SELECT * FROM booksWHERE name>= MySQL and name< MySQM最后 应该注意避免在查询中让MySQL进行自动类型转换 因为转换过程也会使索引变得不起作用
cha138/Article/program/MySQL/201311/29646相关参考
量价理论的八种关系研究表明:成交量几乎总是先于股价,成交量为股价的先行指标。在量价理论里,成交量与股价趋势的关系可归纳为以下八种:1、量(成交量)涨价(股价)涨,即所谓的有价有市。2、量涨价涨,股价创
在动态网站的设计中数据库设计的重要性不言而喻如果设计不当查询起来就非常吃力程序的性能也会受到影响无论你使用的是MySQL或者Oracle数据库通过进行正规化的表格设计可以令你的PHP代码更具可读性更容
一、爆发性流行病:⑴发病季节。2-11月,以5-9月为甚。⑵症状。轻症:上下颌、口腔、鳃盖、眼睛鳍基及鱼体两侧轻度充血;重症:鱼体表严重充血,以至出血,眼球突出,腹部膨大,肛门红肿。⑶防治措施。平均水
一、爆发性流行病:⑴发病季节。2-11月,以5-9月为甚。⑵症状。轻症:上下颌、口腔、鳃盖、眼睛鳍基及鱼体两侧轻度充血;重症:鱼体表严重充血,以至出血,眼球突出,腹部膨大,肛门红肿。⑶防治措施。平均水
MySQL数据库线程缓冲池详解 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! MySQL数据库线
1.水温过高。过高的水温会影响鱼类生长,如青、草、鲢、鳙、鲤、鲫等鱼最适宜生长的水温为23℃~28℃,罗非鱼在25℃~35℃时生长最快。因此,夏季若水温超过鱼类生长适宜温度时,要采取降温措施。 2.
1.水温过高。过高的水温会影响鱼类生长,如青、草、鲢、鳙、鲤、鲫等鱼最适宜生长的水温为23℃~28℃,罗非鱼在25℃~35℃时生长最快。因此,夏季若水温超过鱼类生长适宜温度时,要采取降温措施。 2.
MySQL数据库存储引擎详解 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 存储引擎是什么?
一、爆发性流行病:⑴发病季节。2-11月,以5-9月为甚。⑵症状。轻症:上下颌、口腔、鳃盖、眼睛鳍基及鱼体两侧轻度充血;重症:鱼体表严重充血,以至出血,眼球突出,腹部膨大,肛门红肿。⑶防治措施。平均水
一、爆发性流行病:⑴发病季节。2-11月,以5-9月为甚。⑵症状。轻症:上下颌、口腔、鳃盖、眼睛鳍基及鱼体两侧轻度充血;重症:鱼体表严重充血,以至出血,眼球突出,腹部膨大,肛门红肿。⑶防治措施。平均水