oracle中insert语句(oracle insert语法)

http://www.itjxue.com  2023-01-25 08:32  来源:未知  点击次数: 

oracle insert语句怎么插入当前日期

oracle中当前时间用sysdate表示。所以可以通过如下方式插入:

String userinfo="insert into userinfo VALUES("+"'"+userD+"',sysdate"+")";

//之后执行插库操作。

备注,实际在数据库中插入语句如下

sql:insert into userinfo values('123',sysdate);

oracle 给定表名和条件生成insert语句

插入语句不需要条件的,你说的条件是指什么?下面存储过程的表名是可变的。

create or replace procedure p_insert(v_tab in varchar2,v_val in varchar2) is

begin

EXECUTE IMMEDIATE 'INSERT INTO '||v_tab||' VALUES('||v_val||')';

COMMIT;

end p_insert;

调用:

BEGIN p_insert('dept','50,''COMPUTER'',''HRB'',null'); END;

oracle语句insert into select如何加后续插入条件?

oracle中有批量插入语句insert into tableA (列1,列2,列3) select 列1,列2 from tableB。现在问题是这样的,tableA有3列,而通过最后的select语句所能获得的列只有列1和列2。但列3是非空的,所以插入时必须填写。

A中有3例,B表中你只能获得2列,可以用常量占位解决

insert into tableA (列1,列2,列3) select 列1,列2,常量 ?from tableB

例:如下

insert into tableA (列1,列2,列3) select 列1,列2,'123' ?from tableB 【字符串常量】

insert into tableA (列1,列2,列3) select 列1,列2,123 ?from tableB 【数值常量】

Oracle中插入数据

前提:在做insert数据之前,如果是非生产环境,请将表的索引和约束去掉,待insert完成后再建索引和约束。

insert into tab1 select * from tab2; commit;

这是最基础的insert语句,我们把tab2表中的数据insert到tab1表中。根据经验,千万级的数据可在1小时内完成。但是该方法产生的arch会非常快,需要关注归档的产生量,及时启动备份软件,避免arch目录撑爆。

alter table tab1 nologging;

insert /*+ append */ into tab1 select * from tab2;

commit; alter table tab1 logging;

该方法会使得产生arch大大减少,并且在一定程度上提高时间,根据经验,千万级的数据可在45分钟内完成。但是请注意,该方法适合单进程的串行方式,如果当有多个进程同时运行时,后发起的进程会有enqueue的等待。注意此方法千万不能dataguard上用,不过要是在database已经force logging那也是没有问题的。

insert into tab1 select /*+ parallel */ * from tab2; commit;

对于select之后的语句是全表扫描的情况,我们可以加parallel的hint来提高其并发,这里需要注意的是最大并发度受到初始化参数parallel_max_servers的限制,并发的进程可以通过v$px_session查看,或者ps -ef |grep ora_p查看。

alter session enable parallel dml;

insert /*+ parallel */ into tab1 select * from tab2; commit;

其他方法:

并发的insert,尚未比较和方法2哪个效率更高(偶估计是方法2快),有测试过的朋友欢迎补充。

insert into tab1 select * from tab2 partition (p1);

insert into tab1 select * from tab2 partition (p2);

insert into tab1 select * from tab2 partition (p3);

insert into tab1 select * from tab2 partition (p4);

对于分区表可以利用tab1进行多个进程的并发insert,分区越多,可以启动的进程越多。我曾经试过insert 2.6亿行记录的一个表,8个分区,8个进程,如果用方法2,单个进程完成可能要40分钟,但是由于是有8个分区8个进程,后发进程有enqueue,所以因此需要的时间为40分钟×8;但是如果用方法5,虽然单个进程需要110分钟,但是由于能够并发进程执行,所以总共需要的时间就约为110分钟了。

DECLARE TYPE dtarray IS TABLE OF VARCHAR2(20)

INDEX BY BINARY_INTEGER;

v_col1 dtarray; v_col2 dtarray; v_col3 dtarray;

BEGIN SELECT col1, col2, col3 BULK COLLECT INTO v_col1, v_col2, v_col3

FROM tab2;

FORALL i IN 1 .. v_col1.COUNT insert into tab1

WHERE tab1.col1 = v_col1;

END;

用批量绑定(bulk binding)的方式。当循环执行一个绑定变量的sql语句时候,在PL/SQL 和SQL引擎(engines)中,会发生大量的上下文切换(context switches)。使用bulk binding,能将数据批量的从plsql引擎传到sql引擎,从而减少上下文切换过程,提升效率。该方法比较适合于在线处理,不必停机。

sqlplus -s user/pwd runlog.txt set copycommit 2;

set arraysize 5000;

copy from user/pwd@sid - to user/pwd@sid - insert tab1 using

select * from tab2; exit EOF

用copy的方法进行插入,注意此处insert没有into关键字。该方法的好处是可以设置copycommit和arrarysize来一起控制commit的频率,上面的方法是每10000行commit一次。

我是一个初学者,如何向oracle数据库表中插入数据

工具/材料:电脑,oracle数据库表

1.例test表中有如下数据。

2.插入一条id为6,name为杨七的数据。insert into testvalues (6,'杨七');commit。

3.向表中复制一条目前表中id为1的数据,可用如下语句:insert into test select * from test where id=1;commit;在执行insert语句后,必须提交,即commit,否则不成功。

oracle 怎么知道insert语句插入了几行

sql%found,sql%notfound,sql%rowcount

在执行DML(insert,update,delete)语句时,可以用到以下三个隐式游标(游标是维护查询结果的内存中的一个区域,运行DML时打

开,完成时关闭,用sql%isopen检查是否打开):

sql%found (布尔类型,默认值为null)

sql%notfound(布尔类型,默认值为null)

sql%rowcount(数值类型默认值为0)

sql%isopen(布尔类型)

参考下,望采纳。

(责任编辑:IT教学网)

更多

推荐金山WPS文章