|
| |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
对象的查询 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。 返回类别: 教程 上一教程: .NET Framework 中多语言支持的实现 下一教程: 架构设计之首部曲 您可以阅读与"Websharp使用说明(5)"相关的教程: · Websharp使用说明(3) · Websharp使用说明(6) · Websharp使用说明(1) · Websharp使用说明(7) · Websharp使用说明(4) |
| 快精灵印艺坊 版权所有 |
首页 |
||