Websharp使用说明(5)

转载 2006年06月04日 20:27:00
对象的查询

       Websharp提供了对对象查询的功能,这个功能通过Query接口提供。Query接口的定义可以见:1Websharp主要接口定义——Query

       可以通过下面的办法来使用Query接口:

PersistenceManager pm=PersistenceManagerFactory.Instance().CreatePersistenceManager(pp);

Query q=pm.NewQuery("Product");

q.Filter="ProductID='P001'";

q.Open();

EntityData entity=q.QueryData();

dataGrid1.DataSource=entity;

q.Close();

pm.Close();

 

Websharp也提供了直接操纵数据库的数据访问接口——DataAccess,这个接口对ADO.Net进行了一些封装,可以使程序员更加容易的使用ADO.Net的功能,并且能够屏蔽不同数据库之间的差别。这个接口的定义可以见:1Websharp主要接口定义——DataAccess

能够通过PersistenceManagerNewDataAccess方法来初始化一个DataAccess对象,然后调用相应的办法来执行需要的功能。

 

业务逻辑的处理

有了上面的工作,我们就可以把这些对象组合起来,编写我们的业务逻辑。在面向对象的系统中,业务逻辑表现为对象之间的交互。在一些简单的系统中,没有复杂的业务逻辑,只是一些数据的维护工作,那么,有了上面两个部分的工作,我们实际上可能已经忘成了大部分的工作。

下面是一个简单的例子,表示了一张入库单入库的过程,在这个过程中,需要修改入库单上每种产品的现有库存量:    

public void StoreIntoWarehouse(Form insertForm)

{

     FormDetail detail=insertForm.FormDetail;

     detail.First();

     PersistenceManager pm = PersistenceManagerFactory.Instance().CreatePersistenceManager();

     Transaction tm=pm.CurrentTransaction;

     tm.Begin();

     try

     {

         if(detail.ObjectCount>0)

         {

              do

              {

                   Product product=(Product)pm.FindObjectByPrimaryKey

(detail.ProductID,Type.GetType

("LogisticsDemo.EntityDefinitions.Product"));

                   product.CurrentCount+=detail.InCount;

                   pm.UpdateObject(product);

              }while(detail.Next());

         }

         pm.PersistNewObject(insertForm);

         tm.Commit();

     }

     catch(Exception e)

     {

         tm.Rollback();

         throw e;

     }

     finally

     {

         pm.Close();

     }            

}

     可以看到,在使用Websharp后,对于业务逻辑的编写,可以变成一个非常自然的过程,也能够节省很多代码量。

   

    

业务服务的提供

业务外观层(Business Facade)的目的,是隔离系统功能的提供者和使用者,更明确地说,是隔离业务逻辑的软件的用户界面(可以参见Facade设计模式)。可以使用现有的任何方法来构建构建这个层次,在我们提供的例子中,我们使用了Web Service

Websharp使用说明(5)

       对象的查询       Websharp提供了对对象查询的功能,这个功能通过Query接口提供。Query接口的定义可以见:附1:Websharp主要接口定义——Query       ...
  • sunny_y_m
  • sunny_y_m
  • 2004年02月26日 14:39
  • 1016

Websharp 5 - Websharp编程

Websharp原理 Websharp开发的过程是先设计页面模板,然后编写java代码,即模板设计好了,接下来的任务就是编程来调用它,把模板变量换成动态的内容。从模板设计一章中,我们知道了三种基本的...
  • coolmasoft
  • coolmasoft
  • 2008年08月30日 00:54
  • 522

Websharp使用说明(1)

Websharp使用说明前言N层的应用软件系统,由于其众多的优点,已经成为典型的软件系统架构,也已经为广大开发人员所熟知。在一个典型的三层应用软件系统中,应用系统通常被划分成以下三个层次:数据库层、应...
  • sunny_y_m
  • sunny_y_m
  • 2004年02月26日 14:39
  • 1535

Websharp使用说明(2)

数据实体的表示Websharp在数据的表现上,能够采用两种方式。第一种方式,充分利用了.Net Framework类库中DataSet的功能,设计了一个EntityData类。这个类继承了DataSe...
  • sunny_y_m
  • sunny_y_m
  • 2004年02月26日 10:51
  • 1155

Websharp使用说明(7)

DataAccess: public interface DataAccess      { ...
  • jane082
  • jane082
  • 2006年06月04日 20:31
  • 398

Websharp使用说明(8)

DataAccess:public interface DataAccess     {         #region Support Property & Method         Datab...
  • sunny_y_m
  • sunny_y_m
  • 2004年02月26日 14:40
  • 1255

Websharp使用说明(4)

       数据的存取方式数据存取的目的,是持久化保存对象。在Websharp中,定义了PersistenceManager接口来实现这个功能。PersistenceManager的定义可以见:附1...
  • sunny_y_m
  • sunny_y_m
  • 2004年02月26日 10:51
  • 1023

Websharp使用说明(6)

Websharp应用系统的配置1、  缓存的配置Websharp使用了微软的Cached Application Block来缓存数据,因此,下面的缓存信息必须在应用程序中添加。关于Cached Ap...
  • sunny_y_m
  • sunny_y_m
  • 2004年02月26日 10:51
  • 1022

Websharp使用说明(2)

数据实体的表示Websharp在数据的表现上,能够采用两种方式。第一种方式,充分利用了.Net Framework类库中DataSet的功能,设计了一个EntityData类。这个类继承了DataSe...
  • jane082
  • jane082
  • 2006年06月04日 20:24
  • 486

Websharp使用说明(4)

 数据的存取方式数据存取的目的,是持久化保存对象。在Websharp中,定义了PersistenceManager接口来实现这个功能。PersistenceManager的定义可以见:附1:Websh...
  • jane082
  • jane082
  • 2006年06月04日 20:26
  • 565
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Websharp使用说明(5)
举报原因:
原因补充:

(最多只允许输入30个字)