https://it.cha138.com/tech/show-3207236.html
第一种:
对于字符串结尾不是空格的情况用Len是可以的(如上):
substring(字符串,1,len(字符串)-1) 从第一位开始,截取到第n-1位
left(字符串,len(字符串)-1) 从左侧截取n-1位
但是结尾有空格时得不到正确结果(如下,括号[]不算在字符串内,为了显示后面有空格):
[胡 大侠 ]执行后成为 [胡 大]
所以要先判断结尾是否有空格,有的话用下面语句先行替换:
UPDATE Student SET [Name] = SUBSTRING([Name], 1, LEN([Name])) WHERE RIGHT([Name], 1) = ' '
不管后面在多少空格,这一个子就全替换掉啦!然后再用前面的语句就可以正确去掉最后一个字符了。(如果在你的需求里最后的空格也算一个字符,那么要标记下或者合成一条语句执行)
(PS:试过DataLength()也不行,因为它是以字节计算)
substring(字符串,1,len(字符串)-1) 从第一位开始,截取到第n-1位
第二种:
declare @content varchar(32); --定义一个content的变量
set @content='abc*def'; --对@content变量进行赋值
SELECT REPLACE(@content,'*',''); --例如 需要去掉*号 REPLACE(字符串,需要替换的符号,替换为什么)
第三种:
SELECT STUFF('1abcdef',1,1,'');
标签:字符,Name,--,len,content,sql,字符串,去掉,空格 From: https://www.cnblogs.com/Dongmy/p/17517085.html