--自動編號:Oracle
建表
create table t1(autoid number(10) primary key,name char(4));
創建序列
create sequence seq_t1_autoid;
添加數據
insert into t1(autoid,name) values(seq_t1_autoid.nextval,'a');
insert into t1(autoid,name) values(seq_t1_autoid.nextVal,'b');
commit;
--思考:能不能實現一個與DBMS無關的自動編號方法?
insert into t1(autoid,name) select max(autoid)+1,'c' from t1;
insert into t1(autoid,name)??select max(autoid)+1,'d' from t1;
commit;
--改正:
insert into t1(autoid,name) select nvl(max(autoid),0)+1,'c' from t1;
insert into t1(autoid,name)??select nvl(max(autoid),0)+1,'d' from t1;
commit;
面試:如何在Oracle中實現與Mysql一樣的自動編號:
解決:使用觸發器
create table t1(autoid number(10) primary key);
create sequence seq_t1_autoid;
create or replace trigger tr_t1_autoid
before insert on Friend
for each row
begin
??select seq_t1_autoid.nextval into :new.autoid from dual;
end;
--測試:
insert into t1(name) values('a');
insert into t1(name) values('b');
commit;
select * from t1;?
autoid? name??
?????1?? ? ?a????
?????2????? b????
+--------+------+
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
