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
相关推荐
IT小辉同学5 小时前
PostgreSQL 与 MySQL 获取字段注释并转换为驼峰命名教程
数据库·mysql·postgresql
有想法的py工程师8 小时前
PostgreSQL 查询库中所有表占用磁盘大小、表大小
数据库·postgresql
九皇叔叔12 小时前
【9】PostgreSQL 之 vacuum 死元组清理
数据库·postgresql
鼠鼠我捏,要死了捏3 天前
PostgreSQL性能优化实践指南:从原理到实战
postgresql·performance·tuning
云游3 天前
利用外部Postgresql及zookeeper,启动Apache Dolphinscheduler3.1.9
分布式·postgresql·zookeeper·apache·工作流任务调度
__风__4 天前
PostgreSQL kv(jsonb)存储
数据库·postgresql
九皇叔叔5 天前
【7】PostgreSQL 事务
数据库·postgresql
lzb_kkk5 天前
【C++】C++四种类型转换操作符详解
开发语言·c++·windows·1024程序员节
ldj20206 天前
2025 Centos 安装PostgreSQL
linux·postgresql·centos
坤坤不爱吃鱼8 天前
【MySQL\Oracle\PostgreSQL】迁移到openGauss数据出现的问题解决方案
mysql·postgresql·oracle