婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > PostgreSQL三種自增列sequence,serial,identity的用法區(qū)別

PostgreSQL三種自增列sequence,serial,identity的用法區(qū)別

熱門標(biāo)簽:電話機(jī)器人怎么換人工座席 廣州電銷機(jī)器人公司招聘 400電話申請(qǐng)客服 電銷機(jī)器人能補(bǔ)救房產(chǎn)中介嗎 天津開發(fā)區(qū)地圖標(biāo)注app 江蘇400電話辦理官方 移動(dòng)外呼系統(tǒng)模擬題 地圖標(biāo)注要花多少錢 濟(jì)南外呼網(wǎng)絡(luò)電話線路

這三個(gè)對(duì)象都可以實(shí)現(xiàn)自增,這里從如下幾個(gè)維度來看看這幾個(gè)對(duì)象有哪些不同,其中功能性上看,大部分特性都是一致的或者類似的。

1、sequence在所有數(shù)據(jù)庫中的性質(zhì)都一樣,它是跟具體的字段不是強(qiáng)綁定的,其特點(diǎn)是支持多個(gè)對(duì)個(gè)對(duì)象之間共享。

sequence作為自增字段值的時(shí)候,對(duì)表的寫入需要另外單獨(dú)授權(quán)sequence(GRANT USAGE ON SEQUENCE test_old_id_seq;)

sequence類型的字段表,在使用CREATE TABLE new_table LIKE old_table的時(shí)候,新表的自增字段會(huì)已久指向原始表的sequence

結(jié)論:

對(duì)于自增字段,無特殊需求的情況下,sequence不適合作為“自增列”,作為最最次選。

2、identity本質(zhì)是為了兼容標(biāo)準(zhǔn)sql中的語法而新加的,修復(fù)了一些serial的缺陷,比如無法通過alter table的方式實(shí)現(xiàn)增加或者刪除serial字段

2.1 identity定義成generated by default as identity也允許顯式插入,

2.2 identity定義成always as identity,加上overriding system value也可以顯式不插入

結(jié)論:

identity是serial的“增強(qiáng)版”,更適合作為“自增列”使用。

3、sequence,serial,identity共同的缺點(diǎn)是在顯式插入之后,無法將自增值更新為表中的最大Id,這一點(diǎn)再顯式插入的情況下是潛在自增字段Id沖突的

結(jié)論:

自增列在顯式插入之后,一定要手動(dòng)重置為表的最大Id。

4、自增字段的update沒有細(xì)看,相對(duì)來說自增列的顯式插入是一種常規(guī)操作,那些對(duì)自增列的update操作,只要腦子沒問題,一般是不會(huì)這么干的。

原始手稿,懶得整理了,不涉及原理性的東西,動(dòng)手試一遍就明白了。

---------------------------------------------------------sequence-------------------------------------------------------------
create sequence myschema.seq_1 INCREMENT BY 1 MINVALUE 1 START WITH 1;
create table myschema.test_seq
(
 id int not null default nextval('myschema.seq_1') primary key,
 name varchar(10)
);
隱式插入
insert into myschema.test_seq (name) values ('aaa');
insert into myschema.test_seq (name) values ('bbb');
insert into myschema.test_seq (name) values ('ccc');
select * from myschema.test_seq;
顯式插入
insert into myschema.test_seq (id,name) values (5,'ddd');
select * from test_seq;
再次隱式插入
--可以正常插入
insert into myschema.test_seq (name) values ('eee');
--插入失敗,主鍵重復(fù),因?yàn)樾蛄凶陨硎沁f增的,不會(huì)關(guān)心表中被顯式插入的數(shù)據(jù)
insert into myschema.test_seq (name) values ('fff');
--重置序列的最大值
select setval('myschema.seq_1',(select max(id) from myschema.test_seq)::BIGINT);
--事務(wù)回滾后,序列號(hào)并不會(huì)回滾
begin;
insert into myschema.test_seq (name) values ('ggg');
rollback;
-- truncate 表之后,序列不受影響
truncate table myschema.test_seq;
--重置序列
ALTER SEQUENCE myschema.seq_1 RESTART WITH 1;
---------------------------------------------------------serial-------------------------------------------------------------
create table myschema.test_serial
(
 id serial primary key,
 name varchar(100)
)
select * from test_serial;
insert into myschema.test_serial(name) values ('aaa');
insert into myschema.test_serial(name) values ('bbb');
insert into myschema.test_serial(name) values ('ccc');
select * from myschema.test_serial;
--顯式插入,可以執(zhí)行
insert into myschema.test_serial(id,name) values (5,'ccc');
--再次隱式插入,第二次會(huì)報(bào)錯(cuò),因?yàn)殡[式插入的話,serial會(huì)基于顯式插入之前的Id做自增,serial無法意識(shí)到當(dāng)前已經(jīng)存在的最大值
insert into myschema.test_serial(name) values ('xxx');
insert into myschema.test_serial(name) values ('yyy');
select * from myschema.test_serial;
--truncate table 后serial不會(huì)重置
truncate table myschema.test_serial;
insert into myschema.test_serial(name) values ('aaa');
insert into myschema.test_serial(name) values ('bbb');
insert into myschema.test_serial(name) values ('ccc');
select * from myschema.test_serial;
--驗(yàn)證是否會(huì)隨著事務(wù)一起回滾,結(jié)論:不會(huì)
begin;
insert into myschema.test_serial(name) values ('yyy');
rollback;
--重置serial,需要注意的是重置的Id必須要大于相關(guān)表的字段最大Id,否則會(huì)產(chǎn)生重號(hào)
SELECT SETVAL((SELECT pg_get_serial_sequence('myschema.test_serial', 'id')), 1, false);
---------------------------------------------------------identity-------------------------------------------------------------
drop table myschema.test_identiy_1 
create table myschema.test_identiy_1 
(
 id int generated always as identity (cache 100 START WITH 1 INCREMENT BY 1) primary key , 
 name varchar(100)
);
create table myschema.test_identiy_2
(
 id int generated by default as identity (cache 100 START WITH 1 INCREMENT BY 1) primary key , 
 name varchar(100)
);
insert into myschema.test_identiy_1(name) values ('aaa');
insert into myschema.test_identiy_1(name) values ('bbb');
insert into myschema.test_identiy_1(name) values ('ccc');
insert into myschema.test_identiy_2(name) values ('aaa');
insert into myschema.test_identiy_2(name) values ('bbb');
insert into myschema.test_identiy_2(name) values ('ccc');
select * from myschema.test_identiy_1;
--顯式插入值,如果定義為generated always as identity則不允許顯式插入,除非增加overriding system value 提示
--一旦提示了overriding system value,可以
insert into myschema.test_identiy_1(id,name) values (5,'ccc');
insert into myschema.test_identiy_1(id,name)overriding system value values (5,'ccc');
select * from myschema.test_identiy_2;
--顯式插入值,如果定義為generated by default as identity則允許顯式插入,
insert into myschema.test_identiy_2(id,name) values (5,'ccc');
--顯式插入后,繼續(xù)隱式插入,第二次插入會(huì)報(bào)錯(cuò),identity已久是不識(shí)別表中顯式插入后的最大值
insert into myschema.test_identiy_2(name) values ('xxx');
insert into myschema.test_identiy_2(name) values ('yyy');
select * from myschema.test_identiy_2;
總之個(gè)identity很扯淡,你定義成always as identity,加上overriding system value可以顯式不插入
定義成generated by default as identity也允許顯式插入
不管怎么樣,既然都允許顯式插入,那扯什么淡的來個(gè)overriding system value
--truncate后再次插入,自增列不會(huì)重置
truncate table myschema.test_identiy_1;
select * from myschema.test_identiy_1;
begin;
insert into myschema.test_identiy_1(name) values ('xxx');
rollback;
--truncate并且RESTART IDENTITY后,會(huì)重置自增列
TRUNCATE table myschema.test_identiy_1 RESTART IDENTITY;
select * from myschema.test_identiy_1
--identity自增列的重置表或者更改
ALTER TABLE myschema.test_identiy_1 ALTER COLUMN id RESTART WITH 100;

實(shí)際中更改identity自增長列的當(dāng)前起始值(已有的最大值+1):

補(bǔ)充:PostgreSQL不同的表使用不同的自增序列

hibernate 配置文件里面應(yīng)該是這樣的:

id name="id">
  generator class="sequence">
  param name="sequence">adminuser/param>
  /generator>
 /id>

使用xdoclet時(shí) 類里面的配置應(yīng)該是這樣的:

/**
 * @hibernate.id generator-class="sequence"
 * @hibernate.generator-param name="sequence" value="adminuser"
 */
 
 private int id;

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • postgresql數(shù)據(jù)合并,多條數(shù)據(jù)合并成1條的操作
  • postgresql數(shù)據(jù)添加兩個(gè)字段聯(lián)合唯一的操作
  • postgreSQL使用pgAdmin備份服務(wù)器數(shù)據(jù)的方法
  • postgreSQL查詢結(jié)果添加一個(gè)額外的自增序列操作
  • PostgreSQL 實(shí)現(xiàn)sql放入文件批量執(zhí)行
  • PostgreSQL對(duì)GROUP BY子句使用常量的特殊限制詳解

標(biāo)簽:溫州 海西 榆林 杭州 寶雞 昭通 濮陽 辛集

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PostgreSQL三種自增列sequence,serial,identity的用法區(qū)別》,本文關(guān)鍵詞  PostgreSQL,三種,自,增列,sequence,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PostgreSQL三種自增列sequence,serial,identity的用法區(qū)別》相關(guān)的同類信息!
  • 本頁收集關(guān)于PostgreSQL三種自增列sequence,serial,identity的用法區(qū)別的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲国产视频一区二区| 国产精品亚洲一区二区三区在线 | 色综合色综合色综合色综合色综合| 精品少妇一区二区三区| 99re这里都是精品| 喷水一区二区三区| 亚洲影院理伦片| 久久综合色婷婷| 国产精品一区二区久久不卡| 久久九九99视频| 精品美女在线播放| 亚洲欧美一区二区视频| 久久久精品影视| 亚洲地区一二三色| 日本欧美韩国一区三区| 久久亚洲欧美国产精品乐播| 日韩欧美国产电影| 国产精品不卡在线| 亚洲国产日韩a在线播放性色| 加勒比av一区二区| 国产亚洲女人久久久久毛片| 亚洲成a天堂v人片| 欧美三级电影网| 亚洲成人免费观看| 在线区一区二视频| 一区二区三区欧美日| 精品久久人人做人人爱| 久久精品一二三| 一区二区三区精品久久久| 久久久久久97三级| 久久午夜羞羞影院免费观看| 色综合久久99| 日本亚洲一区二区| 亚洲高清免费观看高清完整版在线观看| 亚洲视频一区在线| 日本亚洲最大的色成网站www| 国产精品资源在线观看| 欧美日韩一卡二卡三卡 | 一区二区三区精品视频在线| 日本中文字幕不卡| 色哟哟亚洲精品| 亚洲麻豆国产自偷在线| 亚洲午夜久久久久久久久电影院| 成人综合婷婷国产精品久久蜜臀 | 91一区二区三区在线观看| 久久久久久久免费视频了| 日韩国产成人精品| 欧美在线观看禁18| 国产精品久久久久久久久动漫 | 国产一区二区三区最好精华液| 精品少妇一区二区三区在线播放| 亚洲一级在线观看| av亚洲精华国产精华精华| 欧美国产精品一区| 国产精品一区二区久激情瑜伽| 在线不卡a资源高清| 亚洲激情第一区| 精品视频一区 二区 三区| 亚洲视频香蕉人妖| 色偷偷成人一区二区三区91| 亚洲精品视频观看| 欧美精品v国产精品v日韩精品| 亚洲大片一区二区三区| 337p亚洲精品色噜噜| 蜜桃久久av一区| 欧美激情一区二区三区蜜桃视频 | 亚洲高清不卡在线观看| 欧美肥妇bbw| 国产自产高清不卡| 国产精品女人毛片| 欧美人动与zoxxxx乱| 蜜桃av一区二区| 亚洲chinese男男1069| 国产精品综合一区二区三区| 国产日韩欧美一区二区三区乱码| 久久只精品国产| 粉嫩嫩av羞羞动漫久久久 | 国产成人自拍高清视频在线免费播放| 丝袜美腿亚洲色图| 天堂av在线一区| 免费在线观看一区| 亚洲国产欧美日韩另类综合| 日韩欧美在线网站| 3d动漫精品啪啪一区二区竹菊| 欧美亚洲一区二区三区四区| 91香蕉视频mp4| 国产91精品免费| 国产成人精品亚洲午夜麻豆| 在线观看成人小视频| 成人小视频在线| 国产又黄又大久久| 日韩电影一区二区三区四区| 国产欧美日韩亚州综合| 欧美精选午夜久久久乱码6080| 成人午夜激情在线| 日韩成人一级大片| 亚洲激情网站免费观看| 国产精品久久久久影视| 在线电影欧美成精品| 欧美揉bbbbb揉bbbbb| 国产福利不卡视频| 久久精品欧美日韩精品| 在线免费观看不卡av| 在线观看亚洲专区| 色综合久久中文字幕综合网| 韩国成人在线视频| 日本在线不卡一区| 波多野结衣一区二区三区| 99国产一区二区三精品乱码| a级精品国产片在线观看| 91丨九色丨蝌蚪富婆spa| 国产91高潮流白浆在线麻豆| 亚洲成av人综合在线观看| 午夜视频在线观看一区二区 | 国产成人日日夜夜| av一二三不卡影片| 欧美日本高清视频在线观看| 日韩亚洲欧美高清| 国产精品久久久久久一区二区三区| 99精品一区二区三区| 不卡欧美aaaaa| 日韩欧美自拍偷拍| 中文字幕欧美一区| 久久91精品久久久久久秒播| 99视频一区二区三区| 欧美一级视频精品观看| 日韩精品一二三| 欧美午夜精品电影| 亚洲综合视频在线| 国产精品99精品久久免费| 色综合色狠狠综合色| 国产精品久久久久久福利一牛影视| 日韩免费视频一区| 欧美一区二区免费视频| 成人在线一区二区三区| 欧美电影一区二区三区| 欧美一区二区三区在线电影| 91亚洲精品乱码久久久久久蜜桃| 亚洲欧美自拍偷拍色图| 亚洲美女精品一区| 久久免费午夜影院| 中文字幕一区二区三区四区不卡| 国产精品久久国产精麻豆99网站| 久久精品国产免费| 五月天视频一区| 91免费国产视频网站| 在线亚洲高清视频| 8v天堂国产在线一区二区| 正在播放一区二区| 人人超碰91尤物精品国产| 国产一区日韩二区欧美三区| 在线亚洲一区二区| 午夜影院久久久| 欧美顶级少妇做爰| 精彩视频一区二区三区| 狠狠v欧美v日韩v亚洲ⅴ| 日韩精品成人一区二区在线| 中文字幕在线观看一区二区| 国内精品嫩模私拍在线| 精品国产三级电影在线观看| 图片区小说区区亚洲影院| 国产精品538一区二区在线| 欧美日韩视频一区二区| 夜夜爽夜夜爽精品视频| 在线一区二区三区四区五区 | 狠狠色丁香婷综合久久| 91麻豆精品国产91久久久久久久久 | 在线成人小视频| 成人av在线网站| 91原创在线视频| 一本大道久久a久久精品综合| 亚洲自拍偷拍综合| 99视频精品免费视频| 久久久精品一品道一区| 久久99精品久久久久| 91免费在线看| 国内精品伊人久久久久影院对白| 中文av一区二区| 国产亚洲欧美一级| 欧美成人三级在线| 欧美精品在欧美一区二区少妇| 成人午夜视频在线| 蜜臀a∨国产成人精品| 亚洲一区二区三区中文字幕在线| 国产亚洲一二三区| 2021中文字幕一区亚洲| 欧美一区日本一区韩国一区| 91精选在线观看| 国产福利不卡视频| 综合激情成人伊人| 久久久久九九视频| 91免费在线播放| 久久亚洲精精品中文字幕早川悠里 | 日韩国产精品大片| 国产呦精品一区二区三区网站| 美女精品一区二区| 亚洲精品久久久久久国产精华液| 久久亚洲精品国产精品紫薇| 欧美国产精品劲爆| 91精品国产欧美一区二区18|