NHibernate使用入门(七)

多对多关联单向映射

相关实体类参考前面

Category.hbm.xml映射文件

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" default-lazy="false"
                   assembly="Ntest"
                   namespace="Ntest.Entities"
                   >
  <class name="Category">
    <id type="int" name="Id">
      <column name="Id" />
      <generator class="identity"></generator>
    </id>
    <property name="Name"/>

  </class>
</hibernate-mapping>

Order.hbm.xml映射文件

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" default-lazy="false"
                   assembly="Ntest"
                   namespace="Ntest.Entities"
                   >
  <class name="Order" table="Orders">
    <id type="int" name="Id">
      <column name="Id" />
      <generator class="identity"></generator>
    </id>
    <property name="Value"/>

    <bag name="Categories" table="OrderToCategory">
      <key column="orderId"/>
      <many-to-many column="categoryId"
          class="Category"/>
    </bag>

  </class>
</hibernate-mapping>

ManyToManyRelation.cs类

 public class ManyToManyRelation
    {
        private readonly ISessionFactory sessionFactory = new Configuration().Configure().BuildSessionFactory();
        protected object CategoryId = 1;
        protected object OrderId = 1;

        public void AddCategoryToOrder()
        {
            using (ISession session = sessionFactory.OpenSession())
            using (ITransaction transaction = session.BeginTransaction())
            {
                var order = session.Get<Order>(OrderId);
                var category = session.Get<Category>(CategoryId);

                order.Categories.Add(category);

                session.Save(order);
                Console.WriteLine("ManyToManyRelation_AddCategoryToOrder:" + order.Categories.Count);
                transaction.Commit();
            }

            using (ISession session = sessionFactory.OpenSession())
            {
                var order = session.Get<Order>(OrderId);
                var category = session.Get<Category>(CategoryId);

                Console.WriteLine("Categories是否包含category:" + order.Categories.Contains(category));
            }
        }
    }

运行结果如图:

数据库表架构生成,参考前面
这里写图片描述


这里写图片描述


数据:

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值