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!

人工智能实验室
相关文章相关文章
  • 长虹新款智能语音空调,告诉你空调也能玩Siri

    长虹新款智能语音空调,告诉你空调也能玩Siri

  • 品友互动为Digital Travel APAC2018 唯一受邀中国AI企业

    品友互动为Digital Travel APAC2018 唯一受邀中国AI企业

  • 第一批国家重点研发计划公布,旷视科技开启“五年行动”

    第一批国家重点研发计划公布,旷视科技开启“五年行动”

  • 让AI触手可及  Qualcomm携手创通联达推出全新终端侧AI开发套件

    让AI触手可及 Qualcomm携手创通联达推出全新终端侧AI开发套件

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

据外媒报道,STEER打造了首款完全自动驾驶停车技术,旨在使常规车辆转变为无人驾驶车辆。STEER的首款技术应用是4级自动驾驶及网络安全停车...

近日,美国软性机器抓手制造商 Soft Robotics 宣布,获得 2000 万美元的融资,本轮投资者包括 Scale Venture Partners,Calibrate Ventures...

据外媒报道,加州车管局发布了《2017自动驾驶脱离报告(California Autonomous Vehicle Disengagement Reports)》,其中谈及了脱离的具体...

用人机语音交互,来解决智能家居适老的问题;通过家庭门禁与安防套件、空气净化套件、可燃气体与有害气体监控套件等相互联动,在不同生活情...