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会计入。前面与中间就都没什么区别了,在这里记录一下,避免大家入坑。

おすすめ

転載: blog.csdn.net/quanyu7121/article/details/119722485