7

適切な SQL コードのみを使用して、SQL Server のテーブル列から PascalCase にテキストを変換することは可能ですか?

TABLE DEFINITION
----------------------
ID  int
CITTA   varchar(50)
PROV    varchar(50)
CAP varchar(50)
COD varchar(50)

変換するテキストを含むフィールドは ですCITTA。「ABANO TERME」、「ROMA」などのすべての大文字の値が含まれます。単語はスペースで区切られます。

編集

一部の単語にはアクセント文字が含まれていることを忘れていました'。この文字は、単語の末尾または途中にあります。

編集2:

結果にいくつかの癖があります:

  • 「ISOLA BALBA」のような名前がある場合、この名前は「IsolaBALba」に変換されます (大文字と小文字は正しいが、スペースがありません)。
  • 「ISOLA D'ASTI」のような名前の場合、これは「IsolaD'asti」に変換されます (以前のようにスペースがなく、大文字と小文字が正しくありません。この場合、正しい結果は「Isola D'Asti」です)。

この小さな問題についてアドバイスをいただけませんか?

4

4 に答える 4

4

少し前にブログに投稿したコードを試してみることをお勧めします。それはあなたの要件に非常によく対応し、他の多くの方法よりも優れたパフォーマンスを発揮すると思います。

SQLServerの適切なケース関数

CREATE FUNCTION dbo.Proper(@DATA VARCHAR(8000))
RETURNS VARCHAR(8000)
AS
BEGIN
  DECLARE @Position INT

  SELECT @DATA = STUFF(LOWER(@DATA), 1, 1, UPPER(LEFT(@DATA, 1))),
         @Position = PATINDEX('%[^a-zA-Z][a-z]%', @DATA COLLATE Latin1_General_Bin)

  WHILE @Position > 0
    SELECT @DATA = STUFF(@DATA, @Position, 2, UPPER(SUBSTRING(@DATA, @Position, 2))),
           @Position = PATINDEX('%[^a-zA-Z][a-z]%', @DATA COLLATE Latin1_General_Bin)

  RETURN @DATA
END

この関数は、大文字を必要とする単語ごとに1回だけループするため、ほとんどの関数よりも少し高速です。

于 2010-12-08T14:01:39.143 に答える
4
DECLARE @T TABLE
(
ID  INT PRIMARY KEY,
CITTA   VARCHAR(50)
)
INSERT INTO @T
SELECT 1, 'ABANO TERME' UNION ALL SELECT 2, 'ROMA' UNION ALL SELECT 3, 'ISOLA D''ASTI';

IF OBJECT_ID('tempdb..#HolderTable') IS NOT NULL
    DROP TABLE #HolderTable

CREATE TABLE #HolderTable
(
Idx INT IDENTITY(1,1) PRIMARY KEY,
ID INT,
Word  VARCHAR(50)
)

CREATE NONCLUSTERED INDEX ix ON #HolderTable(ID)
;

WITH T1 AS
(
SELECT ID, CAST(N'<root><r>' + REPLACE(REPLACE(CITTA, '''', '''</r><r>'), ' ', ' </r><r>') + '</r></root>' AS XML) AS xl
FROM @T
)
INSERT INTO #HolderTable
SELECT ID, 
       r.value('.','NVARCHAR(MAX)') AS Item
 FROM T1
 CROSS APPLY
xl.nodes('//root/r') AS RECORDS(r)

SELECT 
      ID, 
      (SELECT STUFF(LOWER(Word),1,1,UPPER(LEFT(Word,1))) FROM #HolderTable WHERE [@T].ID =  #HolderTable.ID ORDER BY Idx FOR XML PATH('') )
FROM @T [@T]
于 2010-12-08T00:43:21.197 に答える
3

以下の機能を試してください (必要に応じて文字列タイプを調整してください)。これを WHERE 句で使用しないでください。他の場所でのパフォーマンスへの影響を考慮してください。12345678 は任意の大きな値であり、より適切なものに置き換えたいと思うかもしれません!

CREATE FUNCTION dbo.ufn_PascalCase(@str AS VARCHAR(MAX)) RETURNS VARCHAR(MAX)
BEGIN
    SET @str = LOWER(@str)

    DECLARE @result VARCHAR(MAX) = ''

    DECLARE @spaceIndex INTEGER = CHARINDEX(' ', @str)
    WHILE @spaceIndex > 0
    BEGIN
        SET @result += UPPER(SUBSTRING(@str, 1, 1)) + SUBSTRING(@str, 2, @spaceIndex - 2)
        SET @str = SUBSTRING(@str, @spaceIndex + 1, 12345678)
        SET @spaceIndex = CHARINDEX(' ', @str)
    END

    SET @result += UPPER(SUBSTRING(@str, 1, 1)) + SUBSTRING(@str, 2, 12345678)

    RETURN @result
END
于 2010-12-08T00:46:36.677 に答える