铁佛 发表于 2024-8-26 14:49:30

达梦数据库如何设置自增主键

达梦数据库自增通常是利用序列和触发器

1.创建序列

CREATE SEQUENCE your_sequence_name
START WITH 1
INCREMENT BY 1
NOCACHE;
2.创建触发器

在插入新记录时,利用触发器自动从序列中获取下一个值,并设置到自增字段上。
CREATE OR REPLACE TRIGGER your_trigger_name
BEFORE INSERT ON your_table_name
FOR EACH ROW
BEGIN
    IF :NEW.id IS NULL THEN -- 假设id是自增字段
      SELECT your_sequence_name.NEXTVAL INTO :NEW.id FROM DUAL;
    END IF;
END;
完备例子如:
CREATE SEQUENCE seq_u_operation_log_id
START WITH 1
INCREMENT BY 1
NOCACHE;


CREATE TABLE HSZ_PRODUCT_UCENTER.U_OPERATION_LOG (
        ID BIGINT NOT NULL,
        OPERATION VARCHAR(50),
        REQUEST_URI VARCHAR(255),
        REQUEST_METHOD VARCHAR(20),
        REQUEST_PARAMS CLOB,
        USER_AGENT VARCHAR(500),
        CREATOR_NAME VARCHAR(50),
        OPERATION_TIME TIMESTAMP,
        REQUEST_IP VARCHAR(100),
        REQUEST_TIME BIGINT,
        REQUEST_STATUS TINYINT,
        REQUEST_RESULT CLOB,
        PRIMARY KEY (ID)
);

CREATE OR REPLACE TRIGGER trg_u_operation_log_before_insert
BEFORE INSERT ON U_OPERATION_LOG
FOR EACH ROW
BEGIN
    IF NEW.id IS NULL OR NEW.id = 0 THEN   
      SELECT seq_u_operation_log_id.NEXTVAL INTO :NEW.id FROM DUAL;
    END IF;
END;
留意:DMDB中的触发器语法可能与上面的示例不完全类似,详细取决于你的DMDB版本和配置。上面的示例是基于Oracle风格的语法,由于达梦数据库在某些方面与Oracle相似。你可能需要查阅你的DMDB版本的官方文档来获取准确的触发器语法。
留意事项
在利用IDENTITY列时,请确保你的应用步伐在插入记录时不要为IDENTITY列指定值,除非你有特殊的需求。
如果利用序列和触发器,请确保序列和触发器的名称、表名、字段名等与你的实际环境相匹配。
在利用序列时,思量是否需要缓存(NOCACHE或CACHE)来提高性能。不外,利用缓存可能会带来序列值回滚的风险,这取决于你的详细应用场景。
总是查阅最新的达梦数据库文档,由于差别版本的数据库在功能和语法上可能有所差别。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 达梦数据库如何设置自增主键