gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 08:47:26 25 4
gpt4 key购买 nike

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

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com