PostgreSQL common
This commit is contained in:
@@ -21,3 +21,36 @@ ALTER DATABASE fortern REFRESH COLLATION VERSION;
|
|||||||
|
|
||||||
REINDEX DATABASE kt_shop;
|
REINDEX DATABASE kt_shop;
|
||||||
ALTER DATABASE kt_shop REFRESH COLLATION VERSION;
|
ALTER DATABASE kt_shop REFRESH COLLATION VERSION;
|
||||||
|
|
||||||
|
-- 重置某表的某列的自增序列 [表名]_[列名]_seq
|
||||||
|
ALTER SEQUENCE person_id_seq RESTART WITH 4284858;
|
||||||
|
|
||||||
|
-- ctid 会返回一个元组,元组中第一个数字是 page number, 第二个是 slot number。
|
||||||
|
select r.ctid, r.* from study.r;
|
||||||
|
-- 得到
|
||||||
|
-- "(0,1)",1,101
|
||||||
|
-- "(0,2)",2,102
|
||||||
|
-- "(0,3)",3,103
|
||||||
|
|
||||||
|
-- 删除一条
|
||||||
|
delete from study.r where id = 2;
|
||||||
|
-- 再重新查询,得到
|
||||||
|
-- "(0,1)",1,101
|
||||||
|
-- "(0,3)",3,103
|
||||||
|
-- PostgreSQL 会保留空槽
|
||||||
|
|
||||||
|
-- 插入新数据
|
||||||
|
insert into study.r values (104, 4);
|
||||||
|
-- 再重新查询,得到
|
||||||
|
-- "(0,1)",1,101
|
||||||
|
-- "(0,3)",3,103
|
||||||
|
-- "(0,4)",4,104
|
||||||
|
-- 可以看到使用了末尾的新槽位,而不是使用中间的新槽位
|
||||||
|
|
||||||
|
-- 执行清理
|
||||||
|
vacuum full study.r;
|
||||||
|
-- 再次扫面,得到
|
||||||
|
-- "(0,1)",1,101
|
||||||
|
-- "(0,2)",3,103
|
||||||
|
-- "(0,3)",4,104
|
||||||
|
-- 看到空间已经回收
|
||||||
|
|||||||
Reference in New Issue
Block a user