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
相关推荐
睡不醒男孩03082313 小时前
数据库高可用运维实操指南:基于CLup的PostgreSQL生产环境自动化管理
运维·数据库·postgresql
本地化文档20 小时前
psycopg3-docs-l10n
数据库·python·postgresql·github·gitcode·sphinx
J.Kuchiki21 小时前
【PostgreSQL内核学习 —— 外部排序生成与归并】
数据库·学习·postgresql
Amctwd1 天前
【SQL】PostgreSQL 转存 SQLite 用于数据分析
sql·postgresql·sqlite
A-刘晨阳1 天前
数据库挂了服务就瘫?我用PostgreSQL主从流复制搭了高可用架构,cpolar打通远程访问
数据库·postgresql·架构
IvorySQL1 天前
PostgreSQL 技术日报 (6月4日)|SQL/PGQ 新特性,逻辑复制持续优化
数据库·sql·postgresql
数据皮皮侠AI1 天前
中国土地利用驱动因子数据集(9种驱动因子/裁剪到省市/Tif)
大数据·人工智能·笔记·能源·1024程序员节
J.Kuchiki1 天前
【PostgreSQL内核学习:Unique 算子源码深度解读学习】
数据库·学习·postgresql
暴躁小师兄数据学院1 天前
【AI大数据工程师特训笔记】第12讲:表分区与索引
大数据·笔记·sql·postgresql