zoukankan      html  css  js  c++  java
  • 关于oracle的sequence和trigger。

    原先mysql中每个自增字段,在oracle中就需要建立一个sequence和一个trigger。

    就算同一个表中有x个自增字段,那么就需要建立x个sequence和x和trigger。

    实际中,我建立了915个sequence和915个trigger。因为mysql有915个自增自段。

    生成的语句如下:

    create sequence SEQ_E3_910_YUGOU_GOODSMX_ID increment by 1 start with 1
    minvalue 1
    nomaxvalue
    nocache
    order;

    create trigger TRIGGER_E3_910_YUGOU_GOODSMX_I before insert on "YUGOU_GOODSMX"
    for each row
    begin
    select SEQ_E3_910_YUGOU_GOODSMX_ID.nextval into:new."ID" from sys.dual
    ;
    end;

    有915个这样的成对语句出现。

    但是运行时,报错了ORA-24344: success with compilation error。(警告: 创建的触发器带有编译错误。)

    于是我只运行create sequence ,没有问题,一下跑了几百个。

    再只运行create trigger ,就会报如上的错误 。

    但是我把这些create trigger,在navicat里单个运行,就都能成功。

    查了老半天,才知道原因是:http://www.2cto.com/database/201304/205599.html 

    因为触发器需要先编译,每创建一个触发器,需要以“/”结束,然后才能执行下一个。

    于是改为如下:

    create trigger TRIGGER_E3_910_YUGOU_GOODSMX_I before insert on "YUGOU_GOODSMX"
    for each row
    begin
    select SEQ_E3_910_YUGOU_GOODSMX_ID.nextval into:new."ID" from sys.dual
    ;
    end;

    /

    就一次性跑通多个create trigger了。

  • 相关阅读:
    洛谷P3620 [APIO/CTSC 2007] 数据备份
    洛谷P2744 量取牛奶
    洛谷P1560 蜗牛的旅行
    luogu P1776 宝物筛选_NOI导刊2010提高(02)
    luogu P1020 导弹拦截
    luogu P2015 二叉苹果树
    luogu P1137 旅行计划
    树形dp瞎讲+树形dp基础题题解
    luogu P1252 马拉松接力赛 P1803 凌乱的yyy / 线段覆盖
    luogu P1196 [NOI2002]银河英雄传说
  • 原文地址:https://www.cnblogs.com/stringzero/p/5719407.html
Copyright © 2011-2022 走看看