摘要: 当使用 insert...select...进行记录的插入时,如果select的表是innodb类型的,不论insert的表是什么类型的表,都会对select的表的纪录进行锁定。对于那些从oracle迁移过来的应用,需要特别的注意,因为oracle并不存在类似的问题,所以在oracle的应用中insert...select...操作非常的常见。例如:有时候会对比较多的纪录进行统计分析,然后将统计的中间结果插入到另外一个表,这样的操作因为进行的非常少,所以可能并没有设置相应的索引。如果迁移到mysql数据库后不进行相应的调整,那么在进行这个操作期间,对需要select的表实际上是进行的全表扫.. 阅读全文
posted @ 2014-03-14 16:44 yayun 阅读(1554) 评论(0) 推荐(0) 编辑
摘要: 1.对于 MyISAM 类型的表,可以通过以下方式快速的导入大量的数据。ALTER TABLE tblname DISABLE KEYS;LOAD DATA LOCAL INFILE '/usr/share/dict/words' INTO TABLE source_words(word);ALTER TABLE tblname ENABLE KEYS;这两个命令用来打开或者关闭 Myisam 表非唯一索引的更新。在导入大量的数据到一个非空的 MyISAM 表时,通过设置这两个命令,可以提高导入的效率。对于导入大量数据到一个空的 MyISAM 表,默认就是先导入数据然后才创建索 阅读全文
posted @ 2014-03-14 11:42 yayun 阅读(1731) 评论(0) 推荐(0) 编辑