SQL Server Len()函数和DataLength()函数的区别

SQL SERVER LEN()函数和DataLength()函数的区别

最近在使用sqlserver的时候意外发现,len和datalength的区别。
declare @animal varchar(mAX)
set @animal='CCC'
SELECT len(@animal) a_len,datalength(@animal) AS a_datalength 
定义变成为animal,并赋值为CCC,并查询。

在这里插入图片描述
结果集大家可以猜到数据的长度都是为3,但如果在CCC后面打上空格,那么结果就大不相同了。

declare @animal varchar(mAX)
set @animal='CCC  '
SELECT len(@animal) a_len,datalength(@animal) AS a_datalength 

在这里插入图片描述
这个时候len函数还是3,而datalength为5,区别就在于这个,如果把空格放在前面,那么len和datalength函数都会为5,
或者在CCC中间空格为C C C,len和datalength函数也是会为5。

总结

len函数和datalength,len函数在后面空格,是不会计入字符的数量的,而datalength会计入。前面与中间就都没什么区别了,在这里记录一下,避免大家入坑。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值