Oracle INSERT INTO的几种用法

在Oracle中,INSERTINTO语句用于向表中插入数据。它可以用于插入所有列的值,或者只插入指定列的值。此外,还可以结合SELECT语句从一个表复制数据并插入到另一个表中。插入数据时需确保值的顺序与列的顺序匹配,或明确指定列名。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在 Oracle 中,插入数据可以使用 INSERT INTO 语句。INSERT INTO 语句可以有多种写法,具体取决于插入的数据来源和目标,下面列出 INSERT INTO 语句的一些常见用法和语法。

  1. 插入所有列的值

如果要将数据插入到表中的所有列中,则可以使用以下 INSERT INTO 语句:

INSERT INTO table_name VALUES (value1, value2, value3, ...);

其中,table_name 表示表的名称,value1, value2, value3 等列出了要插入的值。要注意的是,插入值的顺序必须与表中列的顺序保持一致。

例如,如果要向 employees 表中插入一条新记录,可以使用以下语句:

INSERT INTO employees VALUES (101, 'John', 'Smith', '01-JAN-1980', 'Sales', 5000, NULL, 10);

该语句将一个新记录插入到 employees 表中,其中包含员工编号、名字、姓氏、出生日期、部门、薪水、经理编号等值。

  1. 插入指定列的值

如果只需要为表中的部分列插入值,则可以使用以下 INSERT INTO 语句:

INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...);

其中,table_name 表示表的名称,column1, column2, column3 等表示要插入的列的名称,value1, value2, value3 等表示要插入的值。

例如,如果要向 employees 表中插入一条新记录,只需要为姓名、出生日期、薪水和部门列插入值,可以使用以下语句:

INSERT INTO employees (first_name, last_name, hire_date, salary, department_id) 
  VALUES ('John', 'Smith', '01-JAN-1980', 5000, 10);
  1. 从其他表中插入数据

有时候需要从一个表中复制数据并插入到另一个表中。可以使用 INSERT INTO SELECT 语句来实现这个目的。语法如下:

INSERT INTO table1 (column1, column2, column3, ...)
  SELECT column1, column2, column3, ... 
  FROM table2
  WHERE condition;

其中,table1 表示目标表,column1, column2, column3 等表示要插入的列,table2 表示需要复制数据的源表,condition 是一个可选的 WHERE 条件语句,用于筛选要复制的数据。

例如,如果要从 new_employees 表中复制数据并插入到 employees 表中,可以使用以下语句:

INSERT INTO employees (employee_id, first_name, last_name, hire_date, salary, department_id) 
  SELECT employee_id, first_name, last_name, hire_date, salary, department_id 
  FROM new_employees;

该语句将从 new_employees 表中复制所有列的数据,并插入到 employees 表中对应列中。

这些是 INSERT INTO 语句的常见用法和语法。根据实际情况,可以选择使用合适的 INSERT INTO 语句来插入数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值