sql server VARCHAR 默认长度的不同的用法表现问题研究

不指定长度,CAST(... AS VARCHAR) 如果超出,最大默认是 VARCHAR(30)。否则小于等于所转换的长度
可以通过SELECT LEN(CAST('abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqloznrstuvwxyzghijklmnopqrstuvwxyz' AS VARCHAR)) 返回30 得到验证

·SELECT LEN(CAST('ab' AS VARCHAR))返回2 得到第二个验证

image.png
image.png

但是定义变量、参数、或函数返回值中使用 VARCHAR 而不指定长度,它可能被默认为 VARCHAR(1),会截断。
可以通过在标量值函数中得到验证

如果把数字转换为字符串,数字的长度就代表字符串所需要的长度SELECT LEN(CAST(123456789456123456701 AS VARCHAR))得到21 ,

VARCHAR 默认不指定长度可以用来自动测量数字的长度
但是某些地方会适得其反必须指定长度.

验证指定长度截断的情况,经过测试发现,数字11 只给定1个的长度就直接变成了*

SELECT CAST(1 AS VARCHAR(2))
SELECT CAST(11 AS VARCHAR(2))
SELECT CAST(11 AS VARCHAR(1))
SELECT CAST('ab' AS VARCHAR(1))
image.png

所以最后总结varchar 一定程度是帮助理解

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值