PostgreSQL 事务与并发控制
-- 创建一个新的序列,用于生成唯一的订单ID
CREATE SEQUENCE order_id_seq START 1;
-- 创建订单表
CREATE TABLE orders (
id INT PRIMARY KEY DEFAULT nextval('order_id_seq'),
product_id INT NOT NULL,
quantity INT NOT NULL,
total_price NUMERIC(10,2) NOT NULL,
created_at TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP
);
-- 创建一个新的序列,用于生成唯一的订单项ID
CREATE SEQUENCE order_item_id_seq START 1;
-- 创建订单项表
CREATE TABLE order_items (
id INT PRIMARY KEY DEFAULT nextval('order_item_id_seq'),
order_id INT NOT NULL REFERENCES orders(id) ON DELETE CASCADE,
product_id INT NOT NULL REFERENCES products(id),
quantity INT NOT NULL,
unit_price NUMERIC(10,2) NOT NULL
);
-- 创建一个新的序列,用于生成唯一的订单支付ID
CREATE SEQUENCE payment_id_seq START 1;
-- 创建支付表
CREATE TABLE payments (
id INT PRIMARY KEY DEFAULT nextval('payment_id_seq'),
order_id INT NOT NULL UNIQUE REFERENCES orders(id) ON DELETE CASCADE,
amount NUMERIC(10,2) NOT NULL,
payment_method TEXT NOT NULL,
paid_at TIMESTAMPTZ NOT NULL
);
-- 创建一个新的序列,用于生成唯一的订单状态ID
CREATE SEQUENCE order_status_id_seq START 1;
-- 创建订单状态表
CREATE TABLE order_statuses (
id INT PRIMARY KEY DEFAULT nextval('order_status_id_seq'),
order_id INT NOT NULL UNIQUE REFERENCES orders(id) ON DELETE CASCADE,
status TEXT NOT NULL,
updated_at TIMESTAMPTZ NOT NULL
);
在这个例子中,我们创建了新的序列和相关的表来跟踪订单、订单项、支付和订单状态。每个表都有一个相应的序列来生成唯一的ID,并且通过外键约束与其他表建立关联。此外,订单项表和支付表中的order_id
字段上有ON DELETE CASCADE
约束,这意味着当订单被删除时,相关的订单项和支付记录也会自动被删除,保持数据的一致性。
评论已关闭