NHibernate中主键生成策略详解.
2009-04-13 17:16 chenkai 阅读(3356) 评论(0) 编辑 收藏 举报最近一直在看NHibernate其中关于主键生成策略这块总是不太清楚,关于属性的定义过于模糊,出现一定异常发现处理方法很有限,下午利用一定时间在网上看了一定资料,决定来整理关于主键生成策略的完整的详细资料。因为学习NHibernate时间还不是太长,难免其中也许有一定纰漏,请大家谅解并指出。
看看格式:
--在id字节中关于Generator中配置
<id
name="PropertyName"
type="typename"
column="column_name"
unsaved-value="any|none|null|id_value"
access="field|property|nosetter|ClassName">
<generator class="generatorClass"/>
</id>
<id
name="PropertyName"
type="typename"
column="column_name"
unsaved-value="any|none|null|id_value"
access="field|property|nosetter|ClassName">
<generator class="generatorClass"/>
</id>
其实在<id>配置节点中,<generator>子节点是可选的,属性class的是一个.NET类名称,用来为该持久化类生成一个唯一的标识,这个Class赋值有两种—
A:系统内置生成器的名称(很常用) B:自定义的类名称(这个自定义类实现了唯一标示)
B方法说明:
B:方法一般很少用,系统内置生成器就够用了,如果定义的自定义类中,需要传入使用的参数
可用Param来传递参数 具体实现如下:
<id name="Id" type="Int64" column="uid" unsaved-value="0">
<generator class="NHibernate.Id.TableHiLoGenerator">
<param name="table">uid_table</param>
<param name="column">next_hi_value_column</param>
</generator>
</id>
可用Param来传递参数 具体实现如下:
<id name="Id" type="Int64" column="uid" unsaved-value="0">
<generator class="NHibernate.Id.TableHiLoGenerator">
<param name="table">uid_table</param>
<param name="column">next_hi_value_column</param>
</generator>
</id>
A方法说明:
A方法使用中,关于内置的生成器需要熟练掌握每个参数所执行动作,用来备查,具体的详细列表如下:
--具体每个参数具体说明如下:可根据个人情况来使用
increment
用于为int类型生成 唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。 在集群下不要使用。
identity
对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。数据库返回的主键值 返回的标识符是int类型的。
sequence
在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence), 而在Interbase中使用生成器(generator)。返回的标识符是int类型的。
hilo
使用一个高/低位算法来高效的生成int类型的标识符。给定一个表和字段(默认分别是是hibernate_unique_key 和next_hi)作为高位值得来源。 高/低位算法生成的标识符只在一个特定的数据库中是唯一的。在用户自行提供的连接中,不要使用这种生成器。
你可以使用where参数来指定表里面用了多少列数据, You can use the "where" parameter to specify the row to use in a table. This is useful if you want to use a single tabel for your identifiers, with different rows for each table.
seqhilo
使用一个高/低位算法来高效的生成int类型的标识符,给定一个数据库序列(sequence)的名字。
uuid.hex
用一个System.Guid的ToString()方法法生成字符串类型的标识符, 字符串的长度由format参数定义。
uuid.string
用一个新的System.Guid实例的byte[]转化为字符串作为标示符。
guid
使用新的System.Guid实例作为标示符。
guid.comb
使用Jimmy Nilsson的算法(请参阅http://www.informit.com/articles/article.asp?p=25862)生成一个新的System.Guid标示符。
native
根据底层数据库的能力选择identity, sequence 或者hilo中的一个。
assigned
让应用程序在 Save()之前为对象分配一个标示符。
foreign
使用另外一个相关联的对象的标识符。通常和<one-to-one>联合起来使用。
increment
用于为int类型生成 唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。 在集群下不要使用。
identity
对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。数据库返回的主键值 返回的标识符是int类型的。
sequence
在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence), 而在Interbase中使用生成器(generator)。返回的标识符是int类型的。
hilo
使用一个高/低位算法来高效的生成int类型的标识符。给定一个表和字段(默认分别是是hibernate_unique_key 和next_hi)作为高位值得来源。 高/低位算法生成的标识符只在一个特定的数据库中是唯一的。在用户自行提供的连接中,不要使用这种生成器。
你可以使用where参数来指定表里面用了多少列数据, You can use the "where" parameter to specify the row to use in a table. This is useful if you want to use a single tabel for your identifiers, with different rows for each table.
seqhilo
使用一个高/低位算法来高效的生成int类型的标识符,给定一个数据库序列(sequence)的名字。
uuid.hex
用一个System.Guid的ToString()方法法生成字符串类型的标识符, 字符串的长度由format参数定义。
uuid.string
用一个新的System.Guid实例的byte[]转化为字符串作为标示符。
guid
使用新的System.Guid实例作为标示符。
guid.comb
使用Jimmy Nilsson的算法(请参阅http://www.informit.com/articles/article.asp?p=25862)生成一个新的System.Guid标示符。
native
根据底层数据库的能力选择identity, sequence 或者hilo中的一个。
assigned
让应用程序在 Save()之前为对象分配一个标示符。
foreign
使用另外一个相关联的对象的标识符。通常和<one-to-one>联合起来使用。