How to: Create a Business Model in the XPO Data Model Designer

This topic provides step-by-step instructions on how to use the XPO Data Model Designer in XAF applications. We will create a simple business model consisting of two objects - Employee and Task. These objects will be linked with a one-to-many relationship. Then you will add XAF-specific attributes in code, and the application will be ready to use.

Note

If you prefer to watch a video rather than walk through these step-by-step instructions, you can find the corresponding tutorial on the DevExpress YouTube Channel: XAF: Start from Building a Data Model using the XPO Data Model Designer.

 

 Create an XPO Data Model

 
  • Create a new XAF solution using the DevExpress v16.1 XAF Solution Wizard template.

  • Right-click the BusinessObjects folder located in the module project and choose Add | New Item. In the invokedAdd New Item dialog, select the DXperience ORM Data Model Wizard template located in the DevExpresscategory. Set the new item's name to MySolutionDataModel.xpo and click Add. You will see that theMySolutionDataModel.xpo item is added, and the wizard dialog is invoked.

  • In the invoked dialog, select Do not connect to a database and click Next, to skip the creation of a database connection using the XPO Data Model Wizard. The database connection is managed by XAF in your solution.

  • As a result, an empty data model will be shown in the designer.

 

 Design the Employee Object

 
  • To add a new business class, drag the XpObject item from the toolbox to the designer's surface.

  • Focus the newly added object. In the Properties window, set the object's Name to Employee.

  • To add a new persistent property, drag the Field item from the Toolbox to the Employee object.

  • Focus the newly added field. In the Properties window, set the field's Name to FirstName.

    Note that the Column Type is String by default.

  • Repeat the two previous steps to add the LastName property.

  • Now add a field of a type other than string. Add the Birthday field, and set its Column Type to DateTime.

  • Next, you will see how to add a calculated field. Drag the Persistent Alias item from the Toolbox to the Employeeobject.

  • Focus the newly added persistent alias. In the Properties window, set Name to Full Name. Then, click the ellipsis button located to the right of the Expression setting. In the invoked Expression editor dialog, specify the[FirstName] + ' ' + [LastName] expression and click OK.

Note

You can inherit the Employee class from the DevExpress.Persistent.BaseImpl.Person class, instead of creating it from scratch. The XPO Data Model Designer supports the use of persistent classes from external assemblies as base classes and property types. To add business classes from the Business Class Library (or your own class library), do the following.

  • Right-click the free space on the design surface. In the invoked context menu, choose Add Assembly.
  • Select the assembly that contains business classes and click Open. You can choose the DevExpress.Persistent.BaseImpl.v16.1.dllassembly that ships with XAF, located in the %PROGRAMFILES(x86)%\DevExpress 16.1\Components\Bin\Framework path, or your custom assembly.
  • In the Select Types dialog, choose the persistent classes to import from the assembly and click OK.

These actions will import classes in read-only mode. Only persistent fields are displayed for these classes, and reference property types correspond to the underlying database types. However, you will be able to use the added classes as ancestors, and inherit new persistent classes from them in the Designer. To specify inheritance, select the Inheritance item in the Toolbox and draw a line from a descendant to a base class. Additionally, you will be able to use these classes as property types.

 

 Design the Task Object

 
  • To add another business class, drag the XpObject item from the toolbox to the designer's surface. Focus the newly added object. In the Properties window, set the object's Name to Task.

  • Add the Subject and Description persistent properties of the string type using the approach described in theDesign the Employee Object section.

  • Next, see how to apply attributes to persistent properties. Focus the Description field. In the Properties window, expand the DBType category, and set Size to Unlimited.

    As a result, the SizeAttribute will be applied to the Description property in the underlying code. The attribute's parameter will be set to SizeAttribute.Unlimited.

 

 Add a One-to-Many Association

 
    • Add the AssignedTo persistent property of the Employee type to the Task class. This property will represent the "one" part of the one-to-many association.

    • In the Toolbox, focus the Association Object item. Draw a line from Employee to Task, to create the association.

Note

Alternatively, you can use the XpObject's title bar context menu to create an association. For details, refer to the Associationsection of the Data Model Designer topic.

  • Save the changes and close the designer.
 

 Add XAF-Specific Attributes in Code

 
  • In the Solution Explorer, expand the BusinessObjects\MySolutionDataModelCode folder. This folder contains the code generated by the designer. Open the Employee.cs (Employee.vb) file. Decorate the Employee class with theDefaultClassOptionsAttribute and ImageNameAttribute attributes to the Employee object. As a result, theEmployee object will be added to the Navigation System, and an icon from the built-in library will be associated with this object.

    C#
    VB
     
    using DevExpress.Persistent.Base;
    // ... 
    [DefaultClassOptions, ImageName("BO_Employee")]
    public partial class Employee {
    public Employee(Session session) : base(session) { }
    public Employee() : base(Session.DefaultSession) { }
    public override void AfterConstruction() { base.AfterConstruction(); }
    }
  • Open the Task.cs (Task.vb) file. Decorate the Task class with the DefaultClassOptions and ImageName attributes.

    C#
    VB
     
    using DevExpress.Persistent.Base;
    // ... 
    [DefaultClassOptions, ImageName("BO_Task")]
    public partial class Task {
    public Task(Session session) : base(session) { }
    public Task() : base(Session.DefaultSession) { }
    public override void AfterConstruction() { base.AfterConstruction(); }
    }
Note

You can add more custom code to the auto-generated classes (e.g., add Action methods or override base class methods). Do not change the code located in files with the designer suffix - they contain designer-generated code, and should not be modified manually. The classes generated are declared as partial. Designed and custom class parts are located in different files.

 

 Run the Application

 

Now you can run the Windows Forms and ASP.NET applications to see the result. These applications are completely based on the business model specified in the XPO Data Model Designer.

  • Windows Forms

  • ASP.NET

How to: Create a Business Model in the XPO Data Model Designer的更多相关文章

  1. How to: Create a Business Model in the XPO Data Model Designer 如何:在 XPO 数据模型设计器中创建业务模型

    This topic provides step-by-step instructions on how to use the XPO Data Model Designer in XAF appli ...

  2. Create Entity Data Model

    http://www.entityframeworktutorial.net/EntityFramework5/create-dbcontext-in-entity-framework5.aspx 官 ...

  3. Entity Framework Tutorial Basics(5):Create Entity Data Model

    Create Entity Data Model: Here, we are going to create an Entity Data Model (EDM) for SchoolDB datab ...

  4. How to: Use the Entity Framework Data Model Located in an External Assembly 如何:使用位于外部程序集中的EF数据模型

    If you have a non-XAF application, and want to develop an XAF application that utilizes the same dat ...

  5. Define the Data Model and Set the Initial Data 定义数据模型并设置初始数据

    This topic describes how to define the business model and the business logic for WinForms and ASP.NE ...

  6. HBase 数据模型(Data Model)

    HBase Data Model--HBase 数据模型(翻译) 在HBase中,数据是存储在有行有列的表格中.这是与关系型数据库重复的术语,并不是有用的类比.相反,HBase可以被认为是一个多维度的 ...

  7. ExtJS笔记 Ext.data.Model

    A Model represents some object that your application manages. For example, one might define a Model ...

  8. [Angular 2] Adding a data model

    Instead of add todo as a string, we create a data model: export class TodoModel{ constructor( public ...

  9. 自定义 ASP.NET Identity Data Model with EF

    One of the first issues you will likely encounter when getting started with ASP.NET Identity centers ...

随机推荐

  1. webService调用模式比较

  2. js 事件冒泡、事件捕获及事件委托

    简介 事件冒泡:从触发事件的节点一直到document,自下而上的去触发事件. 事件捕获:从document到触发事件的节点,自上而下的去触发事件. 事件委托:事件委托就是利用事件冒泡,只指定一个事件 ...

  3. codeforce 460DIV2 D题

    感觉这个题不错,对拓扑排序有了更深的了解,用两种拓扑排序都写了些试试. dfs #include <cstdio> #include <algorithm> #include ...

  4. 分布式文件系统MFS(moosefs)实现存储共享

    分布式文件系统MFS(moosefs)实现存储共享(第二版) 作者:田逸(sery@163.com) 由于用户数量的不断攀升,我对访问量大的应用实现了可扩展.高可靠的集群部署(即lvs+keepali ...

  5. opennebula 一些问t题讨论

    ou_ian - June 8th, 2011 11:13 am非常想请教一下如何设置VM的ip为DHCP? 我们的VM都需要通过eth0 (通过公司的DHCP获得ip)来连接到公司的网络(Inter ...

  6. 9-python 的ProxyHandler处理器(代理设置)

    ProxyHandler处理器(代理设置) 使用代理IP,这是爬虫/反爬虫的第二大招,通常也是最好用的. 很多网站会检测某一段时间某个IP的访问次数(通过流量统计,系统日志等),如果访问次数多的不像正 ...

  7. Apache htpasswd命令

    一.简介 htpasswd是apache的一个工具,该工具主要用于建立和更新存储用户名.密码的文本文件,主要用于对基于http用户的认证. 二.语法 Usage: htpasswd [-cimBdps ...

  8. NEERC17 J Journey from Petersburg to Moscow

    CF上可以提交.   链接 依然是很妙的解法. 我们可以枚举每一个出现过的边权$L$,然后把所有边的边权减掉这个$L$,如果小于$L$就变为$0$,然后跑一遍最短路然后加上$k * L$更新答案即可. ...

  9. 高级软件测试技术(测试管理工具实践day4)

    今天是截止日期,有胡俊辉的指导下小组成员都了解使用了Bugzilla的基本使用.大家都在晚上之前把各自的文档汇总给汪鸿,由他撰写了操作手册.并且在下午杨瑞丰完成了视频的录制工作.但是在转化为MP4 格 ...

  10. 解决Spring Boot(2.1.3.RELEASE)整合spring-data-elasticsearch3.1.5.RELEASE报NoNodeAvailableException[None of the configured nodes are available

    Spring Boot(2.1.3.RELEASE)整合spring-data-elasticsearch3.1.5.RELEASE报NoNodeAvailableException[None of ...