插入数据

INSERT 简介

基本语法:

INSERT INTO 表名
	(字段1,字段2, ...)
VALUES
	(值1,值2, ...);
  • 如果要返回整个插入行,可以使用 RETURNING *
  • 如果要返回插入行某些字段,可以使用 RETURNING 字段1,字段2
  • 如果要返回插入行某个字段,可以使用 RETURNING 字段
  • 也可以使用 AS 来设置别名

通常会应用于自动编号的主键,返回最新插入的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中文网');

插入单行并获取最后插入的ID

插入多行

语法:

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
*/
要查看完整内容,请先登录