say_me_BaBa
say_me_BaBa
采纳率25%
2016-11-29 03:22 阅读 1.0k

SQL 触发器………………

1

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

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

1条回答 默认 最新

  • 已采纳
    villare 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);

    点赞 评论 复制链接分享

相关推荐