2

在数据库(MySql)中,我正在存储一些字符串值并在存储它们之前检查这些字符串的唯一性。

对于快速字符串比较(我的意思是在记录之前检查传入的字符串是否已经存在于数据库中)我想拥有传入的字符串(MD5),将字符串分成2等份,将它们转换为2个bigint,将它们分开存储使用字符串,当记录请求到达时,我想在多列索引中搜索这两个 bigint。(当然我会得到传入的字符串,MD5那个字符串,计算2个bigint部分然后查询数据库)

但是下面的“第 3 行”在我的“MySql 例程”中产生了一个有趣的错误。

...
declare mystring varchar(3000); -- line 1
declare md5bigint1value bigint; -- line 2
...

set md5bigint1value = conv(substring((md5(mystring)),1,16),16,10); -- line 3
...

在“第 3 行”它说:错误代码:1264。第 1 行的列“md5bigint1value”的值超出范围

有谁知道为什么会这样?

如果您需要更多信息,请告诉我。非常感谢。

4

1 回答 1

4

CONV与正 to_base 一起使用时,转换为无符号值,而BIGINT有符号。无符号 64 位值不一定适合有符号 64 位变量。

如果 to_base 为负数,则将 N 视为有符号数。否则,N 被视为无符号。

您要做的是-10用于目标基地,即;

set md5bigint1value = conv(substring((md5(mystring)),1,16),16,-10); -- line 3

用于测试的 SQLfiddle(10 不起作用,-10 会)。

于 2013-04-11T18:01:57.477 回答