佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > postgresql重置序列起始值的操作

postgresql重置序列起始值的操作

熱門標簽:百度競價排名 網(wǎng)站排名優(yōu)化 服務(wù)外包 呼叫中心市場需求 鐵路電話系統(tǒng) Linux服務(wù)器 AI電銷 地方門戶網(wǎng)站

我就廢話不多說了,大家還是直接看代碼吧~

-- 序列重置到1000
alter sequence sequence_name restart with 1000
-- 驗證
SELECT nextval('sequence_name');

補充:postgresql重置序列和自增主鍵

1. 問題背景

數(shù)據(jù)表中插入了幾條測試數(shù)據(jù),后又手動刪除,導(dǎo)致后面插入數(shù)據(jù)的時候報主鍵沖突:

 ERROR: duplicate key value violates unique constraint "tableName_pkey"
DETAIL: Key (id)=(1) already exists.

即使采用INSERT IGNORE的方式或者REPLACE INTO的方式還是報錯,所以就想著重置自增序列和主鍵。

2. 解決辦法

2.1 方法一

(1)重置序列起始值為1

alter sequence xxx_id_seq restart with 1

(2)查看當前序列

SELECT nextval('xxx_id_seq ');

(3)重置自增主鍵

TRUNCATE tableName RESTART IDENTITY;

2.2 方法二

(1)清除所有的記錄

TRUNCATE tablename questions CASCADE;

(2)清除所有的記錄,并且索引號從0開始

TRUNCATE tablename questions RESTART IDENTITY CASCADE;

2.3 方法三

也有可能是自增主鍵和序列不一致導(dǎo)致的,所以也可以不用重置序列起始值和主鍵,采取把序列號改成和當前最大主鍵一致的方式:

select setval('xxx_id_seq', max(id)) from tableName;

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

您可能感興趣的文章:
  • PostgreSQL Sequence序列的使用詳解
  • postgresql 中的序列nextval詳解
  • PostgreSQL 序列綁定字段與不綁定字段的區(qū)別說明
  • PostgreSQL 序列增刪改案例
  • postgresql 實現(xiàn)更新序列的起始值
  • postgresql修改自增序列操作
  • Postgresql數(shù)據(jù)庫之創(chuàng)建和修改序列的操作

標簽:銅川 黃山 仙桃 湘潭 蘭州 衡水 湖南 崇左

巨人網(wǎng)絡(luò)通訊聲明:本文標題《postgresql重置序列起始值的操作》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    福海县| 延川县| 宝坻区| 遂川县| 湄潭县| 孟连| 饶阳县| 庄河市| 张家口市| 正镶白旗| 通州市| 农安县| 兰州市| 河南省| 武城县| 靖州| 三明市| 恩施市| 肃南| 新乡县| 渭源县| 抚宁县| 嘉善县| 罗平县| 全椒县| 五家渠市| 通道| 海晏县| 信阳市| 天台县| 新乡县| 东阳市| 进贤县| 侯马市| 门源| 同德县| 东兴市| 舒城县| 姚安县| 尼勒克县| 菏泽市|