mysql优化 插入和查询,的优化方法

  次阅读 作者:智能小宝 来源:互联网 2016-01-27 15:49 我要评论(0)

1. 说到mysql,我们立刻想起它体积孝速度快、还开源的特点,所以它应用颇广。今天我们来总结一下mysql中最频繁的两个操作:插入和查询,的优化方法。

2.插入:

3.一、文本导入

4.使用LOAD DATA INFILE从文本下载数据这将比使用插入语句快20倍。

5.示例:

6.load data local infile 'C:/Users/DELL/Desktop/Description&Data/news1.txt' into table news (文件位置)

7.fields terminated by ',' (每一字段由 , 分隔开)

8.lines terminated by 'rn' (每一组数据由 换行符 分隔开)

9.(content,date,ip,author,subject); (解释txt中每一行由这几个字段组成)

10.二、一次插多条

11.使用带有多个VALUES列表的INSERT语句一次插入几行比使用一个单行插入语句快几倍。

12.示例:

13.INSERT INTO food VALUES

14.(NULL,'EE果冻','EE果冻厂', 1.5 ,'2007', 2 ,'北京') ,

15.(NULL,'FF咖啡','FF咖啡厂', 20 ,'2002', 5 ,'天津') ,

16.(NULL,'GG奶糖','GG奶糖', 14 ,'2003', 3 ,'广东') ; 而不是:

1.INSERT INTO food VALUES (NULL,'EE果冻','EE

果冻厂', 1.5 ,'2007', 2 ,'北京');

2.INSERT INTO food VALUES (NULL,'FF咖啡','FF

咖啡厂', 20 ,'2002', 5 ,'天津');

3.INSERT INTO food VALUES (NULL,'GG奶糖','GG

奶糖', 14 ,'2003', 3 ,'广东');

4.第一种方式减少了与数据库之间的连接等操作,所以其速度比第二种方式要快。

三、使用varchar

之所以使用varchar,而不是char,因为varchar是按实际数据的长度存储的;而char在存储完实际数据后,还把空白的空间自动补全。所以明显char插入会比varchar慢。实验说明,无论插入数据涉及的列是否建立索引,char的效率都明显低于varchar。

四、控制字段长度

这个很明显,越小的数据类型占用的空间越小,从磁盘读或打包到内存的效率都更好,但也不要太过执着减小数据类型,要是以后应用程序发生什么变化就没有空间了,所以要综合考虑决定字段长度。

五、非空+默认值

NULL对于大多数数据库都需要特殊处理,MySQL也不例外,它需要更多的代码,更多的检查和特殊的索引逻辑,所以我们最好把属性尽量设置成非空,同时赋予它一个默认值,比如 0。

六、禁用事务

MySQL数据库表有两种类型,一种是支持事务处理,一种是不支持事务处理。MySQL在处理这两种表时,分别使用了不同类型的数据库引擎,因此数据库引擎在插入时效率不同,理论上说启用了事务功能后会比较慢。

示例:

Create Table(

.. /*字段说明*/

) ENGINE=InnoDB/MyISAM (带事务、不带事务)

事实证明是否禁用事务对插入数据的速度影响很大。

不过还是要多说一句,事务并非只会让我们的插入变慢。用了事务,就不可避免的要牺牲一部分速度,但是可以很大程度上保证数据的正确性。

七、禁用索引

插入记录时,MySQL会根据表的索引对插入的记录进行排序。如果插入大量数据时,这些排序会降低插入记录的速度。为了解决这种情况,在插入记录之前先禁用索引。等到记录都插入完毕后再开启索引。(虽然对于先插数据还是先建索引可能有一点争议)

示例:

1.ALTER TABLE 表名 DISABLE KEYS ; (禁用索引)

2.

1.ALTER TABLE 表名 ENABLE KEYS ; (启用索引)

1.

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...