求大神帮忙写个触发器:
表名A8104,字段:A81041
我需要这个字段的格式:ER00001,然后ER00002,ER00003……这样自动生成
就剩一个币了
SQL 触发器………………
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
villare 2016-11-29 03:35关注-- 建表
CREATE TABLE A8104(
A81041 VARCHAR2(10) NOT NULL,
FIELD NUMBER(6)
);-- 序列
CREATE SEQUENCE SEQ_A8104
MINVALUE 1
MAXVALUE 99999999
START WITH 1
INCREMENT BY 1
NOCACHE;-- 触发器
CREATE OR REPLACE TRIGGER TRI_A8104_1 --触发器名称
BEFORE INSERT ON A8104
FOR EACH ROW
DECLARE
NEXTID VARCHAR2(10);
BEGIN
IF :NEW.A81041 IS NULL OR :NEW.A81041 = 0 THEN
SELECT 'E' || to_char(SEQ_A8104.NEXTVAL, 'FM000000') --SEQ_A8104正是刚才创建的序列
INTO NEXTID
FROM SYS.DUAL;
:NEW.A81041 := NEXTID;
END IF;
END TRI_A8104_1;INSERT INTO A8104(FIELD) VALUES(10);
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报