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

相关文章推荐

【Boost】boost库asio详解5——resolver与endpoint使用说明

tcp::resolver一般和tcp::resolver::query结合用,通过query这个词顾名思义就知道它是用来查询socket的相应信息,一般而言我们关心socket的东东有address...

SQL Prompt5 破解版+使用说明

Red Gate系列文章: Red Gate系列之一 SQL Compare 10.2.0.1337 Edition 数据库比较工具 完全破解+使用教程 Red Gate系列之二 SQL ...

南非的5DT数据手套使用说明

5DT 数据手套-Ultra数据手套的设计目的是为了满足现代动作捕捉和动画制作等专业人士的严格要求。它提供了舒适,易于使用,小型要素和多种应用的驱动。高数据质量,低相关性和高速率的数据传输,使其满足逼...

html5 canvas 使用说明

前言基本知识绘制矩形清除矩形区域圆弧路径绘制线段绘制贝塞尔曲线线性渐变径向渐变(发散)图形变形(平移、旋转、缩放)矩阵变换(图形变形的机制)图形组合给图形绘制阴影绘制图像(图片平铺、裁剪、像素处理[不...

SQL Prompt5 破解版+使用说明

系统:win7 x64 SP1 + SQL 2008 R2 一、sqldbx工具介绍 在介绍SQL Prompt 5.3.4.1之前,先介绍另外一款sql工具sqldbx。  它也是一款...

【HTML5】开发之meta标签的viewport使用说明

随着高端手机(Andriod,Iphone,Ipod,WinPhone等)的盛行,移动互联应用开发也越来越受到人们的重视,用html5开发移动应用是最好的选择。然而每一款手机有不同的分辨率,不同屏幕大...

Leica D-LUX 5使用说明

  • 2014-09-08 09:38
  • 15.03MB
  • 下载

stc12C5A60s使用说明

  • 2013-05-02 18:52
  • 3.18MB
  • 下载

(android控件)ViewPager介绍和使用说明

引用:http://www.cnblogs.com/macroxu-1982/archive/2012/01/03/2311444.html \ViewPager实现的功能 和实际运行的效果图示意 ...

endnote X5使用说明

  • 2012-12-30 22:10
  • 1.68MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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