PostgreSQL将文本转换成固定的长整型

背景:某个表没有主键,但是有个字段名称(varchar类型)是唯一的,而一般习惯用BIGINT作为主键,于是想到将名称转成BIGINT主键。

考虑到:数字转文本我们常用md5算法,那么是否能用类似的方法实现这个需求?

然后再到了HASHTEXT方法,详见下面示例。

sql 复制代码
-- 将长整型转换成固定的文本
SELECT md5('123456');
-- e10adc3949ba59abbe56e057f20f883e

SELECT md5('A123456');
-- 507f513353702b50c145d5b7d138095c

-- 比如:用序列生成一些字符串可以这样:
SELECT id,md5(id::varchar) from generate_series(1, 2) id;
--1	c4ca4238a0b923820dcc509a6f75849b
--2	c81e728d9d4c2f636f067f89cc14862c


-- 将文本转换成固定的长整型
SELECT HASHTEXT('A123456');
-- 493687159
SELECT ABS(HASHTEXT('A123456'))::BIGINT;
-- 493687159

-- 为了好看点,可以加个固定值
SELECT ABS(HASHTEXT('A123456'))::BIGINT+1000000000000000;
-- 1000000493687159,A123456

SELECT ABS(HASHTEXT('A1234567'))::BIGINT+1000000000000000;
-- 1000001713566073,A1234567
相关推荐
yBmZlQzJ6 小时前
财运到内网穿透域名解析技术机制与中立评估
运维·经验分享·docker·容器·1024程序员节
yBmZlQzJ8 小时前
内网穿透工具通过端口转发实现内外网通信
运维·经验分享·docker·容器·1024程序员节
兴趣互联12 小时前
PostgresSQL数据库如何使用navicat创建分区表
数据库·postgresql
l1t19 小时前
修改一个触发PostgreSQL 17.2 bug的SQL
sql·postgresql·bug
运维行者_19 小时前
不同规模企业如何选 OPM?参考局域网管理软件与 cpu 温度监控适配指南
大数据·运维·服务器·网络·数据库·postgresql·snmp
数据皮皮侠AI19 小时前
数字经济政策工具变量数据(2008-2023)
大数据·数据库·人工智能·笔记·1024程序员节
IvorySQL1 天前
Postgres 18 默认开启数据校验及升级应对方案
数据库·人工智能·postgresql·开源
斯普信专业组1 天前
PostgreSQL高可用集群部署与配置指南
数据库·postgresql
网安_秋刀鱼2 天前
【java安全】shiro反序列化1(shiro550)
java·开发语言·安全·web安全·网络安全·1024程序员节
IvanCodes2 天前
openGauss 核心体系架构深度解析
数据库·sql·postgresql·openguass