NHibernate Step By Step(7)-映射集合类型

1.Set 无序不重复对象 如ISet

2.List 可按位索引对象 如IList

3.Map 键值对象,如HashTable

4.Bag 可重复对象 如IList

5.idbag

示例

1.Set

<class name="A" table="a" lazy="false">
    <id name="Id" column="id" unsaved-value="null">
        <generator class="native" />
    </id>
    <property name="Name" column="aname" />
    <set name="Items" cascade="all-delete-orphan" generic="true">
        <key column="a_id" />
        <one-to-many class="B" />
    </set>
</class>
<class name="B" table="b" lazy="false">
    <id name="Id" column="id" unsaved-value="null">
        <generator class="native" />
    </id>
    <property name="Name" column="aname" />
</class>


<key column="a_id" /> 指定了外键值

<one-to-many class="B" /> 指定集合关联

image

2.List

<class name="A" table="a" lazy="false">
    <id name="Id" column="id" unsaved-value="null">
        <generator class="native" />
    </id>
    <property name="Name" column="aname" />
    <list name="Items" cascade="all-delete-orphan" generic="true">
        <key column="a_id" />
        <index column="a_idx" />
        <one-to-many class="B" />
    </list>
</class>
<class name="B" table="b" lazy="false">
    <id name="Id" column="id" unsaved-value="null">
        <generator class="native" />
    </id>
    <property name="Name" column="aname" />
</class>


因为有索引,所以加了一个index的索引字段,这是必须的

3.Bag

  <class name="A" table="a" lazy="false">
      <id name="Id" column="id" unsaved-value="null">
          <generator class="native" />
      </id>
      <property name="Name" column="aname" />
  
      <bag name="Items" cascade="all-delete-orphan" generic="true">
          <key column="a_id" />
          <one-to-many class="B" />
      </bag>
  </class>
  <class name="B" table="b" lazy="false">
      <id name="Id" column="id" unsaved-value="null">
          <generator class="native" />
      </id>
      <property name="Name" column="aname" />
</class>


4.Map

<class name="A" table="a">
    <id name="Id" column="id" unsaved-value="null">
        <generator class="native" />
    </id>
    <property name="Name" column="aname" />
    <map name="Items" cascade="all-delete-orphan">
        <key column="a_id" />
        <index column="idx" type="String" />
        <one-to-many class="B" />
    </map>

    <map name="SortedList" collection-type="sorted-list" sort="natural">
        <key column="a_id" />
        <index column="idx" type="string" />
        <element column="elt" type="int" />
    </map>

    <map name="SortedDictionary" collection-type="sorted-dictionary" sort="natural">
        <key column="a_id" />
        <index column="idx" type="string" />
        <element column="elt" type="int" />
    </map>
</class>
<class name="B" table="b" lazy="false">
    <id name="Id" column="id" unsaved-value="null">
        <generator class="native" />
    </id>
    <property name="Name" column="aname" />
</class>

(1)A与B关系
image
(2)element表示获取数据库字段集合,而非对象集合,如下映射的类

public class A
    {
        private int? _id;
        private string _name;
        private IDictionary<string, B> _items;

        private IDictionary<string, int> _sortedList;
        private IDictionary<string, int> _sortedDictionary;

        public A() { }

        public int? Id
        {
            get { return _id; }
            set { _id = value; }
        }

        public string Name
        {
            get { return _name; }
            set { _name = value; }
        }

        public IDictionary<string,B> Items
        {
            get { return _items; }
            set { _items = value; }
        }

        public IDictionary<string, int> SortedList
        {
            get { return _sortedList; }
            set { _sortedList = value; }
        }

        public IDictionary<string, int> SortedDictionary
        {
            get { return _sortedDictionary; }
            set { _sortedDictionary = value; }
        }
    }

(3)索引

key和value肯定有索引所以要加所以字段

(4)排序

4.1 sort字段
<map name="SortedList" collection-type="sorted-list" sort="natural">

sort属性中允许的值包括 unsorted, natural和某个实现了System.Collections.IComparer的类的名称

4.2 order-by

<map name="SortedList" order-by="elt asc">

order-by属性的值是一个SQL排序子句而不是HQL的

5.idbag

<class name="A" table="a" lazy="false">
    <id name="Id" column="id" unsaved-value="null">
        <generator class="native" />
    </id>
    <property name="Name" column="aname" />

    <idbag name="Items" cascade="all-delete-orphan" generic="true">
        <collection-id type="Int32" column="item_id">
            <generator class="increment" />
        </collection-id>
        <key column="a_id" />
        <element type="string" />
    </idbag>
</class>

与bag不同,多出了一个id字段,可以有效进行索引
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值