The Club
terça-feira, 9 de fevereiro de 2010
Busca  
Porta 80 Web Hosting
 :: Acessibilidade
Ir para conteúdo principal: ALT + 1
 :: Participe
Seja um autor de CD/DVD de Treinamento
Publique um artigo
Publique uma oportunidade
Publique uma notícia
Publique um curso
Publique uma dica
Publique um código
 :: Informativo
Receba nossos informativos por e-mail.
E-mail:   
 
Digite a palavra abaixo:  
 
 
 :: Oportunidades
Cadastrar oportunidades
Gerenciar suas oportunidades
Cadastrar nova empresa
 :: Especiais
Básico de C++
C++ Builder
Curso ASP.NET 3.5 em VB.NET e C#
Guia Prático de HTML
Testes com Visual Studio Team System 2008
 :: Desenvolvimento
ActionScript
ADO.NET
ASP
ASP.NET
Automação Comercial
C#
C/C++
Coldfusion
CSS
Delphi
Disp. Móveis
HTML
Java
Javascript
LSL (Second Life)
Modelagem
PHP
Python
Sharepoint
Silverlight
SQL
VBA (Office)
Visual Basic
Visual Basic .NET
Visual Fox Pro
WCF/WPF
Web Services
XML
 :: Infra
BizTalk Server
CRM
Exchange Server
ForeFront / Antigen / IAG
Interoperabilidade
ISA Server
Linux
MOF
MS Dynamics CRM
Network
OCS / LCS
Outlook
Powershell e Scripts
Redes
Segurança
System Center e Gerenciamento
Virtualização
Windows
Windows Server
 :: Banco de Dados
Access
Caché
Firebird
Interbase
MySQL
Oracle
SQL Server
Sybase
 :: Gerência
Arquitetura
Ciclo de Vida de Desenvolvimento
Controle de Versão
Estimativas
Metodologias
MOF
Qualidade e Testes
 :: Design
Corel
Flash
Photopaint
Photoshop
 :: Livros
Análise Sistemas
Aplicativos
Banco de Dados
Certificação
Design e CAD
Gerência
Hardware
Internet
Programação
Programação Web
Rede
Segurança
Servidores
Sistemas Operacionais
 :: CDs/DVDs
Desenvolvimento
Infra
Design
 :: E-Books
.NET 2.0 (VS 2005)
.NET 1.1 (VS 2003)
SQL Server
Excel 2007
Excel 2003
Access 2003
ASP 3.0
Delphi
Java
Artigos


MVP Profile
Dez razões para adotar o Linq nas aplicações .Net
Por: Renato Haddad
[Entre em contato com o autor ]
MVP, MCPD e MCTS, palestrante em eventos da Microsoft em diversos países, ministra treinamentos focados em produtividade com o VS.NET 2008, ASP.NET 3.5, Reporting Services e Windows Mobile. Visite o blog http://weblogs.asp.net/renatohaddad.
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  
Dez razões para adotar o Linq nas aplicações .Net
Publicado em: 21/05/2009

Tecnologias utilizadas: LINQ

Sumário:

Neste artigo vou abordar dez razões para se adotar o LINQ (Language Integrated Query) nas aplicações .NET.

Introdução

O LINQ (Language Integrated Query) é uma linguagem de consulta integrada a ser usada em coleções de dados. Muitos pensam que o LINQ é usado apenas para consulta à banco de dados e isto não é verdade. O que o LINQ TO SQL e o ADO Entity Framework permitem é construir uma classe que é o modelo de objeto relacional OR/M para que as classes do LINQ as manipule. Na verdade, nos bastidores são coleções, então, podemos usar o LINQ em qualquer tipo de fonte de dados, sendo uma classe, uma coleção, um array, enfim, qualquer tipo de objeto que seja do tipo IEnumerable ou IQueryable. Veja os dez motivos para se adotar o LINQ em aplicações .NET:

1 – Padronização do código

Todos os códigos escritos com o LINQ são padronizados. A própria sintaxe força o desenvolvedor a usar determinada sequência de códigos para que todos possam entender. Os padrões de programação quando lidamos com consultas são os mais diversos no cenário de um time de desenvolvedores, onde cada um cria o próprio código. É fato que criar um framework numa empresa para engessar os desenvolvedores, não é muito difícil e anormal, em fábricas de softwares isto é comum. Já com o LINQ o cenário é um tanto diferente porque a própria consulta que o desenvolvedor irá criar é consideravelmente menor em relação a quantidade de códigos a serem escritos. Agora, imagine se você criar um framework próprio onde o retorno serão coleções IEnumerable ou IQueryable.  A quantidade de linhas do seu framework vai diminuir consideravelmente. Resumindo, o padrão de codificação será respeitado pela própria sintaxe do LINQ, por exemplo, ao invés de fazer looping para varrer uma datatable, um List (com o Generics), um array ou qualquer outra coleção, com o LINQ isto será apenas uma única linha.

2 – Expressões Lambda

O nome assusta, mas depois de você conhecer, entender e usar, afirmo que é amor a primeira vista. Acreditem, é impressionante a quantidade de códigos que uma expressão Lambda reduz na programação. A dupla Lambda e LINQ não podia ser melhor, pois os métodos do LINQ permitem usar Lambda o tempo todo.

Costumo brincar em palestras que ministro que expressões Lambda você demora um pouco para aprender bem, mas vale muito a pena. Pesquise sobre isto.

 

3 – Fonte de dados

Em relação à fonte de dados do banco de dados, você pode usar qualquer banco de dados que tenha um driver/provider criado para o LINQ. Isto significa dizer que o ADO.NET Entity Framework usará o driver para se conectar e mapear qualquer base de dados, por exemplo, Oracle, DB2, SQL Server, ODBC, etc. Já o LINQ TO SQL foi criado somente para o SQL Server 2000 ou superior. Além disto, lembre-se que qualquer array, list (Generics), classes, XML ou coleção IEnumerable ou IQueryable serve para o LINQ.

Se você desenvolve aplicações móveis com o Windows Mobile 6, saiba que o LINQ para Dataset e o LINQ para XML é suportado. Por enquanto não existe o LINQ para SQL Compact Edition (.sdf) no dispositivo, somente se você usá-lo no desktop.

4 – Código limpo, claro e de fácil manutenção do código

Este é um ponto forte no LINQ. Escrever um código limpo não é para muitos, principalmente para otimizar e maximizar o código. Já um código claro que não precise de documentação e comentários é mais difícil ainda, vocês já devem ter visto diversos códigos escritos por desenvolvedores com diversos níveis, então, sabe o que estou dizendo. Já a manutenção então, já experimentou dar manutenção num código que não foi você que escreveu? Então, sabe muito bem o que significa isto, ler o código, entender o raciocínio, rodar com o debug para entender o fluxo é coisa comum num time. Enfim, com o LINQ, escrever um código limpo e claro é regra obrigatória pela própria sintaxe. Quem vai ganhar com isto é a manutenção quando se precisar alterar algo.

5 - Modelo de Objeto Relacional (OR/M)

O sonho de muitos desenvolvedores é usar o OOP num banco de dados, principalmente o SQL Server. O Visual Studio .NET 2008 (com o Service Pack 1) permite criar modelos de objetos relacionais baseados em qualquer banco de dados que tenha o driver para tal finalidade. Tanto para o LINQ TO SQL quanto para o ADO.NET Entity Framework a maneira de criar o modelo é parecida. Ou você monta a conexão com o banco de dados no Server Exporer e arrasta os objetos (tabelas, consultas e Stored Procedures) ou seleciona os objetos numa lista, dependendo do caminho e do template escolhido. O fato é que isto é tão simples que as alterações na estrutura do banco são refletidas diretamente no modelo. No Entity Framework, basta clicar com o botão direito no modelo e pedir para atualizar. Já no LINQ TO SQL é preciso excluir e arrastar o objeto novamente. Nos bastidores será criada uma classe contendo todos os objetos, os relacionamentos, as propriedades dos mesmos, e o melhor de tudo é que as rotinas de Insert, Delete e Update também. Ou seja, tudo está encapsulado no modelo gerado automaticamente.

6 – Redução considerável do número de linhas na programação

Esta é uma questão de otimizar as rotinas. Pegue um papel e uma caneta ou crie um código no VS.NET para a seguinte situação: dado um array com números aleatórios de 0 a 50, como saber quais números são maiores que 20? Provavelmente você criaria um looping para percorrer cada item do array, faria um IF para avaliar a condição, e conforme o resultado listaria o item ou iria para o próximo. Quantas linhas você precisa para isto? Escreva ai o algoritmo! Ah, esqueci de dizer que quero que o resultado da lista esteja em ordem crescente, ok. Então, com o LINQ precisamos de apenas uma única linha, por exemplo, var resultado = from n in números where n > 20 orderby n select n.

7 – Extensão de classes

As classes geradas pelo modelo de objeto relacional são do tipo partial class e os métodos são partial void. Com isto podemos criar diversos outros arquivos com o mesmo nome da classe sendo do tipo partial class e extender qualquer método, pois são partial void. No Entity há somente um método extensível, mas no LINQ TO SQL todos são extensíveis. Isto nos dá um horizonte enorme em relação a criar novos métodos separados do OR/M, pois se houver alguma atualização do mesmo, todos os métodos estendidos serão preservados, pois estão em arquivos separados.

8 – Fácil Aprendizado

Pela própria facilidade de uso e clareza dos códigos, digo que o aprendizado do LINQ é muito rápido. Se você não conhecer programação orientada a objetos (OOP) não tem problema, é fácil, mas se você conhece OOP terá muito mais facilidade, principalmente quando lidar com o modelo de objeto relacional.

9 – Permite usar Stored Procedures

Stored Procedures são muito usadas em qualquer tipo de projeto, pelas vantagens de segurança, performance e escalabilidade. Quando se cria o OR/M, pode-se adicionar as SPs existentes na base dados. Porém, há uma grande diferença: no LINQ TO SQL uma SP vira um método, ou seja, qualquer SP é possível arrastar no OR/M e usá-la como um método, passando parâmetros ou não. Já no Entity Framework não é possível adicionar qualquer SP, pois é preciso mapear uma tabela no modelo. Mas, se você tiver SPs para Insert, Delete e Update referente a uma tabela, no modelo basta informar na classe mapeada as respectivas SPs para que estas sejam automaticamente invocadas quando da operação. Vale dizer que as SPs podem ter parâmetros de entrada e saída.

10 – Esteja preparado para o que há de mais novo para o presente e futuro

Se você estudar um pouco das novidades que a Microsoft tem lançado, por exemplo, ASP.NET Dynamic Data, ASP.NET MVC e ADO.NET Data Services verá que tudo está baseado no modelo de objeto relacional criado por você a partir de uma fonte de dados. Sendo assim, aprender o LINQ só vai te trazer vantagens em todos os aspectos, principalmente para agregar conhecimento e deixá-lo preparado para o que há de mais novo no mercado. Conhecimento nunca é demais, o que precisamos é de tempo para aprender, então, foque no aprendizado e se dedique.

 

Conclusão

Use e abuse dos recursos do Dynamic Data e do LINQ para ser um parceiro na produtividade no projeto. Aprofunde os estudos em customizações do Dynamic Data para você conseguir automatizar qualquer tipo de aplicação, desde as regras de negócios, layout e requisitos do sistema.

Referências

Página do LINQ http://msdn.microsoft.com/en-us/netframework/aa904594.aspx.

Renato é autor do livro LINQ e C# 3.0 - A Solução em Consultas para Desenvolvedores.
http://www.linhadecodigo.com.br/Livro.aspx?id=3759.


 

Conheça os produtos do autor Renato Haddad

Inclua um comentário sobre o artigo Topo
Elogios e críticas são muito bem vindos, porém o comentário deve ter referência ao artigo em pauta.
O portal e o autor agradecem.
Nome:    
E-mail:      
Comentários:    
Digite a palavra abaixo:  
Para dúvidas técnicas, NÃO UTILIZE ESTE ESPAÇO, utilize nosso fórum de discussão.
http://linhadecodigo.com.br/cs2/forum
 
Comentários sobre o artigo Ver Todos comentários
Parabéns pelo artigo bem objetivo e claro.

Abraço.
Quem enviou: Tadeu Matos
Postado em: 22/05/2009 00:00:00
Outros artigos do autor Topo
Formatar dados com o ASP.NET Dynamic Data
Sincronização de Dados no .NET Framework 3.5
ASP.NET Dynamic Data
Como montar um controle ListView do ASP.NET 3.5 com o LINQ?
Vídeo: Como criar e usar Code Snippets no Visual Studio .NET 2008 (Para assinantes)
10 Razões para adotar o ASP.NET 3.5
Vídeo: Dicas e Truques do Visual Studio .NET 2008 - Parte 2 (Para assinantes)
Vídeo: Dicas e Truques do Visual Studio .NET 2008 - Parte 1 (Para assinantes)
Vídeo: Inicializar objetos na linguagem C# 3.0 (Para assinantes)
Vídeo: Truncando dados no GridView (Para assinantes)
Vídeo: Validação de dados em grupo no ASP.NET 2.0 (Para assinantes)
Vídeo: Controle do status da bateria no Windows Mobile 6 (Para assinantes)
Vídeo: Controle Details View no ASP.NET 2.0 (Para assinantes)
Vídeo: Exibir dados no GridView e Details View no ASP.NET 2.0 (Para assinantes)
Vídeo: Filtrando dados com multiplas seleções no SQL Reporting Services 2005
Vídeo: Filtrando dados em relatório no SQL Reporting Services 2005 (Para assinantes)
Vídeo: Formatar linhas e células no SQL Reporting Services 2005 conforme uma condição (para assinantes)
Vídeo: Windows Mobile 6: Pocket para SmartPhone (Para assinantes)
Vídeo: Windows Mobile 6: Banco de Dados (Para assinantes)
Inserindo Hyperlink com parâmetro no GridView do ASP.NET 2.0
Boas razões para adotar o Windows Mobile 6
Windows Mobile 6 Developer Resource Kit
Crie um Álbum de Fotos no Power Point 2007
Filtrar dados na Folha de Dados no MS-Access 2007
Simulando o Hotmail com ASP.NET 2.0
Controles de usuários que só o ASP.NET 2.0 suporta
Voto de paixão: Visual Studio .NET Beta 2, o que é isso?
Saiba porquê desenvolver aplicações para telefones celulares com .NET
Aplicações Móveis no .NET
Publicidade na WEB - Componente AdRotator
Interagindo com DataList em aplicações ASP.NET
Usando componentes com ADO.NET
Dez Razões para Migrar para o ASP.NET
Artigos relacionados Topo
Compactação de ViewState em ASP.NET - Parte 2 (Colocando na Session)
Escopo e nível de acessos no C#
Encriptando valores passados por QueryString
Array, ArrayList e List(T): O que devemos saber?
Truques em coleções com LINQ e C# 3.0 - Parte 1
Descubra os Delegates "Show de Bola"
Tratamento de excessões em aplicações N-Tier
Generics com C# e .NET 2.0
Explorando as Coleções do .NET Framework - Parte 2
Explorando as Coleções do .NET Framework - Parte 1
Explorando alguns Delegates do C# 2.0: Predicates, Converter, Comparison e Action
C# 4.0 - Tipos Dinâmicos
Delegates e eventos no C# 2.0 - Parte 2
Delegates e eventos no C# 2.0 - Parte 1
Compactação com GZipStream e DeflateStream
Resolva seus problemas do dia-a-dia com Elevate
Criando e Lendo Cookie
Avaliando regras de negócio dinamicamente em C#
Integrando sua Aplicação .Net com Twitter
C# 4.0
Adicionando Menu no DataGridView
Persistindo TreeView no Banco de Dados
MP3 player com DirectX
Mensagem em JavaScript com .NET
Reproduzindo mp3 no .NET com C#
Receitas para o fim de ano para empresas de software
Sobrecarga, Herança, Polimorfismo e Exceção em C#
Qual a razão para incentivar as comunidades técnicas?
Visual Studio e seus Containers
Comparativo de performance: LINQ, Lambda e Dynamic LINQ
Produtos relacionados Topo
Pacote: Promoção: Portal de Vídeos .Net + CD Novidades das Linguagens (válido somente para pagamento via boleto bancário)
Pacote: Promoção Linq To SQL (válido somente para pagamento via boleto bancário)
Livro: Programando C# 3.0 - 5º Edição
Livro: Crystal Reports 2008 - O Guia Completo
Livro: C# 2008 Para Leigos
Livro: Microsoft Visual C# 2008 Express Edition - Aprenda na Prática
CD/DVD: DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
Livro: Profissional C# e a Plataforma .NET 3.5 Curso Completo
Pacote: Pacote promocional Linq to SQL
CD/DVD: DVD de Treinamento E-Commerce com Visual Web Developer
Livro: Programando .NET 3.5
Livro: LINQ e C# 3.0 - A Solução em Consultas para Desenvolvedores
Livro: LINQ em Ação
CD/DVD: DVD de Treinamento - Crie uma aplicação ASP.NET com LINQ TO SQL
Livro: C# 3.0 Guia de Bolso
Livro: Desenvolvendo Information Cards e CardSpace: Do Iniciante ao Profissional
Livro: Desenvolvimento em Camadas com C# .NET
Livro: Use a Cabeça C#
Livro: LINQ Guia de Bolso
Livro: ASP.NET 2.0 Web Parts em Ação
CD/DVD: DVD de Treinamento Explorando o LINQ para SQL
CD/DVD: CD de Treinamento – Implementando AJAX em páginas ASP.NET 3.5 com o Visual Studio .NET 2008
Livro: Soa na Prática - A arte da modelagem de Sistemas Distribuídos
Livro: C# Guia de Consulta Rápida
Livro: Windows Presentation Foundation
Livro: Pro WF Windows Workflow no .NET 3
Livro: Como programar com ASP.Net e C#
CD/DVD: CD de Treinamento sobre ASP.NET 2.0 Básico
CD/DVD: CD de treinamento: Um mergulho no Controle GridView do ASP.NET 2.0
E-Book: Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Livro: Análise de Valor Agregado - 3a. edição
© Copyright 2001-2010 Codeline Editora, Comércio e Tecnologia Ltda. | Política de privacidade e de uso | Anuncie | Fale conosco

» Site hospedado na Porta 80 Web Hosting «
Nossos números
Dicas: 1.314
Códigos/scripts: 279
Funções de VBScript : 90
Funções JScript : 05
Livros: 1.805
Notícias: 1.942
Artigos: 2.746
Cases: 14
Oportunidades: 4.185
Publicidade

Conheça a loja do Linha de Código.

Microsoft indica Linha de Código.

Assine a Revista Mundo .NET
Portal de Vídeos .NET - os melhores vídeos .NET estão aqui
Baixe o Visual Studio 2010 Beta
Revista Codificando .Net

Siga-nos no Twitter

Linha de Código no Orkut
Fórum de discussão do portal Linha de Código
Feeds
Oportunidades
Notícias
Artigos
Artigos personalizado
       (Por assunto)
Artigos personalizado
       (Por autor)
Portal Vídeos .NET
Portal Vídeos Delphi
LC Blog
       (Onde você faz a notícia)
Promoções
Promoção Mobile (válido somente para pagamento via boleto bancário)
Promoção Mobile (válido somente para pagamento via boleto bancário)
De: R$ 239,00
Por: R$ 146,00
Promoção: Portal de Vídeos .Net + CD Novidades das Linguagens (válido somente para pagamento via boleto bancário)
De: R$ 162,00
Por: R$ 89,00
Promoção VSTS (válido somente para pagamento via boleto bancário)
De: R$ 219,00
Por: R$ 146,00
Promoção Linq To SQL (válido somente para pagamento via boleto bancário)
De: R$ 249,00
Por: R$ 156,00
Promoção ASP.Net com Banco de Dados (válido somente para pagamento via boleto bancário)
De: R$ 249,00
Por: R$ 146,00
CDs
DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
De: R$ 83,00
Por: R$ 73,00
Curso completo de MySQL
Por: R$ 89,00
DVD de Treinamento - ISA Server 2006 - Implementação
De: R$ 83,00
Por: R$ 73,00
CD de Treinamento Adobe Photoshop CS4 Extended – 3D Arte
De: R$ 83,00
Por: R$ 53,00
DVD de Treinamento - Recursos avançados do Windows Mobile 6
De: R$ 83,00
Por: R$ 73,00
Livros
Aprendendo SQL
Aprendendo SQL
Por: R$ 83,00
Web Services SOAP em Java
Novatec
Por: R$ 42,00
Guia Mangá de Bancos de Dados
Novatec
Por: R$ 39,00
Guia Mangá de Estatística
Novatec
Por: R$ 39,00
Guia Mangá de Eletricidade
Novatec
Por: R$ 39,00
E-Books
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Por: R$ 30,00
Manual de Estudos - Exame 70-291 - Windows Server 2003 (606 páginas) - entrega via download
Por: R$ 30,00
Dominando MS – Visio ® em 20 Passos - Melhores Práticas em Gestão de Projetos (entrega via download)
Por: R$ 30,00
MS-Project® 2007 - Melhores Práticas de Gestão de Projetos - Dominando MS – Project ® em 20 Passos (e-book com entrega via download)
Por: R$ 20,00
Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Por: R$ 20,00
Os 10+ | Autores do dia
Israel Aéce
Júlio Cesar Fabris Battisti
Alfred Reinold Baudisch
Luiz Felipe de Freitas
Anderson Patricio
Ramon Durães
Robert Martim
Fernando Amaral
Eric C M Oliveira
Marcio Franco
Os 10+ | Artigos do dia
HTML Básico
HTML Avançado
SAP Business One - Implementação e Localização para o Brasil – Overview
PL/SQL - Procedures e Funções
ASP.NET 2.0 - Explorando o GridView
Tutorial de Tabelas Dinâmicas no Excel – Parte 1
PHP: Upload de imagens com segurança
Nota Fiscal Eletrônica - Geração, Assinatura e Transmissão
Criando aplicativos para o Orkut
Instalando Apache + MySQL + PHP 5 no Windows