Una herramienta muy importante de NHibernate, a la vez, deseable por los ORM, es la generación de código.
Para generar el DDL de la base de datos, nos podemos valer de la información del esquema, que nos brindan los archivos de mapeo ó mapping files: hbm.xml.
Un vez que tenemos bien configurados estos archivos, podemos generar las tablas con solamente incluir un par de sentencias en .Net y configurar un archivo xml. Tambien se tiene que tener referenciado a NHibernate.
Código en C#:
using System;
using NHibernate.Cfg;
using NHibernate.Tool.hbm2ddl;
public class MyClass
{
public static void Main()
{
Configuration config = new Configuration();
config.Configure();
SchemaExport exporter = new SchemaExport(config);
//exporter.SetOutputFile(@"c:testDDL.sql");
exporter.Drop(true, true);
exporter.Create(true, true);
}
}
Archivo hibernate.cfg.xml (debe ir copiado en el directorio de salida):
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.0" >
<session-factory name="NHibernate">
<property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
<property name="connection.driver_class">NHibernate.Driver.FirebirdClientDriver</property>
<property name="connection.connection_string">
ServerType=1;
User=sysdba;password=masterkey;Database=C:ruraldata.fdb;
Pooling=false
</property>
<property name="show_sql">true</property>
<property name="dialect">NHibernate.Dialect.FirebirdDialect</property>
<property name="use_outer_join">true</property>
<property name="query.substitutions">true 1, false 0, yes 'Y', no 'N'</property>
<mapping assembly="RuralSolution.Entities" />
</session-factory>
</hibernate-configuration>
En este caso es la exportación del schema de una base de datos Firebird embebida.
Esta herramienta me ha sido de mucha utilidad. Estoy desarrollando una aplicación en SQL Server 2005 y NHibernate, pero, me dà cuenta que la aplicación debÃa ser portable, de modo que tuve que migrar la base de datos a una portable, y como Firebird está pasando todos los test de NH, la elegÃ. Ya tenÃa los hbm, asà que no requirió trabajo demás.
Importante para la generación con Firebird: en el directorio de salida entonces tendriamos que tener: fbembed.dll, FirebirdSql.Data.FirebirdClient.dll, y hibernate.cfg.xml.
Si quieren saber como trabajar con MyGeneration y Firebird embedded léanse este post de mi amigo Matias.