</p> 对于导入大量的数据到一个空的MyISAM表时,默认就是先导入数据然后才创建索引的,索引不用进行设置。* w3 D% ~! b V
引用
- t0 f% O; [1 a& w 1.load data infile '/home/mysql/text_txt' into table text& w! c$ x* c. k9 J
对于InnoDB类型的表,这种方式不能提高导入数据的效率,但也有几种针对InnoDB类型的表进行MySQL数据库优化的方式。
9 }3 n( B) b! l 1. 因为InnoDB类型的表式按照主键的顺序保存的,所以将导入的数据按照主键的顺序排序,可以有效提高导入数据的效率。5 B$ b. o4 ^4 Y2 R' |; P
2. 在导入数据前执行 SET UNIQUE_CHECKS=0,关闭唯一性校验,在导入结束后执行SET UNIQUE_CHECKS=1,恢复唯一性校验,可以提高导入的效率。
7 T' H: R/ X4 Y 3. 如果应用使用自动提交的方式,建议在导入前执行SET AUTOCOMMIT=0,关闭自动提交,导入结束后执行SET AUTOCOMMIT=1,打开自动提交,也可以提高导入效率。
1 }" f3 w+ D: {3 D+ C S; { MySQL数据库优化INSERT语句+ ~! j/ E( X/ L6 m) K
当进行数据INSERT的时候,可以考虑采用以下几种方式进行优化2 X& A9 g* v- L8 Z, ?8 n0 v
1. 如果同时从一个客户插入很多行,尽量使用多个值表的INSERT语句,这种方式将大大缩短客户端与数据库的链接、关闭等消耗,使得效率比分开执行的单个INSERT语句快.
9 R& j, {3 |; Y: S 例如:
4 a3 R; b e4 H 1.insert into test values(1,2)
& l9 G, A, U4 j2 M 2.insert into test values(3,4)
C0 V, W1 F+ B- f6 p n+ d 3.insert into test values(5,6)
( n: g' \$ e! i4 E4 l7 H 将上面三句改为:insert into test values(1,2),(3,4),(5,6)......' o3 d! [( `# @# b. M! C5 @
2. 如果从不同客户插入很多行,能通过使用INSERT DELAYED 语句得到更高的速度。' F q- `& t8 \, |0 E, ? s
DELAYED 的含义是让INSERT 语句马上执行,其实数据都被放在内存的队列中,并没有真正写入磁盘,这比每条语句分别插入要快得多;LOW_PRIORITY刚好相反,在所有其他用户对表的读写完后才进行插入。. p: V! f& [- T
3. 将索引文件和数据文件分在不同的磁盘上存放1 t+ u; [- t7 ^" w6 f
4. 如果进行批量插入,可以增加bulk_insert_buffer_size变量值的方法来提高速度,但是,这只能对于MyISAM表使用。
- M/ M0 g0 i) C1 o' Y 5. 当从一个文本文件中装载一个表时,使用LOAD DATA INFILE。 这通常比使用很多insert语句快20倍左右。0 r( F- v" z4 b; p+ @- G
以上的相关内容就是对MySQL数据库优化方法的介绍,望你能有所收获。 |