来源于:http://www.cnblogs.com/rootq/archive/2009/02/11/1388043.html SQL> select count(*) from t;COUNT(*)----------5442048****************************SQL> alter table t1 nologging;SQL> insert /*+append*/ into t12 select * from t;5442048 rows created.…
SQL> select count(*) from t;COUNT(*)----------5442048****************************SQL> alter table t1 nologging;SQL> insert /*+append*/ into t12 select * from t;5442048 rows created.Elapsed: 00:00:55.73****************************SQL> create ta…
在上一篇的blog中 做了下使用,在归档和非归档下,做数据插入http://blog.csdn.net/guogang83/article/details/9219479.结论是在非归档模式下表设置为nologging用insert /*+append*/速度最快.那为什么快呢,原理是什么?下面我们来一起做一个实验: SQL> create or replace view m_undo_redo as    select  v$statname.name,value    from v$myst…
append 与 insert 对比: # append 操作 >>> count = 10**5 >>> nums = [] >>> for i in range(count): ... nums.append(i) ... >>> nums.reverse() # insert 操作 >>> nums = [] >>> for i in range(count): ... nums.insert…
https://blog.csdn.net/xiaobluesky/article/details/50494101 关于insert /*+ append */我们需要注意以下三点: a.非归档模式下,只需append就能大量减少redo的产生:归档模式下,只有append+nologging才能大量减少redo. b.insert /*+ append */ 时会对表加锁(排它锁),会阻塞表上的除了select以外所有DML语句:传统的DML在TM enqueue上使用模式3(row exc…
一,没有优化的速度:Executed in 69.436 seconds drop table t purge;create table t(x int);/*清空共享池,注意在生产环境中千万不能做这步操作*/alter system flush shared_pool; create or replace procedure proc1as begin  for i in 1 .. 100000    loop       execute immediate      'insert into…
// Initialize conn&stmt Connection conn=null; Statement stmt=null; ... conn=dataSource.getConnection(); stmt = conn.createStatement(); ... conn.setAutoCommit(false); stmt = conn.createStatement(); for(int i=0;i<recordCount;i++) { String insertSql=g…
一. 是否支持多线程?   SQLite官网上的"Is SQLite threadsafe?"这个问答. 简单来说,从3.3.1版本开始,它就是线程安全的了.而iOS的SQLite版本没有低于这个版本的,当然,你也可以自己编译最新版本. 不过这个线程安全仍然是有限制的,在这篇<Is SQLite thread-safe?>里有详细的解释.另一篇重要的文档就是<SQLite And Multiple Threads>.它指出SQLite支持3种线程模式: 单线程:…
最近做了 server_log 日志数据库记录,仅仅插入,由平台来获取数据进行分析的需求. 但是内部反馈插入数据库记录非常耗时,我就很纳闷了,一个insert怎么会 30-50ms 呢?按说应该在 0.5ms 以内的: 经过分析,发现是InnoDB数据库的Row_Format格式问题,改为MyISAM表就可以了,但是InnoDB是支持事务的,一般是推荐InnoDB的,好奇为什么. 而且InnoDB的表,只能选择 COMPACT 和REDUNDANT 两种行格式(RoW_FORMAT). 经过搜索…
  INSERT IGNORE 与INSERT INTO的区别就是INSERT IGNORE会忽略数据库中已经存在 的数据,如果数据库没有数据,就插入新的数据,如果有数据的话就跳过这条数据.这样就可以保留数据库中已经存在数据,达到在间隙中插入数据的目的.…