データベースにテーブルがあります。私のテーブルの名前は「会社」です。データ「company_name」を大文字の最初の文字に変更したい。例えば;
「ABCカンパニー」
「DEF可塑性」
なので
「ABCカンパニー」
「Def Plasticity」
「UPDATE」コマンドを使用する必要があることはわかっています。しかし、どのように?ご協力いただきありがとうございます!
(CONCAT は機能しません)
データベースにテーブルがあります。私のテーブルの名前は「会社」です。データ「company_name」を大文字の最初の文字に変更したい。例えば;
「ABCカンパニー」
「DEF可塑性」
なので
「ABCカンパニー」
「Def Plasticity」
「UPDATE」コマンドを使用する必要があることはわかっています。しかし、どのように?ご協力いただきありがとうございます!
(CONCAT は機能しません)
Initcap
SQL Server にはoracle のような機能はありません。
Initcap の UDF を作成できます。
CREATE FUNCTION [dbo].[InitCap] ( @InputString varchar(4000) )
RETURNS VARCHAR(4000)
AS
BEGIN
DECLARE @Index INT
DECLARE @Char CHAR(1)
DECLARE @PrevChar CHAR(1)
DECLARE @OutputString VARCHAR(255)
SET @OutputString = LOWER(@InputString)
SET @Index = 1
WHILE @Index <= LEN(@InputString)
BEGIN
SET @Char = SUBSTRING(@InputString, @Index, 1)
SET @PrevChar = CASE WHEN @Index = 1 THEN ' '
ELSE SUBSTRING(@InputString, @Index - 1, 1)
END
IF @PrevChar IN (' ', ';', ':', '!', '?', ',', '.', '_', '-', '/', '&', '''', '(')
BEGIN
IF @PrevChar != '''' OR UPPER(@Char) != 'S'
SET @OutputString = STUFF(@OutputString, @Index, 1, UPPER(@Char))
END
SET @Index = @Index + 1
END
RETURN @OutputString
END
GO
UDF の動作を確認しています
select [dbo].[InitCap] ('stackoverflow com');
Stackoverflow Com
このようにテーブルを更新できます
update table
set column=[dbo].[InitCap](column);
update YourTable
set company_name = upper(substring(company_name,1,1)) +
lower(substring(company_name, 2, len(company_name)-1))
where len(company_name) > 0
上記の投稿のおかげで、この関数は、頭字語と見なされる特定の文字長未満の単語を除いて、すべての単語の最初の文字を大文字にします。問題がなければ、2 番目の引数を 0 に設定します。
CREATE function [dbo].[f_camel_exc_short_words] (@InputString varchar(4000),@AcronymMaxLen INT )
RETURNS VARCHAR(4000)
AS
BEGIN
DECLARE @Index INT
DECLARE @Char CHAR(1)
DECLARE @PrevChar CHAR(1)
DECLARE @Word VARCHAR(255)
DECLARE @WordChar CHAR(1)
DECLARE @OutputString VARCHAR(255)
DECLARE @WordIndex INT
SET @Word = ''
SET @OutputString = ''
SET @Index = 1
WHILE @Index <= LEN(@InputString)+1
BEGIN
SET @Char = SUBSTRING(@InputString, @Index, 1)
SET @PrevChar = CASE WHEN @Index = 1 THEN ' ' ELSE SUBSTRING(@InputString, @Index - 1, 1) END
--IF @Char IN (' ', ';', ':', '!', '?', ',', '.', '_', '-', '/', '&', '''', '(')
-- SET @OutputString = @OutputString + @Char
IF @PrevChar IN (' ', ';', ':', '!', '?', ',', '.', '_', '-', '/', '&', '''', '(','0','1','2','3','4','5','6','7','8','9') or @Index = LEN(@InputString)+1
BEGIN
SET @WordIndex = 1
IF LEN(@Word) > @AcronymMaxLen
BEGIN
WHILE @WordIndex <= LEN(@Word)
BEGIN
SET @WordChar = SUBSTRING(@Word,@WordIndex,1)
if @WordIndex = 1 begin
SET @Word = STUFF(@Word,@WordIndex,1,UPPER(@WordChar)) end
else begin
SET @Word = STUFF(@Word,@WordIndex,1,LOWER(@WordChar)) end
SET @WordIndex = @WordIndex + 1
END
END
ELSE BEGIN
SET @Word = UPPER(@Word)
END
set @OutputString = @OutputString + @Word
SET @Word = ''
END
SET @Word = @Word + @Char
SET @Index = @Index + 1
END
return @OutputString
end
GO
パイオニア ユーロ ボンド ファンド クラス C (NON-Dist) (EUR) (オフショア) ISIN LU0119429891 を返しますPRINT dbo.f_camel_exc_short_words ('PIONEER EURO BOND FUND CLASS C (NON-DIST) (EUR) (OFFSHORE) ISIN LU0119429891',4)
。
それが役に立てば幸い。
このような分割関数の助けを借りて。
YourTable
これを試して、あなたのテーブル名に置き換えてください:
update T
set Name = P.Name
from YourTable as T
cross apply (select (select upper(left(X.s, 1))+lower(stuff(X.s, 1, 1, ''))+' '
from dbo.split(' ', Name) as X
for xml path(''), type).value('.', 'varchar(50)')
) as P(Name)
これを試して:
declare @word as nvarchar (50)
set @word = 'ABC COMPANY'
select upper(left(@word, 1)) + lower(SUBSTRING(@word,2,charindex(' ', @word)-2)) + ' ' +
upper(left(substring(@word,charindex(' ', @word)+1,len(@word)-1),1))
+ lower(SUBSTRING(@word,charindex(' ', @word)+2, len(@word)))
さらに変更すると、所有格 ('s) と Mc で始まる単語が処理されます。
if ' ' + @OutputString like '% Mc%'
set @OutputString = ' ' + @OutputString
set @index = CHARINDEX ( ' Mc', @OutputString)
while @Index > 0
begin
set @OutputString = SUBSTRING(@outputString, 1, @index + 2) + UPPER(SUBSTRING(@outputString, @index + 3, 1)) + SUBSTRING(@outputString, @index + 4, len(@outputString))
set @index = CHARINDEX ( ' Mc', @OutputString, @Index + 4)
end
set @outputstring = ltrim(rtrim(@outputstring))
if @OutputString + ' ' like '%''S %'
set @OutputString = ltrim(rtrim(REPLACE(@outputstring + ' ', '''S ', '''s ')))
Returnの直前に置く