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
Geração automática do mapeamento objeto/relacional para o NHibernate usando MyGeneration
Por: Marcos Dell Antonio
[Entre em contato com o autor ]
Profissional certificado (MCPD, MCTS e MCP) em tecnologias da Microsoft e especialista em .NET e Visual Studio Team System. Site: www.marcosdellantonio.net.
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  
Geração automática do mapeamento objeto/relacional para o NHibernate usando MyGeneration
Publicado em: 19/01/2006

Apresento nesse artigo uma forma bem rápida e simples para gerar o mapeamento objeto/relacional para o NHibernate.

Para os que ainda não conhecem, o NHibernate é um framework para persistência de objetos em um banco de dados relacional. Ou seja, você instancia um objeto, carrega suas propriedades com os valores desejados e manda o NHibernate salvar esse objeto no banco. O NHibernate, através do objeto recebido, monta uma query SQL que será executada no banco de dados desejado.

Todo o processo de geração da query SQL é feito com auxílio dos arquivos de mapeamento. Normalmente para cada tabela do banco de dados são gerados dois arquivos:.hbm.xml e .cs. Aqui é que entra o MyGeneration: ele é um software que gera de forma rápida e simples esses dois arquivos para as tabelas do nosso banco de dados.

Não vou entrar em mais detalhes sobre persistência de objetos com o NHibernate, pois isso é assunto para outro artigo. No final desse, tem alguns links sobre isso.

- Softwares usados

MySQL 5.0 Community Edition: banco de dados que usarei para gerar o mapeamento.
Download: http://dev.mysql.com/downloads/mysql/5.0.html

MySQL Connector 1.0.7: provider .NET para acesso ao MySQL.
Download: http://dev.mysql.com/downloads/connector/net/1.0.html

MyGeneration 1.1.5.1: software que gera o mapeamento.
Download: http://www.mygenerationsoftware.com

- Instalação e configuração dos softwares

Também não vou detalhar a instalação dos softwares, afinal todas são bem intuitivas. Sobre a configuração deles, abaixo segue o que fiz:

MySQL: após instalar o MySQL, criei um banco de dados chamado MapOR e uma tabela chamada Cliente. Vou usar esse banco e essa tabela para criar o mapeamento, mas fique a vontade para criá-lo a partir de qualquer outro banco ou tabela, o processo é o mesmo. Veja na imagem abaixo a tabela criada.

MyGeneration: antes de configurar o MyGeneration instale o provider Connector.

Se no final da instalação do MyGeneration você mandou ele abrir, provavelmente uma janela Default Settings deve ter aparecido. Se você não abriu ainda o MyGeneration ou a tela ainda não apareceu, abra ele agora e no menu Edit clique em Default Settings. Nessa janela será configurado o acesso ao banco MySQL.

Na aba Connection configure o seguinte:

- Em Connection String, no campo Driver selecione MySQL2 e defina a string de conexão de acordo com suas configurações locais. Aqui ficou da seguinte forma:

- Em Language Mapping certifique-se que o campo Language esteja definido como MySQL Connector/Net (C#). Veja como ficou aqui:

- Em Database Target Mapping o campo DbTarget deve estar com o valor MySQL Connector/Net. Veja:

Pronto! O MyGeneration está configurado. Para ver se está funcionando, clique em Test Connection.

Antes de fecharmos a janela de configuração salve o que foi feito. Para isso, digite MySQL no campo Saved Connections e depois clique em Save.

- Gerando os arquivos de mapeamento

Usando o MyGeneration vamos gerar os arquivos .hbm.xml e .cs. Por padrão, o software não vem com os arquivos que precisamos para gerar código para o NHibernate, por isso vamos baixa-los. Todo o processo é muito simples e pode ser realizado de dentro do próprio software.

Clique em File - New - Template Browser. A janela a baixo deverá aparecer:

Veja que, como eu falei anteriormente, não há nenhum arquivo relacionado ao NHibernate.

No Template Browser clique no terceiro botão (Online Template Library - o globo). Ao clicar sobre ele a Online Template Library irá aparecer. É através dela que vou fazer o download do template necessário para gerar os arquivos de mapeamento do NHibernate. Veja abaixo uma imagem da Online Template Library:


 

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
Olá Marcos.

Estou tentando executar a aplicação, mas dá um erro, um único erro e estou batendo cabeça pra resolver...

Compiler Error Message: CS0305: Using the generic type 'System.Collections.Generic.IList<T>' requires '1' type arguments

Line 14: public class AtividadeDAO
Line 15: {
Line 16: public static IList RetornaAtividade(string column, int maximumRows, int startRowIndex)
Line 17: {
Line 18: ISession session = NHibernateHelper.GetSession();

o erro se dá na linha 16. Pesquisei em muitos sites e não achei a solução pra isso. A sintaxe do IList está diferente do que encontrei. Não sei o que fazer. Help
Quem enviou: Simone
Postado em: 08/02/2008 00:00:00
Ola Marcos, eu nao estou conseguindo fazer o MyGeneration conectar no MySQL, eu instalei tudo q estava no Tutorial(MySQL, MyGeneration e MySQL Connector .NET)

esta dando o seguinte erro:
http://img74.imageshack.us/img74/593/ssfw9.jpg
vlws
Quem enviou: Raphael
Postado em: 03/08/2007 00:00:00
Boa Tarde,
Primeiramente gostaria de parabenizá-lo, o artigo já é uma referencia para iniciantes em NHibernate.
Estou com problemas no Nhibernate e gostaria de saber se pode me ajudar.

Quando faço uma atualização no banco de um registro ele não é automáticamente refletido no meu site, somente quando são inserções, outro problema é que quando atualizo um registro pelo próprio código do site e quando vou visualizar o dados editado ele traz os dados antigos sendo que ficar apertando F5 a página fica alternando entre o dado antigo e o dado recem atualizado.

Utilizei a ferramenta Visual Paradigm que modela a aplicação em UML e já gera todo o código de acesso e os DAOs para acessos as classes, ferramenta muito boa mas acho que tem algo no código gerado que está com problemas.

Desde já agradeço pela ajuda.
Quem enviou: Pedro Camargo
Postado em: 10/05/2007 00:00:00
Gostei muito do artigo. Porem tentei fazer aqui usando um banco de dados oracle. eu seleciono o banco, e não lista nenhuma tabela. Voce poderia me ajudar?
Quem enviou: Edson Gomes
Postado em: 17/04/2007 00:00:00
Na realidade, estou com uma dificuldade e gostaria se poderia me ajudar.

Quero ciar um mapeamento automático dentro do VB.

Assim que inicializo gostaria de criar este mapeamento.

EX: servidor XX com a pasta YY
h:\xx\yy

obrigado pela atenção

victor
Quem enviou: victor borges
Postado em: 25/08/2006 00:00:00
Ótimo artigo! Uma pergunta: existe alguma ferramenta similar ao MyGeneration para SQL Server 2000?
Obrigado pela atenção.
Quem enviou: Fellipe
Postado em: 27/06/2006 00:00:00
Valeu Gabriel! Obrigado.
Quem enviou: Marcos D. A. de Souza
Postado em: 25/01/2006 00:00:00
Muito bom o artigo! Persistência de objetos é show de bola. Um abraço.
Quem enviou: Gabriel Cassalho
Postado em: 19/01/2006 00:00:00
Outros artigos do autor Topo
Visual Studio Team System: mais qualidade aos times de desenvolvimento de software
Visual Studio Team System - Por onde eu começo?
Primeiras imagens do Visual Studio Team System 2010
Usando o recurso "Auto Complete" no Windows Forms 2.0
Personalizando colunas, linhas e células de um DataGridView
C#.NET: Desenvolvendo aplicações usando a tecnologia WinFX
Usando Nullable Types com NHibernate para campos DateTime
Criando uma aplicação Web em C# usando o NHibernate
.NET: Drag and Drop na prática usando TableLayoutPanel
Tratamento global de exceções em aplicações Windows Forms
Passo a passo como acessar o banco de dados FireBird usando C#.Net, FireBird .Net Data Provider, SharpDevelop e IBExpert
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: Crystal Reports 2008 - O Guia Completo
Livro: Microsoft Visual C# 2008 Express Edition - Aprenda na Prática
CD/DVD: DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
Pacote: Pacote promocional Linq to SQL
CD/DVD: DVD de Treinamento E-Commerce com Visual Web Developer
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: Desenvolvimento em Camadas com C# .NET
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: C# Guia de Consulta Rápida
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)
E-Book: ASP.NET Ajax com C# e VB.NET (E-Book com entrega via download)
CD/DVD: CD de Treinamento - Desenvolvendo uma aplicação Smart Client com Visual Studio 2005, C#, Web Services e Banco de Dados
CD/DVD: CD de Treinamento sobre LINQ to SQL para iniciantes com Visual Studio .Net 2008
CD/DVD: CD de Treinamento sobre ADO.NET para Iniciantes
CD/DVD: CD de Treinamento Novidades das Linguagens C# 3.0 e VB 9 (Visual Basic 9)
Livro: Treinamento Profissional em C#. Net
Livro: Enterprise Library Total
CD/DVD: CD de Treinamento Introdução a .NET com C# - Visual Studio 2005
Livro: Dicas e Truques .NET
Livro: Treinamento Avançado em NET
CD/DVD: CD ASP.NET 2.0 - Atualização Rápida (Visual Studio .NET 2005)
Livro: Macromedia Flash MX 2004 Dicas Geniais
© 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