域名 AXUM.RS 将于2025年10月到期。我们无意再对其进行续费,我们希望你能够接续这个域名,让更多 AXUM 开发者继续受益。
  • 方案1️⃣AXUM.RS 域名 = 3000
  • 方案2️⃣方案1️⃣ + 本站所有专题原始 Markdown 文档 = 5000
  • 方案3️⃣方案2️⃣ + 本站原始数据库 = 5500
如果你有意接续这份 AXUM 情怀,请与我们取得联系。
说明:
  1. 如果有人购买 AXUM.RS 域名(方案1️⃣),或者该域名到期,本站将启用新的免费域名继续提供服务。
  2. 如果有人购买了 AXUM.RS 域名,且同时购买了内容和/或数据库(方案2️⃣/方案3️⃣),本站将关闭。届时我们或许会以另一种方式与你再相遇。

插入数据

本章将讨论如何使用 INSERT 向 PostgreSQL 中插入新行。同时介绍如何通过REGURNING子句返回最新插入行的ID以及批量插入数据的方法。

INSERT 简介

基本语法:

RETURNING 子句

INSERT 语句还有可选的 RETURNING 子句,用于返回插入行的信息。

通常会应用于自动编号的主键,返回最新插入的ID。

通常会应用于自动编号的主键,返回最新插入的ID。

假设自动编号主键的字段名为 id

INSERT INTO 表名
	(字段1,字段2, ...)
VALUES
	(值1,值2, ...)
RETURNING id;

示例

DROP TABLE IF EXISTS links;

CREATE TABLE links (
	id SERIAL PRIMARY KEY,
	url VARCHAR(255) NOT NULL,
	name VARCHAR(255) NOT NULL,
	description VARCHAR (255),
        last_update DATE
);
INSERT INTO links (url, name)
VALUES('https://axum.rs','AXUM中文网');
INSERT INTO links (url, name)
VALUES('http://www.postgresql.org','PostgreSQL') 
RETURNING id;

/* 结果
id
-----
2
*/

插入多行

INSERT INTO 表名
	(字段1,字段2, ...)
VALUES
	(值1-1,值1-2, ...),
	(值2-1,值2-2, ...),
	...
	(值N-1,值N-2, ...);

插入并返回ID:

INSERT INTO 表名
	(字段1,字段2, ...)
VALUES
	(值1-1,值1-2, ...),
	(值2-1,值2-2, ...),
	...
	(值N-1,值N-2, ...)
RETURNING id;

示例:

INSERT INTO 
    links(url,name)
VALUES
    ('https://google.com','谷歌'),
    ('https://github.com','Github')
RETURNING id;
/* 结果
id
-----
3
4
*/
要查看完整内容,请先登录