NHibernate 多主键设置

数据库结构,3个字段,StudentName, ClassName, ClassDate,都为char类型,主键为StudenName + ClassName。

配置文件:

<?xml version="1.0" encoding="utf-8" ?>
 <hibernate-mapping xmlns="urn:nhibernate-mapping-2.0">
    <class name="CompoTest.Classes, CompoTest" table="Classes">
         <composite-id class="CompoTest.ClassInfo, CompoTest" name = "MyClassInfo">
              <key-property name="StudentName" type="String(10)" column="StudentName" />
              <key-property name="ClassName" type="String(10)" column="ClassName" />
         </composite-id>
         <property name="ClassDate" type="String(8)" column="ClassDate" />
   </class>
 </hibernate-mapping>

类:

 public class  Classes
 {
  public Classes()
  {

  }

  private System.String _ClassDate;
  public System.String ClassDate
  {
    get { return _ClassDate; }
   set { _ClassDate = value; }
  }

  private ClassInfo classInfo;
  public ClassInfo MyClassInfo
  {
    get { return classInfo; }
   set { classInfo = value; }
  }

 }

 public class ClassInfo
 {
  public ClassInfo()
  {
  }

  private string studentName;
  public string StudentName
  {
   set { studentName = value; }
   get { return studentName; }
  }

  private string className;
  public string ClassName
  {
   set { className = value; }
   get { return className; }
  }
 }

写几个测试用例:

  [Test]
  public void TestAdd()
  {
   ClassInfo classInfo = new ClassInfo();
   classInfo.ClassName = "Chinese";
   classInfo.StudentName = "Tom";

   Classes classes = new Classes();
   classes.ClassDate = "20041003";
   classes.MyClassInfo = classInfo;
   

   Configuration cfg = new Configuration();
   cfg.AddXmlFile("Classes.hbm.xml");
   ISessionFactory factory = cfg.BuildSessionFactory();
   ISession session = factory.OpenSession();
   ITransaction transaction = session.BeginTransaction();
   
   
   session.Save(classes);
   transaction.Commit();
   session.Close();

  }


  [Test]
  public void TestUpdate()
  {
   ClassInfo classInfo = new ClassInfo();
   classInfo.ClassName = "Chinese";
   classInfo.StudentName = "Tom";
   
   Classes classes = new Classes();
   
   Configuration cfg = new Configuration();
   cfg.AddXmlFile("Classes.hbm.xml");
   ISessionFactory factory = cfg.BuildSessionFactory();
   ISession session = factory.OpenSession();
   ITransaction transaction = session.BeginTransaction();

   classes = (Classes)session.Load(typeof(Classes),classInfo);
   classes.ClassDate = "20041231";

   session.Save(classes);

   transaction.Commit();
   session.Close();
  }

  [Test]
  public void TestDelete()
  {
   ClassInfo classInfo = new ClassInfo();
   classInfo.ClassName = "Chinese";
   classInfo.StudentName = "Tom";
   
   Classes classes = new Classes();
   
   Configuration cfg = new Configuration();
   cfg.AddXmlFile("Classes.hbm.xml");
   ISessionFactory factory = cfg.BuildSessionFactory();
   ISession session = factory.OpenSession();
   ITransaction transaction = session.BeginTransaction();

   classes = (Classes)session.Load(typeof(Classes),classInfo);
   session.Delete(classes);

   transaction.Commit();
   session.Close();
  }

测试成功。。。。。。

转载于:https://www.cnblogs.com/xuxianpeng/archive/2007/04/12/710511.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值