在数据库(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”的值超出范围
有谁知道为什么会这样?
如果您需要更多信息,请告诉我。非常感谢。