首页 > 开发 > 综合 > 正文

Websharp使用说明(5)

2024-07-21 02:17:16
字体:
来源:转载
供稿:网友


对象的查询

websharp提供了对对象查询的功能,这个功能通过query接口提供。query接口的定义可以见:附1:websharp主要接口定义——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的功能,并且能够屏蔽不同数据库之间的差别。这个接口的定义可以见:附1:websharp主要接口定义——dataaccess

能够通过persistencemanager的newdataaccess方法来初始化一个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。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表