大连做网站哪里好,关键词完整版,网站开发google,qq官网首页登录背景#xff1a;某个表没有主键#xff0c;但是有个字段名称#xff08;varchar类型#xff09;是唯一的#xff0c;而一般习惯用BIGINT作为主键#xff0c;于是想到将名称转成BIGINT主键。
考虑到#xff1a;数字转文本我们常用md5算法#xff0c;那么是否能用类似的…背景某个表没有主键但是有个字段名称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))::BIGINT1000000000000000;
-- 1000000493687159A123456SELECT ABS(HASHTEXT(A1234567))::BIGINT1000000000000000;
-- 1000001713566073A1234567