Tem maiúscula? – SQL Server

Boa noite, caros leitores!

Venho-lhes escrever mais uma vez! Hoje um amigo do trabalho, Varley, teve uma necessidade interessante que nos fez pensar em uma função útil a ser feita no SQL Server.

A Necessidade: retornar todos os registros que contivessem alguma letra maiúscula.

Problema: o banco de dados utiliza o collation Latin1_General_CI_AI. Esse collation não faz diferenciação de maiúsculas e minúsculas. Para lembrar um pouco sobre collations leia: https://fredyesmeraldo.wordpress.com/2011/06/10/problemas-para-pesquisar-textos-que-possam-conter-acentos-errados-collations-do-sqlserver-resolverao-seu-problema/

Solução: para conseguir fazer a comparação se é maiúscula ou não, precisamos usar um artifício do SQL Server que converte um collation de uma string. Segue abaixo os códigos para retornar se existe maiúscula e outra função que retorna se existe minúscula. Daí para frente pode-se fazer diversas variações de funções (TodasMaiusculas, TodasMiusculas),

create function dbo.TemMinuscula(@texto varchar(max))
returns bit
as
begin
declare @letras as varchar(100)
declare @i as int
declare @j as int
declare @resultado as bit
declare @saiDoLoop as bit

select
@letras = ‘abcdefghijklmnopqrstuvwxzç’,
@resultado = 0,
@i = 1,
@j = 1,
@saiDoLoop = 0

while ( @i <= LEN(@texto) ) and (@saiDoLoop = 0)
begin
while ( @j <= LEN(@letras)) and (@saiDoLoop = 0)
begin
if SUBSTRING(@texto,@i,1) collate Latin1_General_CS_AI = SUBSTRING(@letras,@j,1) collate Latin1_General_CS_AI
begin
select
@resultado = 1,
@saiDoLoop = 1
end

select @j = @j + 1
end

select @i = @i + 1
select @j = 1
end

return @resultado
end

go

——————————————————–

create function dbo.TemMaiuscula(@texto varchar(max))
returns bit
as
begin
declare @letras as varchar(100)
declare @i as int
declare @j as int
declare @resultado as bit
declare @saiDoLoop as bit

select
@letras = ‘ABCDEFGHIJKLMNOPQRSTUVWXZÇ’,
@resultado = 0,
@i = 1,
@j = 1,
@saiDoLoop = 0

while ( @i <= LEN(@texto) ) and (@saiDoLoop = 0)
begin
while ( @j <= LEN(@letras)) and (@saiDoLoop = 0)
begin
if SUBSTRING(@texto,@i,1) collate Latin1_General_CS_AI = SUBSTRING(@letras,@j,1) collate Latin1_General_CS_AI
begin
select
@resultado = 1,
@saiDoLoop = 1
end

select @j = @j + 1
end

select @i = @i + 1
select @j = 1
end

return @resultado
end

Segue abaixo exemplo de utilização:

select dbo.TemMaiuscula(‘testE’)

Retorna 1
select dbo.TemMinuscula(‘TESTE’)

Retorna 0

 

Espero que possa ter sido útil a ideia e que vocês possam criar mais variações de funções a partir dessas!

Abraço! Boa noite!

Aprendendo a usar CURSOR – SQL Server

Boa noite!

Depois de um tempo se escrever é bom voltar a publicar algo um pouco mais substancial, hehehe…

Não gosto do consumo de processamento que eles geram, mas são muito úteis e bastante poderosos na manipulação de dados. Nesse primeiro momento não vou me aprofundar em CURSORES, mas apresentá-lo aqueles que estão iniciando no Microsoft SQL Server.

O que é CURSOR?

De maneira direta e simplista é uma espécie de ponteiro que nos ajuda a manipular e exibir dados consultados.

Como funciona?

Para entender é interessante um método de dividir como um cursor é declarado e o que ele faz. Segue abaixo:

1. Declara CURSOR (DECLARE)

2. Abre o CURSOR (OPEN)

3. Alimenta variáveis com os dados do CURSOR (FETCH)

4. Fecha e desaloca o CURSOR (CLOSE e DEALLOCATE)

<‘o’> Simples assim? Simples assim.

Vamos para um exemplo prático. Vou utilizar uma tabela cliente cujo o código de criação segue abaixo:

–Código de criação da tabela CLIENTE e alguns INSERTS só para exemplificar o CURSOR

create table CLIENTE
(
CodigoCliente int null,
NomeCliente varchar(50) null
)
go

insert into CLIENTE values (1,’Cliente 1′)
insert into CLIENTE values (2,’Cliente 2′)
insert into CLIENTE values (3,’Cliente 3′)
insert into CLIENTE values (4,’Cliente 4′)
insert into CLIENTE values (5,’Cliente 5′)

Agora vou utilizar o cursor fazer uma manipulação “inútil” para exibir os dados. É somente didática. Não serve de muita coisa, pois sem CURSOR seria imensamente fácil fazê-la. Vou utilizar nos comentários os passos que indiquei a vocês anteriormente para que fique mais fácil a compreensão:

–1. Declara CURSOR (DECLARE)
declare c_aprendendoCursor cursor for
select
CodigoCliente,
NomeCliente
from
CLIENTE

–2. Abre o CURSOR (OPEN)
open c_aprendendoCursor

–3. Alimenta variáveis com os dados do CURSOR (FETCH)
declare @cod int
declare @nome varchar(50)

fetch next from c_aprendendoCursor into @cod, @nome

print ‘Código do Cliente: ‘ + cast(@cod as varchar)
print ‘Nome do Cliente: ‘ + @nome
print ‘————————————————————————————‘

fetch next from c_aprendendoCursor into @cod, @nome

print ‘Código do Cliente: ‘ + cast(@cod as varchar)
print ‘Nome do Cliente: ‘ + @nome
print ‘————————————————————————————‘

fetch next from c_aprendendoCursor into @cod, @nome

print ‘Código do Cliente: ‘ + cast(@cod as varchar)
print ‘Nome do Cliente: ‘ + @nome
print ‘————————————————————————————‘

fetch next from c_aprendendoCursor into @cod, @nome

print ‘Código do Cliente: ‘ + cast(@cod as varchar)
print ‘Nome do Cliente: ‘ + @nome
print ‘————————————————————————————‘

–4. Fecha e desaloca o CURSOR (CLOSE e DEALLOCATE)
close c_aprendendoCursor
deallocate c_aprendendoCursor

Lembrando para quem já usa CURSOR que esse é um exemplo bem simplista! Por isso não vou me deter explicando maiores detalhes do CURSOR e nem sobre WHILE e @@FETCH_STATUS, etc, etc, etc…

Serão cenas do próximo capítulo! Rs

Espero que tenha sido útil. Até a próxima!

Desafio SQL Server – Cadê meu JOIN?!

Achei esse desafio em um site(no qual não vou dizer agora pros espertinhos não procurarem a resposta; porém, darei todo o crédito ao responsável pelo desafio depois, ok?!), e resolvi compartilhar com vocês.

O nome do desafio é Cadê o meu JOIN?

A resposta estarei postando em breve ou comentarei quando alguém acertar! Abraço a todos os amantes do SQL Server!

Uma pessoa me apresentou uma consulta SQL que relacionava os dados de cliente com os endereços.

SELECT c.* FROM Clientes c LEFT OUTER JOIN Regioes r
ON c.regiaoId = r.regiaoId AND
r.regiaoId IS NULL

O interessante é que o plano de execução gerada não possui JOIN entre tabelas. Surge a pergunta: CADÊ MEU JOIN???

image

O problema fica mais interessante quando substituimos o LEFT OUTER JOIN por um INNER JOIN, pois o plano de execução não apresenta a leitura em nenhuma tabela.

SELECT c.* FROM Clientes c INNER JOIN Regioes r
ON c.regiaoId = r.regiaoId AND
r.regiaoId IS NULL

image

A pergunta desse Desafio Ninja é:

O que aconteceu com o Join de tabela e com a operação de Table Scan?

Fico aguardando as respostas nos comentários!

Script usado:

CREATE TABLE Regioes
(regiaoId INT PRIMARY KEY,
   local VARCHAR(100) NOT NULL)

CREATE TABLE Clientes
  (id INT,
nome VARCHAR(50),
regiaoId INT FOREIGN KEY REFERENCES Regioes(regiaoId))

INSERT Regioes VALUES (1, ‘Norte’), (2, ‘Sul’)
INSERT Clientes VALUES (1, ‘Cliente1’, 1), (2, ‘Cliente2’, 1)
GO

SELECT c.* FROM Clientes c LEFT JOIN Regioes r
ON    c.regiaoId = r.regiaoId AND
r.regiaoId IS NULL

SELECT c.* FROM Clientes c INNER JOIN Regioes r
ON    c.regiaoId = r.regiaoId AND
r.regiaoId IS NULL

Introdução ao SQL Server 2012 – Livro Grátis

Olá! Bom dia!

Depois de um milênio sem postar nada estou de volta! Rsrs

E com uma excelente notícia: a Microsoft cada vez mais estimula seus usuários a se aperfeiçoarem em suas ferramentas!

A prova disso é a liberação de um livro gratuito sobre introdução ao SQL Server 2012! Isso mesmo: gratuito! “De grátis”! Lógico, que de graça só o PDF! Rsrs Se interessar o livro, ele custa aproximadamente U$ 15,00.

Se quiser ler a matéria completa: http://blogs.msdn.com/b/microsoft_press/archive/2012/03/15/free-ebook-introducing-microsoft-sql-server-2012.aspx

Se quiser baixar somente o livro: Clique Aqui

Até a próxima pessoal!