關于主鍵:在建表時指定primary key字句即可:
創(chuàng)新互聯(lián)建站主要業(yè)務有網站營銷策劃、成都做網站、成都網站制作、微信公眾號開發(fā)、小程序制作、H5開發(fā)、程序開發(fā)等業(yè)務。一次合作終身朋友,是我們奉行的宗旨;我們不僅僅把客戶當客戶,還把客戶視為我們的合作伙伴,在開展業(yè)務的過程中,公司還積累了豐富的行業(yè)經驗、營銷型網站建設資源和合作伙伴關系資源,并逐漸建立起規(guī)范的客戶服務和保障體系。
create table test(
id ?number(6) primary key,
name varchar2(30)
);
如果是對于已經建好的表,想增加主鍵約束,則類似語法:
alter table test add constraint pk_id primary key(id); ?
其中add constraint 和 primary key是關鍵字,pk_id是主鍵名稱,自定義的額,只要不重復即可。
也可以自動一些,對表的插入操作,建立一個觸發(fā)器,每當有數(shù)據(jù)插入時,觸發(fā)器自動修改id值為序列的新值,這樣就完全實現(xiàn)自增id功能了。不過其實也沒有這個必要。因為觸發(fā)器如果建多了,有時會比較混亂,不易管理。
第一種,通過序列以及觸發(fā)器實現(xiàn)主鍵自增長。
這種方式適用于直接使用JDBC連接數(shù)據(jù)庫。這種方式將主鍵自增長的任務完全交給數(shù)據(jù)庫,我們無需在代碼層面上進行任何控制。
第二種,通過序列以及Hibernate配置實現(xiàn)自增長。
這種方式適用于通過Hibernate連接數(shù)據(jù)庫的方式。這種方式在數(shù)據(jù)庫上創(chuàng)建序列,通過配置在POJO類上的注釋,讓Hibernate去調用數(shù)據(jù)庫的序列實現(xiàn)自增長。
這兩種方式都是通過Oracle的序列實現(xiàn)自增長,但第一種通過數(shù)據(jù)庫的觸發(fā)器在插入的時候自動插入主鍵。而后者則由Hibernate自動完成獲取主鍵,插入主鍵這一操作。
這里Oracle數(shù)據(jù)庫使用命令行操作,注意Oracle不能直接設置自增字段,需要使用序列+觸發(fā)器來實現(xiàn)。
1.創(chuàng)建Book表
Create table Book(
Id NUMBER(6) constraint s_PK primary key,
Title nvarchar2(200) not null,
Author nvarchar2(200) not null,
Publisher nvarchar2(200) not null,
ISBN nvarchar2(50) not null,
Price NUMBER(6,2) not null,
CategoryName nvarchar2(50) not null,
Description nvarchar2(1000) not null,
ImageName varchar2(50)
);
2.創(chuàng)建自增序列
create sequence BOOK_seq (BOOK_seq為序列名,任意?。?/p>
increment by 1 (increment 表示字段逐條增加1)
start with 1 (設置自增序列的初始值為1)
nomaxvalue (不限制自增序列的最大值)
minvalue 1; (設置自增序列的最小值為1)
3.試用一下,向BOOK表中插入一條數(shù)據(jù),Id列就引用了自增序列。
insert into BOOK values(BOOK_seq.nextval,'a','a','a','a',32.1,'a',
'a','1.jpg');
注意:
操作之后記得輸入“commit;“保存操作。
Oracle數(shù)據(jù)庫的的命令行創(chuàng)建表,系統(tǒng)會自動轉化為大寫字母,假如使用數(shù)據(jù)庫操作客戶端,那么建表等操作時記得字段名大寫。
-----oracle 指定字段 自增 ,1.要先創(chuàng)建一個序列 2. 之后創(chuàng)建一個觸發(fā)器
--- 序列 (序列與觸發(fā)器實現(xiàn)t_sys_organize表中F_ID字段的自動增長)
create sequence t_sys_organize_F_ID_SEQUENCE
minvalue 100000
maxvalue 99999999
start with 100000
increment by 1
nocache;
--觸發(fā)器 (序列與觸發(fā)器實現(xiàn)t_sys_organize表中F_ID字段的自動增長)
CREATE OR REPLACE TRIGGER t_sys_organize_F_ID_TRIGGER BEFORE INSERT ON t_sys_organize FOR EACH ROW WHEN(NEW.F_ID IS NULL)
BEGIN
SELECT t_sys_organize_F_ID_SEQUENCE.NEXTVAL INTO:NEW.F_ID FROM dual;
END;