oracle插入(insert into)
转载:http://www.oraclejsq.com/article/010100199.html
oracle对表数据的插入是使用insert命令来执行的。
insert 命令结构:
insert
into
表名(列名1,列名2,列名3.....)
values
(值1,值2,值3.....);
语法解析:
1、列名可以省略,当列名不填时,默认的是表中的所有列,列的顺序是按照建表的顺序进行排列的。
2、列名的数量和值的数量要一致,并且值的类型要和列的类型一一对应。
3、当表当中某些字段设置了某些约束的情况下,必须按照字段的约束来进行该值的插入,例如:学生信息表(stuinfo)当中设置有主键(主键字段是stuid),因此该字段必须具有唯一性,不能和原有的数据重复。age、stuname、calassno等字段是必填字段,因此是必须有值的。
案例1:向学生信息表(stuinfo)插入一条数据:insert
into
student.stuinfo (stuid, stuname, sex, age, classno, stuaddress, grade, enroldate, idnumber)
values
(
'sc201801005'
,
'龙七'
,
'1'
, 26,
'c201801'
,
'福建省厦门市xxx号'
,
'2018'
, to_date(
'01-09-2018'
,
'dd-mm-yyyy'
),
'3503021992xxxxxxxx'
);
select
*
from
student.stuinfo t
where
t.stuid=
'sc201801005'
;
案例2:向学生信息表(stuinfo)插入重复数据:insert
into
student.stuinfo (stuid, stuname, sex, age, classno, stuaddress, grade, enroldate, idnumber)
values
(
'sc201801005'
,
'龙七'
,
'1'
, 26,
'c201801'
,
'福建省厦门市xxx号'
,
'2018'
, to_date(
'01-09-2018'
,
'dd-mm-yyyy'
),
'3503021992xxxxxxxx'
);
insert插入一个select的结果集
在 oracle 中,一个 insert 命令可以把一个select结果集一次性插入到一张表中。
语法结构如下:
insert
into
表
select
子句;
案例3:把上一章节利用oracle查询(select)语句备份的表stuinfo_2018的数据一次插入表stuinfo当中:delete
from
student.stuinfo t
where
t.stuid
in
(
select
b.stuid
from
student.stuinfo_2018 b );
insert
into
student.stuinfo
select
*
from
student.stuinfo_2018;
select
*
from
student.stuinfo;