之前写了数据库连接配置,这次说说映射文件的配置,即表映射【ORM的核心就是此啦!】。
下面我们使用最原始的手动配置hbm.xml文件。
步骤:
1、添加People类
1 | namespace NHibernateStudy |
2、添加People.hbm.xml文件【注意哦:生成操作要改为“嵌入的资源”——右击文件,选择属性】
1 |
|
3、hibenate.cfg.xml中添加映射文件配置【添加到session-factory节点内】
1 | <mapping resource="NHibernateStudy.People.hbm.xml" assembly="NHibernateStudy" /> |
4、可以操作People添加数据啦!
1 | ISessionFactory sessionFactory = (new Configuration()).Configure().BuildSessionFactory(); |
上述代码中有两个额外的要点,下面理一下
第一个是自动生成id的策略,第二个是formula的使用
1、官方提供了许多常用的ID生成策略,基本足够用了,当然也可以自己实现。【注:个人常用的应该是uuid.hex了,主要是使用guid的字符串】
详见官方文档:查看;此处仅接受个人常用
- | - - | - |
---|---|---|
identity | 数据库生成int型主键 | |
uuid.hex | System.Guid使用ToString()生成Guid | |
guid.comb | Guid类型标识符 |
其中uuid映射为字符串类型,guid映射为Guid类型。
2、关于formula的使用,主要用于一个字段不是直接来自于数据库,是通过计算或多表筛选得出的。上文中就使用firstname和lastname拼接fullname【sqlite中字符串拼接用‘||’】。
其中需要注意的:新增数据,保存后立即查询,formula不生效,需要执行session.clear()清空缓存以使生效,或者使用session.Evict(x)将之前加的数据从缓存中移除,如此,formula才能正确执行。