我在 Amazon Web Services RDS 上使用 MySQL 5.6.17,当调用 SELECT UUID_SHORT() 时,我得到的数字大于 9223372036854775807。例如我得到的数字是
12057145185130250250
问题出在我的表中,我有一个未签名的 BIGINT(20) 列,但是当存储数字时 12057145185130250250 我收到错误 MySQL 22003
'MySQL 22003 Out of range value for column '' at row 1'
如果我在我们的测试服务器 MySQL 5.6.11(在 Windows 2008 64x 上运行)上运行 SELECT UUID_SHORT()
,结果如下;
23526798209843216
我将要保存我的号码的列更改为未签名的 BIGINT(20),但仍然出现此错误。
有什么想法吗?
更新
在我最初的帖子中,我发现如果我使用 Workbench 编辑器手动将值“12057145185130250250”插入到 BIGINT(20) 列中,它可以很好地保存。
但是,如果我使用如下所示的存储过程保存值,这就是我遇到问题的时候;
DELIMITER $$
CREATE DEFINER=`testaccount`@`%` PROCEDURE `CreateCustomer`(iUserId
INTEGER, sPassword VARCHAR(75))
BEGIN
DECLARE iSalt BIGINT;
SELECT UUID_SHORT() INTO iSalt;
INSERT INTO UserCustomer
(
UserId,
Password,
Salt
)
VALUES
(
iUserId,
SHA2(CONCAT(iSalt,sPassword), 256),
iSalt
);
END
最佳答案
BIGINT
和 BIGINT UNSIGNED
不一样。除非显式未签名,否则所有整数数据类型都是有符号的。
而且,UUID_SHORT()
旨在生成唯一但非随机、不可预测且始终递增的值,这对于盐来说似乎是一个特别糟糕的选择,不是吗?
...特别是因为 RANDOM_BYTES()
函数是在 5.6.17 中引入的。
http://dev.mysql.com/doc/refman/5.6/en/encryption-functions.html#function_random-bytes
关于MySQL UUID_SHORT() 给出错误 Out of range value for column,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24324548/