NHibernate初学四之关联一对一关系
1:数据库脚本,创建两张表T_Area、T_Unit,表示一个单位对应一个地区,在单位表中有个AreaID为T_Area表中的ID;

CREATE TABLE [dbo].[T_Area](
[ID] [int] IDENTITY(1,1) NOT NULL,
[AreaName] [nvarchar](50) COLLATE Chinese_PRC_CI_AS NULL,
CONSTRAINT [PK_T_Area] PRIMARY KEY CLUSTERED
(
[ID] ASC
)WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY] CREATE TABLE [dbo].[T_Unit](
[ID] [int] IDENTITY(1,1) NOT NULL,
[UnitName] [nvarchar](50) COLLATE Chinese_PRC_CI_AS NULL,
[AreaID] [int] NULL,
CONSTRAINT [PK_T_Unit] PRIMARY KEY CLUSTERED
(
[ID] ASC
)WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY]

![]() |
![]() |
2:实体代码如下:

namespace Wujy.ModelLibrary.Entity
{
public class AreaModel
{
public virtual int Id { get; set; }
public virtual string Areaname { get; set; }
public virtual UnitModel unit { get; set; }
}
} namespace Wujy.ModelLibrary.Entity
{
public class UnitModel
{
public virtual int Id { get; set; }
public virtual string Unitname { get; set; }
public virtual int? Areaid { get; set; }
public virtual AreaModel area { get; set; }
}
}

3:XML映射文件的内容:
3.1 AreaModel.hbm.xml文件内容

<hibernate-mapping assembly="Wujy.ModelLibrary" namespace="Wujy.ModelLibrary.Entity" xmlns="urn:nhibernate-mapping-2.2">
<class name="AreaModel" table="T_Area" lazy="true" >
<id name="Id" column="ID">
<generator class="identity" />
</id>
<property name="Areaname">
<column name="AreaName" sql-type="nvarchar" not-null="false" />
</property>
<one-to-one name="unit" cascade="all"></one-to-one>
</class>
</hibernate-mapping>

3.2 UnitModel.hbm.xml文件内容

<hibernate-mapping assembly="Wujy.ModelLibrary" namespace="Wujy.ModelLibrary.Entity" xmlns="urn:nhibernate-mapping-2.2">
<class name="UnitModel" table="T_Unit" lazy="true" >
<id name="Id" column="ID">
<generator class="identity" />
</id>
<property name="Unitname">
<column name="UnitName" sql-type="nvarchar" not-null="false" />
</property>
<property name="Areaid">
<column name="AreaID" sql-type="int" not-null="false" />
</property>
<one-to-one name="area" cascade="all"></one-to-one>
</class>
</hibernate-mapping>

注意:Cascade:则表示一种级联操作,它的值有none\save-update\delete\all\all-delete-ophan,它主要作用是在父类子类之间进行操作时,哪些操作会对父类(如班级Class类)、子类(Student)有影响。在NHibernate社区,Cascade默认值为none。
4:主要代码如下,其它DAL层的代码可以见文章后面的源代码下载,其中Button3_Click中的代码里面有获得model.area.Areaname areamodel.unit.Unitname;

protected void Button1_Click(object sender, EventArgs e)
{
AreaModel model = new AreaModel();
model.Areaname = "厦门";
AreaBll.Add(model);
Response.Write("成功");
} protected void Button2_Click(object sender, EventArgs e)
{
UnitModel model = new UnitModel();
model.Unitname = "软件园";
model.Areaid = 1;
UnitBll.Add(model);
Response.Write("成功");
} protected void Button3_Click(object sender, EventArgs e)
{
UnitModel model = UnitBll.findById(1);
Response.Write(model.area.Areaname + "|" + model.Areaid + "|" + model.Unitname); AreaModel areamodel = AreaBll.findById(1);
Response.Write("<br/>"+areamodel.unit.Unitname);
} protected void Button4_Click(object sender, EventArgs e)
{
UnitModel model = UnitBll.findById(1);
UnitBll.Remove(model);
Response.Write("成功");
}

效果图:
5:删除后的效果图,由于XML映衬文件设置cascade="all",都同样把数据库中两张表都删除:

UnitModel model = UnitBll.findById(1);
UnitBll.Remove(model);
Response.Write("成功"); 或 AreaModel model = AreaBll.findById(1);
AreaBll.Remove(model);
Response.Write("成功");

6:one-to-one的XML属性说明:

<one-to-one
name="PropertyName"
class="ClassName"
cascade="all|none|save-update|delete"
constrained="true|false"
fetch="join|select"
property-ref="PropertyNameFromAssociatedClass"
access="field|property|nosetter|ClassName"
/> (1) name: 属性的名字。
(2) class (可选 - 默认是通过反射得到的属性类型):被关联的类的名字。
(3) cascade(级联) (可选) 表明操作是否从父对象级联到被关联的对象。
(4) constrained(约束) (可选) 表明该类对应的表对应的数据库表,和被关联的对象所对应的数据库表之间,通过一个外键引用对主键进行约束。 这个选项影响Save()
和Delete()在级联执行时的先后顺序以及 决定该关联能否被委托(也在schema export tool中被使用).
(5) fetch (可选 - 默认设置为select): 在外连接抓取或者序列选择抓取选择其一.
(6) property-ref: (可选) 指定关联类的属性名,这个属性将会和本类的主键相对应。如果没有指定,会使用对方关联类的主键。
(7) access (可选 - 默认是 property): NHibernate用来访问属性的策略。

感谢您的阅读,坚持每天进步一点点,离成功就更新一步;希望文章对您有所帮助;源代码下载
转载至:http://www.cnblogs.com/wujy/p/3602200.html
NHibernate初学四之关联一对一关系的更多相关文章
- NHibernate初学五之关联一对多关系
1:创建两张表T_Country.T_Person:其中T_Person表中有一个CountryID对应T_Country的ID,一个Country可以对应多个Person CREATE TABLE ...
- NHibernate初学六之关联多对多关系
1:创建三张表T_Course.T_Student.T_Middle:其中一个学生可以对应多个课程,一个课程也可以对应多个学生,用T_Middle存放它们的关系内容: CREATE TABLE [db ...
- Entity Framework - 理清关系 - 基于外键关联的单向一对一关系
注:本文针对的是 Entity Framework Code First 场景. 之前写过三篇文章试图理清Entity Framework中的一对一关系(单相思(单向一对一), 两情相悦(双向一对 ...
- Hibernate 、多表关联映射 - 一对一关系映射(one- to-one)
hibernate.cfg.xml: <hibernate-configuration> <session-factory name="sessionFactory&quo ...
- Entity Framework - 基于外键关联的单向一对一关系
代码的世界,原以为世界关系很简单,确道是关系无处不在.NET世界里ORM框架中EntityFramework作为其中翘楚,大大解放了搬砖工作的重复工作,着实提高了不少生产力,而也碰到过不少问题!比如关 ...
- hibernate 关系映射之 单向外键关联一对一
这里的关系指的是对象与对象之间的关系 注解方式单向关联一对一: //这个类描述的husband是一个对应一个wife的 import javax.persistence.Entity; import ...
- 0049 MyBatis关联映射--一对一关系
世上的事务总不是孤立存在的,表现在Java类里面,则是类与类之间的关系,比如继承is-a.依赖use-a.关联has-a,反映在数据库中,则是表与表之间的关系,比如外键 关联关系存在着以下几种类型:一 ...
- hibernate(五) hibernate一对一关系映射详解
序言 之前讲解了一对多(单向.双向).多对多(双向),今天就讲解一下最后一个关系,一对一. 心情不错.状态也挺好的,赶紧写一篇博文造福一下大家把. --WH 一.一对一关系的概述 一对一关系看起来简单 ...
- Hibernate学习(五)———— hibernate一对一关系映射详解
一.一对一关系的概述 一对一关系看起来简单,其实也挺复杂的.其中关系就包含了四种,单向双向和主键关联外键关联. 什么意思呢,也就是包含了单向一对一主键关联.双向一对一主键关联,单向一对一外键关联,双向 ...
随机推荐
- ny58 最小步数
最少步数 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 这有一个迷宫,有0~8行和0~8列: 1,1,1,1,1,1,1,1,1 1,0,0,1,0,0,1,0,1 1 ...
- ios应用下架方法(说明)
ios应用下架方法(说明) 正在审核中的: 在binary details里边 reject按钮 已经上架的: 在itunesconnect里的app详情里面找到rights and pricin ...
- nrm 的使用说明
nrm -- NPM registry 管理工具 开发的npm registry 管理工具 nrm, 能够查看和切换当前使用的registry, 最近NPM经常 down 掉, 这个还是很有用的哈哈 ...
- gulp自动化ES6转ES5
npm install --save-dev gulp npm install --save-dev gulp-babel npm install --save-dev babel-preset-es ...
- python学习笔记(20)--生成点拨【已放弃】
说明: 1. 本来是要写个脚本生成点拨rtf给讲师朗读的,不过实在是安装不上pywin32这个模块,虽然下载下来了whl文件,pip install 也能安装,但是导入pywin32.win32com ...
- DRAM 各项基本参数记录
记录一下DRAM的各项基本参数 tCL CAS Latency CAS 潜伏期, 列地址寻找/读写命令执行完毕,准备要读出来,需要一个延时缓一缓 tRAS: RAS Active Timeing 行有 ...
- Ubuntu下安装Apache
Ubuntu为我们提供了 su apt-get install 命令,通过它你可以很方便地安装一些软件,这些软件是放在Ubuntu放置在各个地方的服务器上面,如果你想安装的软件是比较常见的,一般都可以 ...
- nginx日志分析利器GoAccess(转)
面试的时候一定会被面到的问题是:给出web服务器的访问日志,请写一个脚本来统计访问前10的IP有哪些?访问前10的请求有哪些?当你领略过goaccess之后,你就明白,这些问题,除了考验你的脚本背诵记 ...
- shell脚本----if(数字条件,字符串条件,字符串为空)
二元比较操作符,比较变量或者比较数字. 注意数字与字符串的区别. 1.整数比较 -eq 等于,如:if [ "$a" -eq "$b" ] -ne 不等于,如 ...
- [转]Private Libraries、Referenced Libraries、Dependency Libraries的区别
一.v4.v7.v13的作用和用法 1.Android Support V4, V7, V13是什么? 本质上就是三个java library. 2.为什么要有support库? 是为了解决软件的 ...