ホームページ > データベース > mysql チュートリアル > Oracle利用触发器实现自增列

Oracle利用触发器实现自增列

WBOY
リリース: 2016-06-07 16:07:59
オリジナル
1287 人が閲覧しました

Oracle没有自增列功能,mysql 和 sqlserver 分别用auto_increment和identity(1,1)来实现自增。Oracle要实现只能通过序列实现,

Oracle利用触发器实现自增列

[日期:2015-02-10] 来源:Linux社区  作者:neweastsun [字体:]

Oracle没有自增列功能,,mysql 和 sqlserver 分别用auto_increment和identity(1,1)来实现自增。Oracle要实现只能通过序列实现,每次插入的时候通过取序列的值显示的给自增列,感觉有些不方便,这里使用触发器来代替,从而使插入的时候三者数据库在语法上一致,便于DAO代码的移植。下面是Oracle实现示例,步骤如下:

1、创建表

create tabletest_user(

  user_id  number(10,0) primary key,

  user_name varchar2(40)

);

2、创建序列

create sequence  test_user_seq start with 1 maxvalue 9999999999 increment by 1; 

3、创建触发器

create or replace

trigger  test_user_trigger     

before insert on  test_user     

for each row     

begin     

select test_user_seq.nextval into :new.user_id from dual;     

end ; 

4、插入数据

insert intotest_user(user_name) values('tom');

insert intotest_user(user_name) values('jack');

5、测试结果

select * from test_user;

Oracle利用触发器实现自增列

本文永久更新链接地址:

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート