Salve, salve meus amigos! Vamos para mais um dia de treinamento. Nesse momento de pandemia, espero que todos estejam bem e cuidando-se pois não podemos dar mole para o Corona!
No post de hoje vamos falar sobre as possibilidades de manipulação de String. Muito conteúdo, espero que gostem, pois está bem interessante!
Listo abaixo as funções que serão comentadas.
LEFT()
RIGHT()
SUBSTRING()
REPLICATE()
CONCAT()
LTIM()
RTRIM()
TRIM()
LEN()
CHARINDEX()
PATINDEX()
ISNULL()
NULLIF()
REPLACE()
SPACE()
UPPER()
LOWER()
STUFF()
Função LEFT()
A função LEFT() serve para retorna o conteúdo do lado esquerdo do texto a partir da posição passada na função.
-- # Sintaxe da Função LEFT()
LEFT ( character_expression , integer_expression )
Exemplo 01: Construir uma consulta para retornar as 7 posições a esquerda da coluna NM_TIPO_ELEICAO.
SELECT [NM_TIPO_ELEICAO], LEFT([NM_TIPO_ELEICAO],7) NM_TIPO_ELEICAO_L7
FROM [TESTE].[dbo].[Vagas_Disponiveis]
Link Função LEFT() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/left-transact-sql?view=sql-server-ver15
Função RIGHT()
A função RIGHT() é o oposto da função LEFT(), pois a função RiGHT() é usada para retornar o conteúdo do lado direito do texto a partir da posição passada na função.
-- # Sintaxe da Função RIGHT()
RIGHT ( character_expression , integer_expression )
Exemplo 02: Construir uma consulta para retornar as 9 posições a esquerda da coluna NM_TIPO_ELEICAO.
SELECT [NM_TIPO_ELEICAO], RIGHT([NM_TIPO_ELEICAO],9) NM_TIPO_ELEICAO_R9
FROM [TESTE].[dbo].[Vagas_Disponiveis]
Link Função RIGHT() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/right-transact-sql?view=sql-server-ver15
Função REPLACE()
A função REPLACE() é usada para substituir um conteúdo em uma coluna por outro.
-- # Sintaxe da Função REPLACE()
REPLACE ( string_expression , string_pattern , string_replacement )
Exemplo 03: Construir uma consulta para substituir na coluna NM_TIPO_ELEICAO o valor "Eleição Ordinária" por "Eleição Municipais".
SELECT [NM_TIPO_ELEICAO],
REPLACE([NM_TIPO_ELEICAO],'Eleição Ordinária' , 'Eleição Municipais') NM_TIPO_ELEICAO_NOVA
FROM [TESTE].[dbo].[Vagas_Disponiveis]
Link Função REPLACE() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/replace-transact-sql?view=sql-server-ver15
Função LEN()
A função LEN() é usada para identificar o comprimento de uma expressão em caracteres.
-- # Sintaxe da Função LEN()
LEN ( string_expression )
Exemplo 04: Construir uma consulta, retornando na coluna NOM_UE_LEN a quantidade de caracteres da coluna NOM_UE.
SELECT NM_UE, LEN(NM_UE) NOM_UE_LEN
FROM [TESTE].[dbo].[Vagas_Disponiveis]
Link Função LEN() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/len-transact-sql?view=sql-server-ver15
Função LOWER()
A função LOWER() é usada para transformar strings maiúsculas (uppercase) para minúsculas (lowercase).
-- # Sintaxe da Função LOWER()
LOWER ( character_expression )
Exemplo 05: Construir uma consulta, retornando na coluna NOM_UE_LOWER o conteúdo da coluna NOM_UE em minúsculo.
SELECT NM_UE, LOWER(NM_UE) NOM_UE_LOWER
FROM [TESTE].[dbo].[Vagas_Disponiveis]
Link Função LOWER() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/lower-transact-sql?view=sql-server-ver15
Função UPPER()
A função UPPER() funciona de formar contrária a função LOWER(), é usada para transformar strings minúsculas (lowercase) em maiúsculas (uppercase).
-- # Sintaxe da Função UPPER()
UPPER ( character_expression )
Exemplo 06: Construir uma consulta, retornando na coluna DS_CARGO_UPPER o conteúdo da coluna DS_CARGO toda em maiúscula.
SELECT DS_CARGO, UPPER(DS_CARGO) DS_CARGO_UPPER
FROM [TESTE].[dbo].[Vagas_Disponiveis]
Link Função UPPER() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/upper-transact-sql?view=sql-server-ver15
Existem 3 funções no Microsoft SQL Server que são utilizadas para remoção de espaços.
Função TRIM()
A função TRIM() remove todos os espaços em branco de uma string.
-- # Sintaxe da Função TRIM()
TRIM ( string )
Exemplo 07: Realizar uma consulta para eliminar os espaços da string ' TESTE FUNÇÃO TRIM() ' usando a função TRIM().
SELECT LTRIM(' TESTE FUNÇÃO TRIM() ')
Link Função TRIM() https://docs.microsoft.com/pt-br/sql/t-sql/functions/trim-transact-sql?view=sql-server-ver15
Função LTRIM()
A função LTRIM() remove todos os espaços em branco a esquerda de uma string.
-- # Sintaxe da Função LTRIM()
LTRIM ( character_expression )
Exemplo 08: Realizar uma consulta para eliminar os espaços da string ' TESTE FUNÇÃO LTRIM() ' usando a função LTRIM().
SELECT LTRIM(' TESTE FUNÇÃO LRIM() ')
Link Função LTRIM() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/ltrim-transact-sql?view=sql-server-ver15
Função RTRIM()
A função RTRIM() remove todos os espaços em branco a direita de uma string.
-- # Sintaxe da Função RTRIM()
RTRIM ( character_expression )
Exemplo 09: Realizar uma consulta para eliminar os espaços da string ' TESTE FUNÇÃO LTRIM() ' usando a função RTRIM().
SELECT LTRIM(' TESTE FUNÇÃO RTRIM() ')
Link Função RTRIM() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/rtrim-transact-sql?view=sql-server-ver15
Função REPLICATE()
A função REPLICATE() é usada para repetir N vezes uma sequência de caracteres especificado.
-- # Sintaxe da Função REPLICATE()
REPLICATE ( string_expression , integer_expression )
Exemplo 10: Realizar uma consulta para repetir 2 vezes string 'TESTE FUNÇÃO REPLICATE()' usando a função REPLICATE().
SELECT REPLICATE('TESTE FUNÇÃO REPLICATE()',2)
Link Função REPLICATE() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/replicate-transact-sql?view=sql-server-ver15
Função SPACE()
A função SPACE() é usada para aplicar a quantidade de espaço determinados dentro do parênteses.
-- # Sintaxe da Função SPACE()
SPACE ( integer_expression )
Exemplo 11: Realizar uma consulta para incluir 2 espaços entre as palavras 'TESTE FUNÇÃO' e 'SPACE()' usando a função SPACE().
SELECT 'TESTE FUNÇÃO' + SPACE(2) + 'SPACE()'
Link Função SPACE() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/space-transact-sql?view=sql-server-ver15
Função STUFF()
A função STUFF() é usada para apagar da string “texto” a partir das posição inicial mais a quantidade de caracteres e substitui pela expressão determinada, observe a sintaxe abaixo.
-- # Sintaxe da Função STUFF()
STUFF( character_expression , start , length , replaceWith_expression )
Exemplo 12: Realizar uma consulta para remover da palavra "DBA" a partir da segunda posição 2 caracteres e adicionar a expressão "BAASSISTS", utilize a função STUFF().
SELECT STUFF('DBA', 2,2, 'BAASSISTS')
Link Referencia STUFF() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/stuff-transact-sql?view=sql-server-ver15
Função SUBSTRING()
A função SUBSTRING() é usada para retornar de uma string a informação determinada a partir da posição inicial até a quantidade de caracteres determinada, ou seja, de uma posição até uma quantidade de caracteres.
-- # Sintaxe da Função SUBSTRING()
SUBSTRING ( expression ,start , length )
Exemplo 13: Realizar uma consulta para retornar a palavra "DBAASSISTS" a palavra que é formada a partir da posição 1 indo até a posição 3, utilize a função SUBSTRING().
SELECT SUBSTRING('DBAASSISTS',1,3)
Link Função SUBSTRING() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/substring-transact-sql?view=sql-server-ver15
Funções PATINDEX() e CHARINDEX()
As funções são usadas para devolver a posição de uma string dentro de um texto. Se nada for encontrar, é retornado zero.
-- # Sintaxe da Função PATINDEX()
PATINDEX ( '%pattern%' , expression )
-- # Sintaxe da Função CHARINDEX()
CHARINDEX( expressionToFind , expressionToSearch [ , start_location ] )
Exemplo 14: Realizar uma consulta para retornar a posição da palavra "DB" dentro da frase "É MUITO BOM ESTUDAR DB COM DBASSISTS", utilize a função PATINDEX().
SELECT PATINDEX( '%DB%' , 'É MUITO BOM ESTUDAR DB COM DBASSISTS' )
Exemplo 15: Realizar uma consulta para retornar a posição da palavra "SQL" dentro da frase "Microsoft SQL Server", utilize a função CHARINDEX().
SELECT CHARINDEX('SQL', 'Microsoft SQL Server')
Link Função PATINDEX() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/patindex-transact-sql?view=sql-server-ver15
Link Função CHARINDEX() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/charindex-transact-sql?view=sql-server-ver15
Vamos abrir um parêntese para apresentar uma abordagem sobre as funções CHARINDEX e PATINDEX. De forma resumida, elas basicamente fazem a mesma coisa.
Retornam a posição inicial de um padrão que você especifica;
PATINDEX() pode usar caracteres curingas, mas a CHARINDEX() não pode.
Ambas as funções usam dois argumentos.
PATINDEX(), você deve incluir sinais de porcentagem antes e depois do teste padrão, a menos que você está procurando o padrão como o primeiro (omita o primeiro%) ou os últimos (omita o último%) caracteres em uma coluna.
CHARINDEX(), o padrão não pode incluir caracteres curinga. O segundo argumento é uma expressão de caracteres, geralmente um nome de coluna.
Função ISNULL()
A função ISNULL() é usada para tratar colunas com valores nulos. É possivel com o seu uso, passar um valor sempre que o selecionado for nulo.
-- # Sintaxe da Função ISNULL()
ISNULL ( check_expression , replacement_value )
Exemplo 16: Realize uma consulta na tabela VAGAS_DISPONIVEIS e todas as vezes que a coluna DS_CARGO estiver nulla, informar "NÃO INFORMADO", utilize a função ISNULL().
SELECT ISNULL(DS_CARGO, 'NÃO INFORMADO') DS_CARGO , *
FROM dbo.Vagas_Disponiveis
Link Função ISNULL() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/isnull-transact-sql?view=sql-server-ver15
Iremos abordar nesse momento a diferença entre ISNULL() e IS NULL.
ISNULL() é uma função do Microsoft SQL Server que efetua a troca do valor NULL pelo caracter especificado no comando;
IS NULL é um operador do Microsoft SQL Server que retorna verdadeiro algum registro satisfaça a condição descrita;
Não use ISNULL() para localizar valores NULL, para localizar valores NULL deve-se usar o operador IS NULL.
Função NULLIF()
A função NULLIF() retornará a primeira expression se as duas expressões não forem iguais.
-- # Sintaxe da Função NULLIF()
NULLIF ( expression , expression )
Link Função NULLIF() - https://docs.microsoft.com/pt-br/sql/t-sql/language-elements/nullif-transact-sql?view=sql-server-ver15
Função CONCAT()
A função CONCAT() é usada para concatenar strings.
-- # Sintaxe da Função CONCAT()
CONCAT ( string_value1, string_value2 [, string_valueN ] )
Exemplo 17: Realize uma consulta para concatenar as strings , 'É MUITO ', 'BOM ', 'ESTUDAR DB' e 'COM DBASSISTS' utilize a função CONCAT().
DECLARE @A VARCHAR(10) = 'É MUITO ',
@B VARCHAR(10) = 'BOM ',
@C VARCHAR(10) = 'ESTUDAR DB',
@D VARCHAR(10) = 'COM DBASSISTS'
SELECT CONCAT(@A, @B, @C, @D)
Link Função CONCAT() - https://docs.microsoft.com/pt-br/sql/t-sql/functions/concat-transact-sql?view=sql-server-ver15
Novamente vamos abrir outro parêntese para falar da função CONCAT().
A função CONCAT() é mais simples de ser utilizada do que o operador de concatenação (+) por dois importantíssimos motivos:
Ela ignora dados nulos;
DECLARE @A VARCHAR(10) = 'É MUITO ',
@B VARCHAR(10) = NULL,
@C VARCHAR(10) = 'ESTUDAR DB',
@D VARCHAR(10) = 'COM DBASSISTS'
SELECT CONCAT(@A, @B, @C, @D)
Ela concatena diferentes tipos de dados sem necessitar de conversão.
DECLARE @A VARCHAR(10) = 'DBASSISTS ',
@B VARCHAR(10) = 'É NOTA ',
@C INT = 10
SELECT CONCAT(@A, @B, @C)
Observação: Função disponível a partir da versão 2012 ou em versões posteriores.
Links de Referência:
Comentarios