oracle中主键自增的生成步骤
2012-03-13 23:19
211 查看
--均在oracle 10g下完成以下步骤
--首先创建一张表(自己用的用户表)
CREATE TABLE Y_USER(
USER_ID NUMBER(8) NOT NULL PRIMARY KEY,
USER_NAME VARCHAR2(20) NOT NULL,
GENDER INT NOT NULL,
ADDRESS VARCHAR2(30),
STATUS INT NOT NULL,
PHONE NUMBER(12),
IDENTITY INT NOT NULL,
EMAIL VARCHAR2(50) NOT NULL
);
--然后创建用户序列
DROP SEQUENCE S_TB_USER;
CREATE SEQUENCE S_TB_USER MINVALUE 1 MAXVALUE 99999
INCREMENT BY 1
START WITH 1
NOCACHE
ORDER;
--第三步创建用户触发器
CREATE OR REPLACE TRIGGER T_TB_USER
BEFORE INSERT ON Y_USER
--Y_USER为表名
FOR EACH ROW
DECLARE
NEXTID NUMBER;
BEGIN
IF
:NEW.USER_ID IS NULL OR :NEW.USER_ID
= 0 THEN --USER_ID
为主键列名
SELECT S_TB_USER.NEXTVAL INTO NEXTID FROM DUAL;
--S_TB_USER为刚创建的序列名
:NEW.USER_ID:=NEXTID;
END IF;
END T_TB_USER;
完成以上三步,就可以实现自增了!!!!
--首先创建一张表(自己用的用户表)
CREATE TABLE Y_USER(
USER_ID NUMBER(8) NOT NULL PRIMARY KEY,
USER_NAME VARCHAR2(20) NOT NULL,
GENDER INT NOT NULL,
ADDRESS VARCHAR2(30),
STATUS INT NOT NULL,
PHONE NUMBER(12),
IDENTITY INT NOT NULL,
EMAIL VARCHAR2(50) NOT NULL
);
--然后创建用户序列
DROP SEQUENCE S_TB_USER;
CREATE SEQUENCE S_TB_USER MINVALUE 1 MAXVALUE 99999
INCREMENT BY 1
START WITH 1
NOCACHE
ORDER;
--第三步创建用户触发器
CREATE OR REPLACE TRIGGER T_TB_USER
BEFORE INSERT ON Y_USER
--Y_USER为表名
FOR EACH ROW
DECLARE
NEXTID NUMBER;
BEGIN
IF
:NEW.USER_ID IS NULL OR :NEW.USER_ID
= 0 THEN --USER_ID
为主键列名
SELECT S_TB_USER.NEXTVAL INTO NEXTID FROM DUAL;
--S_TB_USER为刚创建的序列名
:NEW.USER_ID:=NEXTID;
END IF;
END T_TB_USER;
完成以上三步,就可以实现自增了!!!!
相关文章推荐
- Oracle到MySQL数据库迁移之--主键生成策略替换
- 关于Hibernate的oracle主键id生成策略uuid、native和sequence
- ORACLE uuid自己主动生成主键
- 关于Hibernate的oracle主键id生成策略uuid、native和sequence
- oracle主键生成方式
- oracle 如何实现主键id自增,或自动生成
- iBatis自动生成的主键 返回主键 (Oracle,Sql Server,Mysql,SQLite)
- Oracle数据运用那种主键生成策略
- oracle/mysql/sql_server对于主键生成策略的代码展示
- PowerDesigner中如何生成主键和自增列--Oracle版本
- 用oracle的trigger生成主键的时候和hibernate冲突的讨论(转)
- 生成Oracle Statpack步骤
- 分析Oracle生成Statpack步骤
- 在jfinal实现oracle”自增主键“保存入库,并获取自生成的主键
- oracle主键生成方式
- oracle下主键生成,及导入导出方法
- oracle 在插入数据库时自动生成主键
- Oracle主键自动生成_表and存储过程
- PowerDesigner中如何生成主键和自增列--Oracle版本
- oracle中,主键生成策略