say_me_BaBa 2016-11-29 03:22 采纳率: 25%
浏览 1019
已采纳

SQL 触发器………………

求大神帮忙写个触发器:
表名A8104,字段:A81041
我需要这个字段的格式:ER00001,然后ER00002,ER00003……这样自动生成
就剩一个币了

  • 写回答

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);

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?