XPO 第三方控件学习(DevExpress Persistent Object )系列---表间关系

     支持一对一,一对多,多对多三种关系。

数据库的表间关系在框架内体现为持久对象之间的关系。一般我们在设计一些类似关系的类时,我们用数组或者其他集合表示方法IList等等,来为类之间建立关系。

XPO使用XPCollection来表示类之间的”对多关系”。并且附加属性来表示多对多还是一对多的关系。

1、一对多:

在一个类中定义:

Public Class Customer

    Inherits XPObject

    <Association("CustomerAddresses", GetType(Address))> _

    Public ReadOnly Property Addresses() As XPCollection

        Get

            Return GetCollection("Addresses")

        End Get

    End Property

End Class 'Customer

同时另一个类Adresses中定义:

    <Association("CustomerAddresses")> Public Customer As Customer

此时这个类的关联关系并没有指定关联类型,因为已经说明了类型。

可以在关联关系中进一步指定其他附加属性,比如级联删除关系:

Public Class Customer

    Inherits XPObject

    <Association("CustomerOrders", GetType(Order)), Aggregated()> _

       Public ReadOnly Property Orders() As XPCollection

        Get

            Return GetCollection("Orders")

        End Get

    End Property

End Class 'Customer 

多了Aggregated这种特性,表示聚集,也就是表之间的级联删除关系。

 

访问子表的方法:枚举

Dim theOrder As Order

For Each theOrder In  theCustomer.Orders '

'…

Next theOrder           

增加子表的记录:

myCustomer.Orders.Add(myOrder)

 

posted on 2010-03-04 22:29  SUNJUNLIN  阅读(913)  评论(0编辑  收藏  举报

导航