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
相关推荐
程序员是干活的7 小时前
私家车开车回家过节会发生什么事情
java·开发语言·软件构建·1024程序员节
ZhongruiRao1 天前
Springboot+PostgreSQL+MybatisPlus存储JSON或List、数组(Array)数据
spring boot·postgresql·json
x-cmd1 天前
[241005] 14 款最佳免费开源图像处理库 | PostgreSQL 17 正式发布
数据库·图像处理·sql·安全·postgresql·开源·json
AI人H哥会Java1 天前
【PostgreSQL】实战篇——使用 PostgreSQL 进行数据分析与报表生成
数据库·sql·postgresql
文牧之2 天前
PostgreSQL 和Oracle 表压缩的对比
运维·数据库·postgresql·oracle
踩着阴暗的自己向上爬2 天前
Day01-postgresql数据库基础入门培训
数据库·postgresql
PGCCC2 天前
【PGCCC】从 PostgreSQL 表恢复已删除的数据 | 翻译
数据库·postgresql
老年DBA3 天前
postgresql-重复执行相同语句,试试 prepare!
数据库·postgresql
music score3 天前
Ubuntu编译fftw3
linux·ubuntu·postgresql
AI人H哥会Java4 天前
【PostgreSQL】入门篇——索引:提高查询性能的利器
数据库·sql·postgresql