asp.net2.0里面的objectdatasource可以使数据显示控件gridview等进行绑定显示,编辑。还可以支持内置的分页,排序等。使用了orm之后,一样可以使用objectdatasource。
这里的分页不再是从数据库取出所有,然后选择性绑定,而是直接在数据库取出第几页,然后绑定。这个差别还是十分巨大的,效率大大提高。
编辑,创建,排序也都是,直接由objectdatasource提供,不需要再gridview中写什么代码。
这样,可以把object设计的包含有不少逻辑,至少是对数据库操作的,而ui就显得比较简单,剥离的再开一点,对以后移植到win上,或者做成smartclient都比较有益。
这里有一片blog,讲的比较好http://www.evosoftworks.com/articles/wormods.aspx。
我用的正好也是wilsonorm,所以照此也作了一个。
基本的结构是这样的:
ui(gridview等控件--objectdatasource控件)----〉objectdatasource类(object,写crud分页等逻辑)---〉(orm实现crud)---〉db
主要有几步
1:给object增加属性和方法,来完成crud,分页等逻辑
2:配置gridview等ui控件连接到objectdatasource控件。
先看第一个
1:给object增加属性和方法,来完成crud,分页等逻辑。该object类由工具根据db结构生成,同时生成的还有mapping文件。
首先,给该object增加一个标示属性dataobject(),在system.componentmodel命名空间里面 [dataobject()]
public class productdescription
{ 第二,给这个object类增加crud的方法。
先看一个insert方法
[dataobjectmethod(dataobjectmethodtype.insert)]
public static void insert(productdescription productdescription)
{
try
{
manager.datamanager.starttracking(productdescription, initialstate.inserted);
manager.datamanager.persistchanges(productdescription);
}
catch (exception ex)
{
log.error(ex);
}
} 这个方法前面需要加一个[dataobjectmethod(dataobjectmethodtype.insert)]属性,表示这是insert方法;
这个方法是静态公开的方法;
参数,就是这个object本身的一个实例。这样比较好,因为在逻辑好很好理解,都是在对object进行操作。
剩下的,delete,update方法也是这样写。
然后看看select方法,比较特殊。
select方法
1 [dataobjectmethod(dataobjectmethodtype.select)]
2 public collection<productdescription> retrieve(string query, int maxrows, int startrowindex, string sortclause)
3 {
4 try
5 {
6 int numpages = 0;
7 if (sortclause == null || sortclause == "")
8 sortclause = "modifieddate desc";
9 collection<productdescription> cs;
10 cs = retrievepage(query, sortclause, maxrows, (int)math.ceiling((double)startrowindex / maxrows) + 1, out numpages);
11 _numrecs = ((iobjectpage)cs).totalcount;
12 return cs;
13 }
14 catch (exception ex)
15 {
16 log.error(ex);
17 return null;
18 }
19 }
20 [dataobjectmethod(dataobjectmethodtype.select)]
21 static public objectset retrieve(string key, string value)
22 {
23 if (value == null || value == "")
24 return null;
25 try
26 {
27 queryhelper helper = manager.datamanager.queryhelper;
28 key = helper.getfieldname(typeof(productdescription).tostring() + "." + key);
29 objectquery query = new objectquery(typeof(productdescription), string.format("{0}='{1}'", key, value), "");
30 objectset obj = manager.datamanager.getobjectset(query);
31 return obj;
32 }
33 catch (exception ex)
34 {
35 log.error(ex);
36 return null;
37 }
38 }
39
40 public int reccount(string query, int maxrows, int startrowindex, string sortclause)
41 {
42 return _numrecs;
43 }
44
45 public static collection<productdescription> retrievepage(string whereclause, string sortclause, int pagesize, int pageindex, out int pagecount)
46 {
47 objectquery<productdescription> query = new objectquery<productdescription>(whereclause, sortclause, pagesize, pageindex);
48 objectset<productdescription> pageset = manager.datamanager.getobjectset<productdescription>(query);
49 pagecount = pageset.pagecount;
50 return pageset;
51 } 第一个方法public collection<productdescription> retrieve(string query, int maxrows, int startrowindex, string sortclause),这是可以实现内置分页,和排序的方法。需要注意的是这句代码_numrecs = ((iobjectpage)cs).totalcount; 在这里,分页之后,立即取出总页数,这个是用来供显示页号的;于此对应,方法 public int reccount(string query, int maxrows, int startrowindex, string sortclause)就是用来取出记录条数的;注意,这两个方法一定要对应,参数也一样。
第二个方法 static public objectset retrieve(string key, string value)只是普通的取出一条纪录。可以用在detailview/formview的显示。
代码看上去虽然很多,但是其实很模式化,所以可以使用codesmith或者直接修改一下ormhelper工具来动态生成,不需要手工写代码。
有了这四个方法,crud,分页,排序就已经完成了。这样的object,和ui无关,只是数据逻辑。
2:ui的配置。ui配置也分两层:gridview等显示控件;objectdatasource控件
现在给gridview等控件配置object数据源,直接连接到object上,实现显示编辑等功能。其实就是设置一个连接到objectdatasource的属性。
<asp:gridview id="gv_data" runat="server" allowpaging="true" allowsorting="true" datasourceid="ods_list"
这是objectdatasource控件的配置
objectdatasource
1<asp:objectdatasource id="ods_list" runat="server" dataobjecttypename="businessmodel.productdescription"
2 deletemethod="delete" oldvaluesparameterformatstring="original_{0}" selectmethod="retrieve"
3 typename="businessmodel.productdescription" updatemethod="update" sortparametername="sortclause"
4 maximumrowsparametername="maxrows" selectcountmethod="reccount" enablepaging="true"
5 conflictdetection="overwritechanges" convertnulltodbnull="false">
6 <selectparameters>
7 <asp:parameter name="query" type="string" />
8 <asp:parameter name="maxrows" type="int32" />
9 <asp:parameter name="startrowindex" type="int32" />
10 <asp:parameter name="sortclause" type="string" />
11 </selectparameters>
12</asp:objectdatasource>
看看里面的属性,就是配置crud方法的参数,和对应的方法名。这些正是我们在类中实现的。比方说这里配置delete方法:deletemethod="delete";而这里就是刚才说的记录个数的属性:selectcountmethod="reccount";还有排序等等。
这里的参数怎么传递?系统相关的属性由系统传递,比方说,maxrows,startrowindex什么的;也可以用代码来传递: this.ods_list.selectparameters["query"].defaultvalue = query;
新闻热点
疑难解答
图片精选