基本值类型(Basic value types)
基本的值类型大致可以粗糙的分为三组:System.ValueType
类型,System.Object
类型和支持大对象的System.Object
类型.和.NET类型一样,System.ValueType对应的列不能存储null
值,而System.Object可以.
表4.3 System.ValueType 映射类型
NHibernate 类型 | .NET 类型 | Database 类型 | 备注 |
---|---|---|---|
Boolean | System.Boolean | DbType.Boolean | 在没有指定类型(type ) 属性时的默认值 |
Byte | System.Byte | DbType.Byte | 在没有指定类型(type ) 属性时的默认值 |
Char | System.Char | DbType.StringFixedLength - 1 char | 在没有指定类型(type ) 属性时的默认值 |
DateTime | System.DateTime | DbType.DateTime -忽略毫秒 | 在没有指定类型(type ) 属性时的默认值 |
Decimal | System.Decimal | DbType.Decimal | 在没有指定类型(type ) 属性时的默认值 |
Double | System.Double | DbType.Double | 在没有指定类型(type ) 属性时的默认值 |
Guid | System.Guid | DbType.Guid | 在没有指定类型(type ) 属性时的默认值 |
Int16 | System.Int16 | DbType.Int16 | 在没有指定类型(type ) 属性时的默认值 |
Int32 | System.Int32 | DbType.Int32 | 在没有指定类型(type ) 属性时的默认值 |
Int64 | System.Int64 | DbType.Int64 | 在没有指定类型(type ) 属性时的默认值 |
PersistentEnum | 一个System.Enum | 潜在类型对应的DbType | 不用在映射文件指定 |
Single | System.Single | DbType.Single | 在没有指定类型(type ) 属性时的默认值 |
Ticks | System.DateTime | DbType.Int64 | type="Ticks" 必须被指定 |
TimeSpan | System.TimeSpan | DbType.Int64 | 在没有指定类型(type ) 属性时的默认值 |
Timestamp | System.DateTime | DbType.DateTime - 取决于数据库支持 | type="Timestamp" 必须被指定 |
TrueFalse | System.Boolean |
| type="TrueFalse" 必须被指定 |
YesNo | System.Boolean | DbType.AnsiStringFixedLength - 一个字符,'Y' 或者'N' | type="YesNo" 必须被指定 |
表4.4 System.Object 映射类型
NHibernate 类型 | .NET 类型 | Database 类型 | 备注 |
---|---|---|---|
AnsiString | System.String | DbType.AnsiString | type="AnsiString" 必须被指定 |
CultureInfo | System.Globalization.CultureInfo | DbType.String - 表明文化(culture)的5个字符 | 在没有指定类型(type ) 属性时的默认值 |
Binary | System.Byte[] | DbType.Binary | 在没有指定类型(type ) 属性时的默认值 |
Type | System.Type | DbType.String 容纳程序集全名 | 在没有指定类型(type ) 属性时的默认值 |
String | System.String | DbType.String | 在没有指定类型(type ) 属性时的默认值 |
表4.5 Large Object 映射类型
NHibernate 类型 | .NET 类型 | Database 类型 | 备注 |
---|---|---|---|
StringClob | System.String | DbType.String | type="StringClob" 必须被指定.整个字段被读入内存 |
BinaryBlob | System.Byte[] | DbType.Binary | type="BinaryBlob" 必须被指定. 整个字段被读入内存 |
Serializable | 任何被标记了可序列化属性(SerializableAttribute)的 | DbType.Binary | type="Serializable" 应该被指定. 如果不能为属性找到NHibernate类型,这是最后可依靠的类型。 |
要掌握NHibernate或者使用某种工具生成NHibernate的hbm.xml文件,应该了解这是一个NHibernate类型名的完整的层。type="integer"
被映射为Int32
NHibernateType,type="short"
被映射为Int16
NHibernateType.查看所有的转换你可以查看NHibernate.Type.TypeFactory
类的静态构造函数.
开发者创建属于他们自己的值类型也是很容易的。比如说,你可能希望持久化Int64
类型的属性,持久化成为VARCHAR
字段。NHibernate没有内置这样一种类型。自定义类型能够映射一个属性(或集合元素)到不止一个数据库表字段。比如说,你可能有这样的属性:Name {get; set;}
,这是String
类型的,对应的持久化到三个字段:FIRST_NAME
,INITIAL
, SURNAME
。
要实现一个自定义类型,可以实现NHibernate.IUserType
或NHibernate.ICompositeUserType
中的任一个,并且使用类型的全限定类名来声明属性。请查看NHibernate.DomainModel.DoubleStringType
这个例子,看看它是怎么做的。
<property name="TwoStrings" type="NHibernate.DomainModel.DoubleStringType, NHibernate.DomainModel"> <column name="first_string"/> <column name="second_string"/> </property>
注意使用<column>
标签来把一个属性映射到多个字段的做法。
虽然NHibernate内置的丰富类型和对component的支持意味着你可能很少需要使用自定义类型,至少对于你程序中经常出现的自定义类(并非实体)来说,这是一种好方法。比如说,MonetoryAmount
(价格总额)对比使用ICompositeUserType
来说更好,虽然它可以很容易的使用一个component实现。这样做的动机之一是抽象。通过自定义类型,以后假若你改变表示金额值的方法时,你的映射文件不需要更改,这就得到了保护。
你可强制NHibernate在生成的SQL中把标识符用引号前后包围起来,这需要在映射文档中使用反向引号(`)把表名或者字段名包围(可能比较拗口,请看下面的例子)。NHibernate会使用相应的SQLDialect
(方言)来使用正确的引号风格(通常是双引号,但是在SQL Server中是括号,MySQL中是反向引号)。
<class name="LineItem" table="`Line Item`"> <id name="id" column="`Item Id`"> <generator class="assigned"/> </id> <property name="itemNumber" column="`Item #`"/> ... </class>
允许在独立的映射文档中定义subclass
和joined-subclass
,直接位于hibernate-mapping
下。这就可以让你每次扩展你的类层次的时候,加入新的映射文件就行了。在子类的映射中你必须指定一个extends
属性,指明先前已经映射过的超类。如果你使用嵌入的资源(Embedded Resources)配置NHibernate, hbm.xml文件会自动配置为正确的顺序.如果手动添加或者在cfg.xml文件中指定它们,映射文件的排序是非常重要的!
<hibernate-mapping> <subclass name="Eg.Subclass.DomesticCat, Eg" extends="Eg.Cat, Eg" discriminator-value="D"> <property name="Name" type="String"/> </subclass> </hibernate-mapping>