MySQL UUID_SHORT() 给出错误 Out of range value for column

标签 mysql uuid bigint

我在 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

最佳答案

BIGINTBIGINT 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/

相关文章:

Python - 1000-2000 个 API 请求

php - 在 echo php 表上使用 css

mysql - 本地开发joomla与远程数据库

uuid - 如何在 Ada 中生成唯一 ID?

php - 选择 * 不同的地方

random -/proc/sys/kernel/random/uuid 是强 key Material 吗?

arrays - uuid 数组上的 PostgreSQL GIN 索引

sql - PostgreSQL 总和类型转换为 bigint

sql - 无法应用于 Athena 中的 bigint、varchar

javascript - 在 Javascript 中将 BigInteger 转换为 Int64