1, 一对一。

对于数据量比较大的时候,考虑查询的性能,肯能会把一个对象的属性分到两个表中存放;比如用户和用户资料,经常使用的一般是Id和用户名,用户资料(学校,籍贯等)是不经常被查询的,所以就会分成两个表。实体和映射如下:

使用以下代码插入数据:

public ActionResult InitData()

{

using (var session = MvcApplication.SessionFactory.OpenSession(new DebugInterceptor()))

using (var transaction = session.BeginTransaction())

{

try

{

for (int i = 0; i < 10; i++)

{

User user = new Models.User

{

Name = "FuzhePan_" + i

};

session.Save(user);

UserProfile profile = new UserProfile

{

UserId = user.Id,

Address = "山东山东山东_" + i,

School = "chsoolssss_" + i

};

session.Save(profile);

}

transaction.Commit();

}

catch (Exception)

{

transaction.Rollback();

throw;

}

}

return Content("搞定");

}

以下代码进行数据展示:

结果:

2,一对多 && 多对一。

一对多的关系是最常用的,比如在一个问答系统中,一个用户对应多个问题。

首先添加用户、问题实体和相应映射:

[Class(Table = "NH_User")]

public class User

{

[Id(1, Name = "Id", TypeType = typeof(long), Column = "Id", UnsavedValue = "0")]

[Generator(2, Class = "native")]

public virtual long Id { get; set; }

[PropertyAttribute(Column = "Name", TypeType = typeof(string))]

public virtual string Name { get; set; }

[OneToOne]

public virtual UserProfile UserProfile { get; set; }

[Bag(0, Table = "Question", Lazy = CollectionLazy.True, Cascade ="all")]

[Key(1, Column = "UserId")]

[OneToManyAttribute(2, ClassType = typeof(Question))]

public virtual List<Question> Questions { get; set; }

}

[Class]

public class Question

{

[Id(1, Name = "Id")]

[Generator(2, Class = "native")]

public virtual long Id { get; set; }

[Property]

public virtual long UserId { get; set; }

[Property]

public virtual string Subject { get; set; }

[Property]

public virtual string Body { get; set; }

[ManyToOne(0, Column = "UserId", Insert = false, Update = false)]

public User User { get; set; }

}

User实体添加了一个Question集合,并配置其对应着Question表,Lazy设置延迟加载,通过Key.Column配置逻辑外键是Question中的UserId,通过OneToMany配置用户和问题是一对多的关系。

在Question中,通过ManyToOne配置多队以的关系,Insert=false和Update=false表示当我们插入或修改一个Question的时候并不会级联插入或修改其所对应的User实体。

Bag其实是NHibernate所依赖的Iesi.Collections.dll库中所提供的集合之一,下面对所有集合进行说明:

Bag:对象集合,每个元素可以重复。在.Net中相当于IList或者IList<T>实现。

Set:对象集合,每个元素必须唯一。在.Net中相当于ISet或者ISet<T>实现。

List:整数索引对象集合,每个元素可以重复,在.Net中相当于ArraryList或者List<T>实现。

Map:键值对集合。在.Net中相当于HashTable或者IDictionary<Tkey,TValue>实现。

父级和子级的关系通过inverse配置,级联操作通过Cascade控制。对于一对多的情况,类之间的关系默认是由父级来维护,如果想让自己维护,则需要inverse=true。

Casecade控制级联操作,值有:,none\save-update\delete\all\all-delete-ophan,默认值为none。

none:不进行级联操作,但删除父级时,会将子级的外键置为null。

save-update:保存和修改父级的子级集合时,会同步到数据库中。

delete:删除操作同步到数据库。

all:包括所有,但删除父级时,会将父级关联的外键置为null。

all-delete-ophan:和all的区别是,删除父级时,会级联删除关联的子级。

3,多对多。

多对多的情况,一般通过一个中间表转换成一对多的形式。但NHibernate支持直接配置两个类是多对多,从而忽略中间表的存在。这种情况不常用,故略之。

使用NHibernate(7)-- 一对一 && 一对多 && 多对多的更多相关文章

  1. JPA级联(一对一 一对多 多对多)注解【实际项目中摘取的】并非自己实际应用

    下面把项目中的用户类中有个:一对一  一对多  多对多的注解对应关系列取出来用于学习      说明:项目运行正常 问题类:一对多.一对一.多对多 ============一对多 一方的设置 @One ...

  2. Python进阶----表与表之间的关系(一对一,一对多,多对多),增删改查操作

    Python进阶----表与表之间的关系(一对一,一对多,多对多),增删改查操作,单表查询,多表查询 一丶表与表之间的关系 背景: ​ ​ ​  ​ ​ 由于如果只使用一张表存储所有的数据,就会操作数 ...

  3. mybatis 一对一 一对多 多对多

    一对一 一对多 多对多

  4. day 69-70 一对一 一对多 多对一联表查询

    day 69 orm操作之表关系,多对多,多对一 多对一/一对多, 多对多{类中的定义方法} day69 1. 昨日内容回顾 1. 单表增删改查 2. 单表查询API 返回QuerySet对象的: 1 ...

  5. JPA 一对一 一对多 多对一 多对多配置

    1 JPA概述 1.1 JPA是什么 JPA (Java Persistence API) Java持久化API.是一套Sun公司 Java官方制定的ORM 方案,是规范,是标准 ,sun公司自己并没 ...

  6. MySQL一对一:一对多:多对多: 实例!!!!

    学生表和课程表可以多对多 一个学生可以学多门课程 一门课程可以有多个学生: 多对多 *** 一个学生对应一个班级 一个班级对应多个学生: 一对多 *** 一个老师对应多个学生 多个学生对应一个老师:一 ...

  7. 初学者易上手的SSH-hibernate04 一对一 一对多 多对多

    这章我们就来学习下hibernate的关系关联,即一对一(one-to-one),一对多(one-to-many),多对多(many-to-many).这章也将是hibernate的最后一章了,用于初 ...

  8. SQLAlchemy_定义(一对一/一对多/多对多)关系

    目录 Basic Relationship Patterns One To Many One To One Many To Many Basic Relationship Patterns 基本关系模 ...

  9. MySQL一对一:一对多:多对多

    学生表和课程表可以多对多 一个学生可以学多门课程 一门课程可以有多个学生: 多对多 *** 一个学生对应一个班级 一个班级对应多个学生: 一对多 *** 一个老师对应多个学生 多个学生对应一个老师:一 ...

随机推荐

  1. 5.Firedac错误信息

    主要错误信息属性: 1.EFDDBEngineException Errors -- TFDDBError对象集合. ErrorCount --错误的记录数 Kind -- DBMS的错误集合. Me ...

  2. Hadoop HDFS编程 API入门系列之HdfsUtil版本2(七)

    不多说,直接上代码. 代码 package zhouls.bigdata.myWholeHadoop.HDFS.hdfs1; import java.io.FileInputStream;import ...

  3. javascript高级程序设计--笔记01

    概述 JavaScript的实现包含三个部分: 1  核心(ECMAScript)   提供核心语言功能 2  文档对象模型(DOM)  一套提供了访问以及操作网页内容的API 3  浏览器对象模型( ...

  4. 第一零二天上课 PHP TP框架 引入文件路径问题和调用验证码的方式

    外部文件引入到视图模板的方式       1,将外部文件放在Public文件夹下,用load标签引入       2,在模板出书写引入代码(方法有很多,只有以下方法不容易出问题) <load h ...

  5. python 操作exls学习之路1-openpyxl库学习

    这篇要讲到的就是如何利用Python与openpyxl结合来处理xlsx表格数据.Python处理表格的库有很多,这里的openpyxl就是其中之一,但是它是处理excel2007/2010的格式,也 ...

  6. 百思不得骑姐的问题——难道是控件的bug?

    直接进入主题,困惑了一下午了. 要实现的功能: winform的checkedlistbox控件 点击  “全部”  就都选上,可是如果点击过快就会出现如上现象,下面选项未显示选中. 代码如下: pr ...

  7. jQuery的append和appendTo

    这两个关键词,Insus.NET刚开始学习jQuery时,也被它弄得不好理解.现用得多了,运行与理解也不难了. 查了英文词典append的意思是“添加,附加”: 而后者appendTo意思是“ 添加至 ...

  8. mfc中CString转化为string的方法

    LL(1)分析法实验的mfc做到最后因为CString转化为string的问题卡了一个多小时,也是惨,网上各种方法找过都不行.幸亏最后还是找到几行代码搞定了.特此mark一下. USES_CONVER ...

  9. quick-cocos2d-x之testlua之VisibleRect.lua

    require "extern" --这个类找到了可视区域的9个点的坐标:左上.上的中点.右上.左的中点.左下.下的中点.右下.右的中点.一般用于使用相对坐标的场合,解决自适应屏幕 ...

  10. php get_magic_quotes_gpc()函数

    magic_quotes_gpc函数在php中的作用是判断解析用户提示的数据,如包括有:post.get.cookie过来的数据增加转义字符“\”,以确保这些数据不会引起程序,特别是数据库语句因为特殊 ...