本章将讨论如何使用 INSERT
向 PostgreSQL 中插入新行。同时介绍如何通过REGURNING
子句返回最新插入行的ID以及批量插入数据的方法。
INSERT
简介
基本语法:
INSERT INTO 表名
(字段1,字段2, ...)
VALUES
(值1,值2, ...);
RETURNING
子句
INSERT
语句还有可选的 RETURNING
子句,用于返回插入行的信息。
- 如果要返回整个插入行,可以使用
RETURNING *
- 如果要返回插入行某些字段,可以使用
RETURNING 字段1,字段2
- 如果要返回插入行某个字段,可以使用
RETURNING 字段
- 也可以使用
AS
来设置别名
假设自动编号主键的字段名为 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中文网');
插入单行并获取最后插入的ID
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, ...);
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
*/