本篇文章小编给大家分享一下在PostgreSQL中设置表中某列值自增或循环方式代码示例,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
在postgresql中,设置已存在的某列(num)值自增,可以用以下方法:
//将表tb按name排序,利用row_number() over()查询序号并将该列命名为rownum,创建新表tb1并将结果保存到该表中 create table tb1 as (select *, row_number() over(order by name) as rownum from tb); //根据两张表共同的字段name,将tb1中rownum对应值更新到tb中num中 update tb set num=(select tb1.rownum from tb1 where tb.name = tb1.name); //判断表tb1的存在并删除表 drop table if exists tb1;
在postgresql中,循环设置已存在的某列(num)值为0-9,可以用以下方法:
//将表tb按name排序,利用row_number() over()查询序号并将该列命名为rownum,创建新表tb1并将结果保存到该表中 create table tb1 as (select *, row_number() over(order by name) as rownum from tb); //根据两张表共同的字段name,将tb1中rownum对应值更新到tb中num中,由于为0-9循环自增,则%10 update tb set num=(select tb1.rownum from tb1 where tb.name = tb1.name) % 10; //判断表tb1的存在并删除表 drop table if exists tb1;
其它:附录一个postgresql循环的写法(与上文无关)
do $$ declare v_idx integer :=0; begin while v_idx < 10 loop update tb set num = v_idx; v_idx = v_idx + 1; end loop; end $$;
补充:postgreSQL SQL语句创建自增表
方法一:postgreSQL通过将字段类型设置为serial来将表设计为自增表
CREATE TABLE t_achievement_directory ( id serial8 PRIMARY KEY, directory_name varchar(255) COLLATE "pg_catalog"."default", pid int8, modify_time timestamp(6) ) ;
方法二:GENERATED BY ALWAYS AS IDENTITY 或 GENERATED BY DEFAULT AS IDENTITY
id int8 NOT NULL GENERATED BY DEFAULT AS IDENTITY
或
id int8 NOT NULL GENERATED ALWAYS AS IDENTITY
这两种方式的区别在于:
generated always as identity 总是按照(START WITH 1 INCREMENT BY 1)的方式插入数据,并维护索引。即不允许用户向id列指定数据插入。
但是 generated by default as identity 则是在用户不指定id列值的情况下按照(START WITH 10 INCREMENT BY 10)方式插入数据,如果用户指定,则依然按照指定的值插入。
火柴人绳索英雄2无限金币版 (Stickman Rope Hero 2)安卓版v2.2v3.4.2
下载奥特曼之格斗超人内测版本 安卓最新版v11.0.0
下载奥特曼之格斗超人百度版 安卓版v11.0.0
下载奥特曼之格斗超人4399游戏盒版 最新安卓版v11.0.0
下载德凯奥特曼D闪光剑模拟器 安卓版v1.0
德凯奥特曼D闪光剑模拟器是一个非常有趣的奥特曼变身模拟器,可
亚刻觉醒器 安卓版v1.1
亚刻觉醒器模拟器是一个非常有趣的奥特曼变身模拟器,为喜欢亚刻
海上餐厅无限金币版 v1.0
海上餐厅免广告版是游戏的破解版本,在该版本中为玩家去除了广告
阿西美女室友竟然全解锁版 v1.0.2
阿西美女室友竟然内置菜单版是游戏的破解版本,在该版本中为玩家
我是大东家正版 最新版v1.2.738
我是大东家正版是一款放置类模拟经营手游,玩家将回到古代成为家