NHibernate 学习 第九天 外键关系的处理之一对一

本文介绍如何在Users表中通过外键关联Roles表,实现一对一的关系。主要步骤包括:在User.cs类中添加虚拟属性UserRole来表示角色关联,并在User.hbm.xml文件中移除R_Id字段,使用one-to-one节点来定义这种一对一的关系。

Users 表中有一个外键 是Roles表关联的,我们要将其关联起来

1. 在User.cs 里面添加一个外键对象

因为Users - Roles 是 one to one 的关系,那么在这我们只需要处理Users里面的信息

 

 public class User
    {
        
public virtual int Id { getset; }
        
//public virtual string U_name { get; set; }
        
//public virtual string U_pwd { get; set; }
        
//public virtual int R_id { get; set; }

        
public virtual LoginInfo LogInfo { getset; }

        
public virtual Role UserRole { getset; }
    }

 

2. 在User.hbm.xml文件里面干掉 R_Id 的字段,添加one to one 的节点

 

<!-- 这里应该是外键关系,先用一般的关系来处理 -->
   
<!-- <property name="R_id" column="r_id" not-null="false" type="int" length="4"/>-->
    
<one-to-one
      name
="UserRole"
      cascade
="all"
      
class="llr.Models.Role, llr.Models"
   
/>

 

OK 。搞定

 

 

转载于:https://www.cnblogs.com/mullr2005/archive/2011/06/11/2078267.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值