是否有可能從NHibernate配置文件生成數據庫表和c#類?之後,是否可以更改配置文件並非破壞性地更新表和配置文件?從NHibernate配置文件生成數據庫
你推薦任何工具來做到這一點嗎? (最好是免費的...)
是否有可能從NHibernate配置文件生成數據庫表和c#類?之後,是否可以更改配置文件並非破壞性地更新表和配置文件?從NHibernate配置文件生成數據庫
你推薦任何工具來做到這一點嗎? (最好是免費的...)
正如Joachim所說,它是您正在尋找的「hbm2ddl.auto」設置。
你可以通過這樣的代碼設置:
var cfg = new NHibernate.Cfg.Configuration();
cfg.SetProperty("hbm2ddl.auto", "create");
cfg.Configure();
而且你還可以將其設置在App.config文件:
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
<session-factory>
<property name="hbm2ddl.auto">create</property>
是的,可以從NHibernate配置文件生成數據庫表和C#類。讓我在這裏解釋這個例子。
1:Address.hbm.xml
<?xml version="1.0" encoding="UTF-8"?>
<hibernate-mapping
xmlns="urn:nhibernate-mapping-2.0"
default-cascade="none">
<class
name="Your.Domain.AddressImpl, Your.Domain"
table="[ADDRESS]"
dynamic-insert="true"
dynamic-update="true"
lazy="true">
<id name="Id" type="long" unsaved-value="0">
<column name="ID" sql-type="NUMERIC(19,0)"/>
<generator class="native"> </generator>
</id>
<property name="Address1" type="string">
<column name="ADDRESS1" not-null="true" unique="false" sql-type="VARCHAR(100)"/>
</property>
<property name="Address2" type="string">
<column name="ADDRESS2" not-null="true" unique="false" sql-type="VARCHAR(100)"/>
</property>
<property name="City" type="string">
<column name="CITY" not-null="true" unique="false" sql-type="VARCHAR(100)"/>
</property>
<property name="State" type="string">
<column name="STATE" not-null="true" unique="false" sql-type="VARCHAR(100)"/>
</property>
<property name="Zipcode" type="string">
<column name="ZIPCODE" not-null="true" unique="false" sql-type="VARCHAR(100)"/>
</property>
</class>
</hibernate-mapping>
第2步: 只需通過在配置文件中的時候,您的地址目標siply如下所示
using System;
namespace Your.Domain
{
public partial class Address
{
#region Attributes and Associations
private string _address1;
private string _address2;
private string _city;
private long _id;
private string _state;
private string _zipcode;
#endregion
#region Properties
/// <summary>
///
/// </summary>
public virtual string Address1
{
get { return _address1; }
set { this._address1 = value; }
}
/// <summary>
///
/// </summary>
public virtual string Address2
{
get { return _address2; }
set { this._address2 = value; }
}
/// <summary>
///
/// </summary>
public virtual string City
{
get { return _city; }
set { this._city = value; }
}
/// <summary>
///
/// </summary>
public virtual long Id
{
get { return _id; }
set { this._id = value; }
}
/// <summary>
///
/// </summary>
public virtual string State
{
get { return _state; }
set { this._state = value; }
}
/// <summary>
///
/// </summary>
public virtual string Zipcode
{
get { return _zipcode; }
set { this._zipcode = value; }
}
#endregion
}
}
第3步:與再次查看「Column」名稱屬性及其實際引用實際後端數據庫表「Address」的數據類型。
也有幫助您生成基於不同的輸入,如UML,或實際的數據庫架構等
查看「hbm2ddl.auto」設置所有這些文物爲您(在工具巨量配置或NHibernate.Cfg.Configuration)。使用「創建」,您可以從映射中重新創建整個數據庫模式,「更新」設置應該更新您的模式。