将上层变为小写

时间:2015-03-24 09:02:52

标签: tsql ssrs-2008-r2

在我的SELECT语句中,我有:

,用户名

当在查询中出现时,它显示为:JOHN.SMITH

是否可以使用CAST或CONVERT将其更改为John Smith?

感谢任何建议。

感谢。

2 个答案:

答案 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)

它会在.之前获取所有内容,然后在降低其余部分时将第一个字母上升,然后在.之后对所有内容执行相同操作。

但是,如果您在代码中处理此内容会好得多,因为当您回到阅读此查询时,您可能不知道它在做什么。