电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 在线教程-> .NET
Asp.net2.0:如何使用ObjectDataSource(配合ORM)-.NET教程,Asp.Net开发
作者:网友供稿 点击:6
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
 

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;

http://dlwang2002.cnblogs.com/archive/2006/06/11/422991.html


文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·经典收藏之 - C++内存管理详解-.NET教程,C#语言
·Master Page 初探-.NET教程,评论及其它
·GDI+编程10个基本技巧-.NET教程,评论及其它
·VB.NET中让Textbox只能输入数字(二)-.NET教程,VB.Net语言
·stl应用小问题-.NET教程,评论及其它
·WIN32中颜色值(COLORREF)与.NET中颜色值(Color)的转换-ASP教程,系统相关
·打造自己的专业图像工具-Visual C++ 2005图像编程系列【三】-.NET教程,C#语言
·.Net中常见问题及解决方法归类-.NET教程,.NET Framework
·Lex和Yacc从入门到精通(3)--一个极其简单的lex和yacc程序-.NET教程,评论及其它
·VB下几个非常有用的函数-.NET教程,VB.Net语言

最新文章
·VC#初学入门:第一个Windows程序
·ASP.NET 2.0-选用DataSet或DataReader
·用.net 处理xmlHttp发送异步请求
·asp.net创建文件夹的IO类的问题
·asp.net 2.0 中加密web.config 文件中的配置节
·关于ASP.NET调用JavaScript的实现
·如何实现ASP.NET网站个性化
·Acegi安全系统的配置-.NET教程,评论及其它
·Spring安全系统:Acegi Security Acegi简介-.NET教程,评论及其它
·Biztalk 开发之 架构和实例的验证-.NET教程,评论及其它


 
 


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号