欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > IT业 > PostgreSQL INSERT INTO 语句的深入解析

PostgreSQL INSERT INTO 语句的深入解析

2025/7/4 10:24:42 来源:https://blog.csdn.net/lly202406/article/details/141179484  浏览:    关键词:PostgreSQL INSERT INTO 语句的深入解析

PostgreSQL INSERT INTO 语句的深入解析

PostgreSQL 是一个功能强大的开源对象关系数据库系统,它使用和扩展了SQL语言。INSERT INTO 是SQL语言中的一个关键命令,用于向PostgreSQL数据库表中插入新行。本文将详细介绍INSERT INTO语句的使用方法、语法、示例以及一些高级特性。

INSERT INTO 基础语法

基本的INSERT INTO语句语法如下:

INSERT INTO 表名称 (列1, 列2, 列3, ..., 列N)
VALUES (值1, 值2, 值3, ..., 值N);
  • 表名称:指定要插入数据的表名。
  • 列1, 列2, ..., 列N:指定要插入数据的列名。
  • 值1, 值2, ..., 值N:指定要插入的具体数据值。

如果插入的是表中的所有列,则可以省略列名称:

INSERT INTO 表名称
VALUES (值1, 值2, 值3, ..., 值N);

INSERT INTO 示例

假设我们有一个名为employees的表,表结构如下:

CREATE TABLE employees (id SERIAL PRIMARY KEY,first_name VARCHAR(50),last_name VARCHAR(50),age INT,salary DECIMAL(10, 2)
);

插入一行新数据:

INSERT INTO employees (first_name, last_name, age, salary)
VALUES ('John', 'Doe', 30, 70000.00);

如果插入所有列的数据,可以省略列名:

INSERT INTO employees
VALUES (DEFAULT, 'Jane', 'Smith', 28, 65000.00);

这里使用了DEFAULT来表示自动增长的ID列。

高级 INSERT INTO 特性

插入多行

PostgreSQL允许一次性插入多行数据:

INSERT INTO employees (first_name, last_name, age, salary)
VALUES('Alice', 'Johnson', 25, 55000.00),('Bob', 'Brown', 35, 75000.00),('Charlie', 'Davis', 40, 80000.00);

从另一个表中选择数据插入

INSERT INTO语句还可以从另一个表中选择数据来插入:

INSERT INTO employees (first_name, last_name, age, salary)
SELECT first_name, last_name, age, salary
FROM temp_employees;

这里,从temp_employees表中选择的数据将被插入到employees表中。

返回插入的行

使用RETURNING子句,INSERT INTO语句可以返回插入的行:

INSERT INTO employees (first_name, last_name, age, salary)
VALUES ('Eve', 'Wilson', 45, 90000.00)
RETURNING id, first_name, last_name, age, salary;

这将返回插入行的ID和其他列的值。

总结

INSERT INTO是PostgreSQL中用于插入数据的关键语句。通过本文,我们了解了INSERT INTO的基本语法、插入单行和多行数据的方法、从其他表中选择数据插入的技巧,以及使用RETURNING子句返回插入行的高级特性。这些知识对于在PostgreSQL中进行数据操作至关重要。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词