Implementando um Extension Method para coleções utilizarem a expressão Soundex

Standard

Vou demostrar neste artigo como podemos criar um Extension Method para coleções (IEnumerable) poderem utilizar um recurso muito utilizado em Transact-SQL chamado Soundex.

Para quem não conhece [ou não sabe nem o que é], a expressão Soundex retorna um código de quatro caracteres utilizado para comparar a semelhança entre duas sequências de caracteres. Ou seja, foneticamente falando, “casa” seria o mesmo que “caza”, ou até mesmo “cazza”, pois o som ao reproduzi-las seria o mesmo.

O algoritmo para a geração dos quatro caracteres para a comparação fonética é realizado utilizando algumas regras e “quase todas” letras do alfabeto.

Básicamente, as seguintes regras são consideradas:

1- Guarda-se o primeiro caracter da sequência e ignora os demais que forem iguais a (a, e, i, o, u, y, h, w);
2- concatena-se os próximos caracteres com seu respectivo código:
b, f, p, v => 1 
c, g, j, k, q, s, x, z => 2 
d, t => 3 
l => 4 
m, n => 5 
r => 6 
3- Dois caracteres adjacentes com o mesmo número são codificados como um único número, assim como, dois caracteres iguais separados por ‘h’ ou ‘w’ são codificados como um número único.
4- Se houver letras duplicadas, a segunda letra é ignorada
5- Continue até que o resultado seja três números, ou, preencher com “0” até ficarem três números.

Vamos criar nossa rotina para geração do código Soundex:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/// <summary>
/// Gera código Soundex
/// </summary>
/// <param name="valor"/>Valor base a ser verificado
/// <returns>String com código Soundex</returns>
public static string GeraSoundex(this string valor)
{
    if (String.IsNullOrEmpty(valor))
        return null;

    StringBuilder resultado = new StringBuilder(valor.Length);

    string valorBase = valor.ToUpper().Replace(" ", string.Empty);

    resultado.Append(valorBase[0]);
    char valorAnterior = '0';
    for (int i = 1; i < valorBase.Length; i++)
    {
        char valorEquivalente = '0';
        char valorAtual = valorBase[i];

        if ("BFPV".Contains(valorAtual))
            valorEquivalente = '1';

        else if ("CGJKQSXZ".Contains(valorAtual))
            valorEquivalente = '2';

        else if ("DT".Contains(valorAtual))
            valorEquivalente = '3';

        else if ('L'.Equals(valorAtual))
            valorEquivalente = '4';

        else if ("MN".Contains(valorAtual))
            valorEquivalente = '5';

        else if ('R'.Equals(valorAtual))
            valorEquivalente = '6';

        if (valorEquivalente != valorAnterior && valorEquivalente != '0')
        {
            resultado.Append(valorEquivalente);
            valorAnterior = valorEquivalente;
        }
    }
    while (resultado.Length < 4)
        resultado.Append("0");

    return resultado.ToString(0, 4);
}

Continue reading

Linq to SQL – Catalogando Log (SQL query/Command) do Linq em arquivos externos

Standard

Um recurso bem interessante que temos no Linq (toSQL e Entity), é a possibilidade de catalogar e analisar as queries que são geradas. Ou seja, como o linq gerencia a forma de geração do código SQL/command a ser executado efetivamente na base de dados, podemos com este recurso, verificar se nossa query linq está sendo processada da melhor forma possível e com a melhor performance.

Para tanto, vamos primeiramente criar uma estrutura para a realização de uma query bem simples, veja:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
// Cria contexto de dados
DBDataContext _db = new DBDataContext();

// Efetua uma query
var query = from p in _db.Produtos
where p.valor.HasValue
select p;

// Registra LOG com a query gerada pelo LINQ
_db.Log = new LogQueryLinq();

// Percorre a query e mostra ao usuário cada produto
foreach (var p in query)
Console.WriteLine(string.Format("Produto:{0} | Valor Total{1}", p.nome, p.valor ));

Continue reading

Resumo de artigos publicados no TechNet Wiki até hoje (13/07/2012)

Standard

Para você que não conhece o TechNet Wiki tenho uma coisa para contar, você está perdedo tempo, além de uma grande variedade de temas e conteúdos, existe uma página totalmente em pt-BR. Wink

Atualmente, na página de Desenvolvimento existem diversos artigos interessantes, no total, eu já publiquei 15 artigos, alguns deles já publicados aqui também!

Veja abaixo minhas publicações até hoje 13/07/2012:

 

ASP.NET MVC

ASP.NET MVC – Autenticação Básica
http://social.technet.microsoft.com/wiki/contents/articles/6466.aspx

ASP.NET MVC – Verificando se a Action solicitada existe em uma requisição
http://social.technet.microsoft.com/wiki/contents/articles/6465.aspx

ASP.NET MVC – Evitando ataques de Redirecionamento
http://social.technet.microsoft.com/wiki/contents/articles/6464.aspx

ASP.NET MVC – Validando os parâmetros na requisição de uma URL
http://social.technet.microsoft.com/wiki/contents/articles/6490.asp-net-mvc-validando-os-parametros-na-requisicao-de-uma-url-pt-br.aspx

ASP.NET MVC – Criando uma aplicação multi-idiomas
http://social.technet.microsoft.com/wiki/contents/articles/6491.aspx

ASP.NET MVC – Renderizando Gráficos do Google Chart com Html Helpers
http://social.technet.microsoft.com/wiki/contents/articles/6505.aspx

ASP.NET MVC – Criando uma aplicação MVC compatível com o Windows Azure
http://social.technet.microsoft.com/wiki/contents/articles/6777.asp-net-mvc-criando-uma-aplicacao-mvc-compativel-com-o-windows-azure-pt-
br.aspx

ASP.NET MVC – Trabalhando com vários Submits na mesma View
http://social.technet.microsoft.com/wiki/contents/articles/7374.asp-net-mvc-trabalhando-com-varios-submits-na-mesma-view-pt-br.aspx

 

Windows Azure

Windows Azure – Entendendo as principais Roles
http://social.technet.microsoft.com/wiki/contents/articles/6778.windows-azure-entendendo-as-principais-roles-pt-br.aspx

 

Linq to SQL

Linq to SQL – Trabalhando com Stored Procedures simples
http://social.technet.microsoft.com/wiki/contents/articles/6484.linq-to-sql-trabalhando-com-stored-procedures-simples-pt-br.aspx

Linq to SQL – Trabalhando com Stored Procedures complexas
http://social.technet.microsoft.com/wiki/contents/articles/6485.aspx

Linq to SQL – Escrevendo diretamente com SQL
http://social.technet.microsoft.com/wiki/contents/articles/6486.aspx

Linq to SQL – Utilizando Compiled Query
http://social.technet.microsoft.com/wiki/contents/articles/6487.aspx

Linq to SQL – Adicionando Validações
http://social.technet.microsoft.com/wiki/contents/articles/6488.aspx

Paginação com Linq utilizando Skip e Take
http://social.technet.microsoft.com/wiki/contents/articles/6489.aspx

Você é “dev”? Contribua também!

Abs

 

Criando um repositório genérico para Entity Framework

Standard

Irei demonstrar aqui uma forma bem simples e rápida para implementarmos um repositório genérico com Entity Framework. A ideia de implementação será a mesma utilizada com Linq to SQL, ou seja, nosso repositório será responsável por realizar apenas quatro operações: Selecionar os dados, salvar, apagar e atualizar.

Vamos primeiramente criar uma interface para o repositório:

public interface IRepositorio
{
	void Atualiza();

	void Apaga<TEntidade>(TEntidade entidade) where TEntidade : class;

	void Salva<TEntidade>(TEntidade entidade) where TEntidade : class;

	IQueryable<TEntidade> Seleciona<TEntidade>() where TEntidade : class;
}

Continue reading

Criando um repositório genérico para Linq to SQL

Standard

Vou demonstra aqui uma forma bem rápida e produtiva para criarmos um repositório genérico com Linq to SQL. Basicamente devemos efetuar quatro operações básicas: Selecionar os dados, salvar, apagar e atualizar.

Vejamos como ficaria nossa interface para o repositório genérico:

public interface IRepositorio
{
   void Atualiza();

   void Apaga<TEntidade>(TEntidade entidade) where TEntidade : class;

   void Salva<TEntidade>(TEntidade entidade) where TEntidade : class;

   IQueryable<TEntidade> Seleciona<TEntidade>() where TEntidade : class;
}

Pegou a idéia com Generics? veja a implementação: Continue reading

Implementando um Extension Method para IEnumerables utilizarem a expressão Soundex

Standard

Imagem 1

 

Vou demostrar neste artigo como podemos criar um Extension Method para coleções (IEnumerable) poderem utilizar um recurso muito utilizado em Transact-SQL chamado Soundex.

Para quem não conhece [ou não sabe nem o que é], a expressão Soundex retorna um código de quatro caracteres utilizado para comparar a semelhança entre duas sequências de caracteres. Ou seja, foneticamente falando, “casa” seria o mesmo que “caza”, ou até mesmo “cazza”, pois o som ao reproduzi-las seria o mesmo.

O algoritmo para a geração dos quatro caracteres para a comparação fonética é realizado utilizando algumas regras e “quase todas” letras do alfabeto. Onde básicamente, as seguintes regras são consideradas:

 

1 – Guarda-se o primeiro caracter da sequência e ignora os demais que forem iguais a (a, e, i, o, u, y, h, w);

2 – concatena-se os próximos caracteres com seu respectivo código:

  • b, f, p, v => 1
  • c, g, j, k, q, s, x, z => 2
  • d, t => 3
  • l => 4
  • m, n => 5
  • r => 6

3 – Dois caracteres adjacentes com o mesmo número são codificados como um único número, assim como, dois caracteres iguais separados por ‘h’ ou ‘w’ são codificados como um número único.

4 – Se houver letras duplicadas, a segunda letra é ignorada

5  – Continue até que o resultado seja três números, ou, preencher com “0” até ficarem três números. Continue reading

Dica Rápida – Default Values com Linq to SQL

Standard

Sabemos que no Sql Server podemos criar colunas de tabelas com valores padrão, ou seja, valores default que serão utilizados caso não passe valor algum para o campo.

Veja a tabela abaixo:

CREATE TABLE TabelaTeste
(
Cod INT IDENTITY(1,1) PRIMARY KEY NOT NULL,
Nome VARCHAR(100) NOT NULL DEFAULT('Zaccanini'),
Valor DECIMAL(18,2) NOT NULL DEFAULT(100), 
Data DATETIME NOT NULL DEFAULT(GETDATE()),
Obs VARCHAR(MAX) NULL
)

Observe que as colunas Nome, Valor e Data possuem valores default. Para realizarmos um insert no próprio Sql Server, podemos fazer algo bem simples, como:

INSERT INTO TabelaTeste DEFAULT VALUES

Algora iremos realizar o mesmo insert, porém, com Linq to SQL.

Para tanto basta definir a propriedade “Auto Generated Value” como “True” nas colunas que possuem valores default, observe abaixo:

Imagem 1

E para o insert:

DB.TabelaTestes.InsertOnSubmit(new TabelaTeste());
DB.SubmitChanges();

Pronto, muito simples e rápido. (Acreditem se quiser, vi muitas dúvidas sobre isto! :P)

 

Abraços.

 

Crie consultas dinâmicas com Predicated Builder

Standard

C# 4.0 in a Nutshell

Vamos falar neste artigo sobre um recurso muito utilizado e que ajuda muito o trabalho para criação de cosultas dinâmicas com Linq chamado Predicated Builder.

Predicated Builder é uma biblioteca gratuita desenvolvida por Josefh Albahari e Ben Albahari (Experts em C# por sinal) que viabiliza a criação de queries dinâmicas para consultas com Linq. Sua utilização é muito simples e possui um código bem limpo e fácil. Continue reading

Linq com .Net Framework 2.0/3.0 ? Sim, é possível, use o LinqBridge

Standard

Para quem não sabe, o Linq foi inserido na biblioteca do .Net Framework a partir da versão 3.5, mas, seria muito interessante podermos utiliza-lo em aplicações que utilizam versões anteriores de Framework, como a 3.0 ou 2.0 não ?

Darei aqui uma dica rápida e muito interessante para viabilizar a situação proposta, demonstrarei o uso de uma biblioteca gratuita, desenvolvida justamente para realizar esta ponte, entre versões mais antigas do .Net Framework(2.0 e 3.0) com o Linq. Ela chama-se:

LinqBridge

O LinqBridge foi lançado a algum tempo (em 2007 mais precisamente), e foi desenvolvida por Joseph Albahari. Com o LinqBridge podemos utilizar todos os operadores padrão de Enumerables do .Net Framework 3.5, disponibilizando para tanto Linq to Objects. Continue reading

Linq to SQL – Conceitos Avançados ( Parte 6 ) – Adicionando validações

Standard

A Validação de Dados com Linq é na verdade uma verificação de que os valores inseridos nos objetos de dados estão em conformidade com a estrutura e esquema do objeto, além de prevenir e viabilizar a realização de validações especificas de sua aplicação no objeto.

Além de prevenir erros, a validação de dados reduz requisições no Banco de Dados uma vez que a validação é efetuada na aplicação antes de sua atualização de fato no Banco. Continue reading