在我的SELECT语句中,我有:
,用户名
当在查询中出现时,它显示为:JOHN.SMITH
是否可以使用CAST或CONVERT将其更改为John Smith?
感谢任何建议。
感谢。
答案 0 :(得分:0)
首先用空格替换句号:
SELECT REPLACE(SELECT UserName FROM YourTable, '.', ' ')
将其保存在变量中,或将此选择直接放在下面的函数中。
不幸的是,我现在没有t-sql,所以我无法检查语法是否100%正确。
然后将第一个字符设置为大写。如果您使用的是oracle,我会告诉您使用initcap,但这在t-sql中不存在。
取自链接:http://www.devx.com/tips/Tip/17608
create function initcap (@text varchar(4000))
returns varchar(4000)
as
begin
declare @counter int,
@length int,
@char char(1),
@textnew varchar(4000)
set @text = rtrim(@text)
set @text = lower(@text)
set @length = len(@text)
set @counter = 1
set @text = upper(left(@text, 1) ) + right(@text, @length - 1)
while @counter <> @length --+ 1
begin
select @char = substring(@text, @counter, 1)
IF @char = space(1) or @char = '_' or @char = ',' or @char = '.' or @char = '\'
or @char = '/' or @char = '(' or @char = ')'
begin
set @textnew = left(@text, @counter) + upper(substring(@text,
@counter+1, 1)) + right(@text, (@length - @counter) - 1)
set @text = @textnew
end
set @counter = @counter + 1
end
return @text
end
因此使用此函数转换大写字符串。希望这会有所帮助。
答案 1 :(得分:0)
你可以这样做:
DECLARE @UserName AS varchar(50) = 'JOHN.SMITH'
SELECT LEFT(UPPER(LEFT(@UserName, CHARINDEX('.', @UserName)-1)),1) + SUBSTRING(LOWER(LEFT(@UserName, CHARINDEX('.', @UserName)-1)),2,LEN(LEFT(@UserName, CHARINDEX('.', @UserName)-1))-1) + ' ' + LEFT(UPPER(RIGHT(@UserName, LEN(@UserName) - CHARINDEX('.', @UserName))),1) + SUBSTRING(LOWER(RIGHT(@UserName, LEN(@UserName) - CHARINDEX('.', @UserName))),2,LEN(RIGHT(@UserName, LEN(@UserName) - CHARINDEX('.', @UserName)))-1)
它会在.
之前获取所有内容,然后在降低其余部分时将第一个字母上升,然后在.
之后对所有内容执行相同操作。
但是,如果您在代码中处理此内容会好得多,因为当您回到阅读此查询时,您可能不知道它在做什么。