域名 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 INTO 表名(字段列表) 
VALUES(值列表)
ON CONFLICT 目标 行为;
  • 目标:能唯一标识数据的表达式,比如主键、唯一约束等
  • 行为:可以是以下之一:
    • DO NOTHING:如果数据已存在,则不执行任何操作
    • DO UPDATE SET 字段1=值1, ... WHERE 条件:更新某些字段的值
  • DO NOTHING:如果数据已存在,则不执行任何操作
  • DO UPDATE SET 字段1=值1, ... WHERE 条件:更新某些字段的值

示例数据:

DROP TABLE IF EXISTS customers;

CREATE TABLE customers (
	customer_id serial PRIMARY KEY,
	name VARCHAR UNIQUE,
	email VARCHAR NOT NULL,
	active bool NOT NULL DEFAULT TRUE
);

INSERT INTO 
    customers (name, email)
VALUES 
    ('IBM', '[email protected]'),
    ('Microsoft', '[email protected]'),
    ('Intel', '[email protected]');
INSERT INTO customers (name, email)
VALUES('Microsoft','[email protected]') 
ON CONFLICT ON CONSTRAINT customers_name_key 
DO NOTHING;

由于已存在 Microsoft,并且 ON CONFLICT行为DO NOTHING,所以不执行使用操作。

本示例的 目标 使用的是唯一约束 CONSTRAINT customers_name_key,相对的,直接使用唯一约束的字段名会更直观:

INSERT INTO customers (name, email)
VALUES('Microsoft','[email protected]') 
ON CONFLICT (name) 
DO NOTHING;

示例二:插入/更新“Microsoft”的联系方式

EXCLUDED.email 是指当前已存在记录中的 email 字段的值

要查看完整内容,请先登录