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
相关推荐
Lupino16 分钟前
构建现代化的 Python PostgreSQL 工具库:psql_utils 的重构与优化之旅
python·postgresql
Chef_Chen1 小时前
数据科学每日总结--Day41--ubuntu安装tailscale
数据库·ubuntu·postgresql
扫地的小何尚11 小时前
NVIDIA RTX PC开源AI工具升级:加速LLM和扩散模型的性能革命
人工智能·python·算法·开源·nvidia·1024程序员节
柠檬叶子C13 小时前
PostgreSQL 忘记 postgres 密码怎么办?(已解决)
数据库·postgresql
光蛋15 小时前
PostgreSQL 显式锁定:从原理到实践(趣味版)
postgresql
2301_8002561116 小时前
数据库设计中的 “数据依赖→设计异常→关系分解(范式)” 核心逻辑
数据库·postgresql
码间拾光・菲林斯16 小时前
PostgreSQL 微服务架构开发实战:数据一致性、多租户设计与框架集成
微服务·postgresql·架构
IvorySQL17 小时前
PostgreSQL 的 SQL 查询之旅
数据库·人工智能·postgresql·开源
TimerShaft1 天前
CentOS7安装PostgresSQL和PGVector
postgresql·centos·pgvector
2301_800256111 天前
R-Tree创建与遍历,R-Tree在4类空间查询中的应用,实现4类空间查询的各类算法[第8章]
数据库·算法·机器学习·postgresql·r-tree