当前位置:首页 > 编程笔记 > 正文
已解决

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

来自网友在路上 181881提问 提问时间:2023-10-25 11:04:21阅读次数: 81

最佳答案 问答题库818位专家为你答疑解惑

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

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

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

-- 将长整型转换成固定的文本
SELECT md5('123456');
-- e10adc3949ba59abbe56e057f20f883eSELECT 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,A123456SELECT ABS(HASHTEXT('A1234567'))::BIGINT+1000000000000000;
-- 1000001713566073,A1234567
查看全文

99%的人还看了

猜你感兴趣

版权申明

本文"PostgreSQL将文本转换成固定的长整型":http://eshow365.cn/6-24134-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!