ToB企服应用市场:ToB评测及商务社交产业平台
标题:
达梦数据库如何设置自增主键
[打印本页]
作者:
铁佛
时间:
2024-8-26 14:49
标题:
达梦数据库如何设置自增主键
达梦数据库自增通常是利用序列和触发器
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企服之家,中国第一个企服评测及商务社交产业平台。
欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/)
Powered by Discuz! X3.4