在User-Defined Variables下,MySQL 手册文档:
可以从一组有限的数据类型中为用户变量分配一个值:整数、十进制、浮点、二进制或非二进制字符串或
NULL
值。十进制和实数值的分配不会保留值的精度或小数位数。将除允许类型之一之外的类型的值转换为允许类型。例如,具有时间或空间数据类型的值被转换为二进制字符串。如果为用户变量分配了非二进制(字符)字符串值,则它具有与字符串相同的字符集和排序规则。用户变量的强制性是隐含的。(这与表列值的强制力相同。)
但是手册没有说明:
支持的整数的大小(例如 4-byte
INT
或 8-byteBIGINT
),它们是有符号还是无符号,以及是否ZEROFILL
应用(如果是,使用什么显示宽度);这个 sqlfiddle 似乎暗示 MySQL 5.5.25 将使用 up to
BIGINT
,根据分配进行签名,并且不会应用任何ZEROFILL
.定点值和浮点值中使用的精度和小数位数,因为赋值中没有保留这点;和
字符串的最大长度(以字符和/或字节为单位)。
sqlfiddle 受限于
max_allowed_packet
2 20字节(我无法更改):我猜想支持LONGTEXT
2 32字节(4GiB)。
可以安全地依赖哪些限制,尤其是跨不同的服务器版本和配置?