"Se um trabalhador quiser fazer bem o seu trabalho, ele deve primeiro afiar suas ferramentas." - Confúcio, "Os Analectos de Confúcio. Lu Linggong"
Primeira página > Programação > Como dividir com segurança Strings no T-SQL usando delimitadores?

Como dividir com segurança Strings no T-SQL usando delimitadores?

Postado em 2025-03-24
Navegar:157

How to Safely Split Strings in T-SQL Using Delimiters?

String de segmento

com base no delimitador em t-sql

pergunta:

No SQL, usando a substring para dividir strings com base em delimitadores, pode causar erros quando o delimitador não existir. O código a seguir demonstra o seguinte:

SELECT SUBSTRING(myColumn, 1, CHARINDEX('/', myColumn)-1) AS FirstName,
       SUBSTRING(myColumn, CHARINDEX('/', myColumn)   1, 1000) AS LastName
FROM   MyTable

Quando uma linha sem delimitador é encontrada, ele lança um erro: "O parâmetro de comprimento passado para a função esquerda ou substring é inválido".

Solução:

Para resolver esse problema, você pode usar a instrução CASE na função de substring, como mostrado abaixo:

SELECT SUBSTRING(myColumn, 1, CASE CHARINDEX('/', myColumn)
            WHEN 0
                THEN LEN(myColumn)
            ELSE CHARINDEX('/', myColumn) - 1
            END) AS FirstName
    ,SUBSTRING(myColumn, CASE CHARINDEX('/', myColumn)
            WHEN 0
                THEN LEN(myColumn)   1
            ELSE CHARINDEX('/', myColumn)   1
            END, 1000) AS LastName
FROM MyTable

Este código atualizado usa Charindex para avaliar a posição do delimitador. Se o delimitador não for encontrado (Charindex retornará 0), a instrução CASE usa o comprimento da string para garantir que toda a string seja tratada como um nome. Se existir um delimitador, ele calcula a posição do primeiro caractere após o delimitador como o índice inicial do sobrenome.

Tutorial mais recente Mais>

Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.

Copyright© 2022 湘ICP备2022001581号-3