</p> 对于导入大量的数据到一个空的MyISAM表时,默认就是先导入数据然后才创建索引的,索引不用进行设置。% {$ \8 h i5 d6 G: z% W/ t+ G
引用6 d# o8 r0 V# V. `
1.load data infile '/home/mysql/text_txt' into table text, D1 w2 I6 h- N. N) C, [
对于InnoDB类型的表,这种方式不能提高导入数据的效率,但也有几种针对InnoDB类型的表进行MySQL数据库优化的方式。
! f- b$ A: W' z8 L. u$ w 1. 因为InnoDB类型的表式按照主键的顺序保存的,所以将导入的数据按照主键的顺序排序,可以有效提高导入数据的效率。/ p4 n8 m/ a% p$ b' T1 T0 t
2. 在导入数据前执行 SET UNIQUE_CHECKS=0,关闭唯一性校验,在导入结束后执行SET UNIQUE_CHECKS=1,恢复唯一性校验,可以提高导入的效率。 @7 u) s4 R6 a; Z7 w& S0 z9 ]
3. 如果应用使用自动提交的方式,建议在导入前执行SET AUTOCOMMIT=0,关闭自动提交,导入结束后执行SET AUTOCOMMIT=1,打开自动提交,也可以提高导入效率。
9 n' B R1 L5 ~, X MySQL数据库优化INSERT语句# ^8 Z6 g; G- \1 Q2 j; o
当进行数据INSERT的时候,可以考虑采用以下几种方式进行优化% F/ h/ L8 [# Q# O4 M- X
1. 如果同时从一个客户插入很多行,尽量使用多个值表的INSERT语句,这种方式将大大缩短客户端与数据库的链接、关闭等消耗,使得效率比分开执行的单个INSERT语句快.
0 l5 D, z/ q0 V b" q- p 例如:8 @. n' x! g+ a6 D7 C$ G5 M2 v
1.insert into test values(1,2)
6 [- Y- _4 Y" C- A, _4 r9 |0 { 2.insert into test values(3,4)+ M/ H( s( K, P! K8 H6 j7 B, D3 W1 \
3.insert into test values(5,6)- F8 `' q# k0 G+ D5 K) P
将上面三句改为:insert into test values(1,2),(3,4),(5,6)......
; o. h! o$ z$ M- m( ^5 D$ l 2. 如果从不同客户插入很多行,能通过使用INSERT DELAYED 语句得到更高的速度。
; |) L* y; w! [. u( }) C! G1 g# ` DELAYED 的含义是让INSERT 语句马上执行,其实数据都被放在内存的队列中,并没有真正写入磁盘,这比每条语句分别插入要快得多;LOW_PRIORITY刚好相反,在所有其他用户对表的读写完后才进行插入。
$ K! O* y' G: O2 y0 C E 3. 将索引文件和数据文件分在不同的磁盘上存放
6 p6 N4 ]: c2 r% O$ T9 A( ]( M 4. 如果进行批量插入,可以增加bulk_insert_buffer_size变量值的方法来提高速度,但是,这只能对于MyISAM表使用。
! Q$ ?: R4 h5 s: J 5. 当从一个文本文件中装载一个表时,使用LOAD DATA INFILE。 这通常比使用很多insert语句快20倍左右。% F' t6 t1 L% D; _( c: u
以上的相关内容就是对MySQL数据库优化方法的介绍,望你能有所收获。 |