`
try1try
  • 浏览: 11257 次
  • 来自: ...
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

AJAX DataSet的使用心得

阅读更多

AJAX DataSet的使用心得<o:p></o:p>

<o:p> </o:p>

作者:玉壶冰<o:p></o:p>

<o:p> </o:p>

       无论是VBDelphi.NET还是Java,都有提供对数据结果集的操作,有了数据结果集,我们只需要使用结果集的方法移动记录,获取记录字段数据,再结合界面,就可以很容易地完成一个数据库应用的编程,现在都流行用AJAX做基于web的系统了。

老大决定新版要用AJAX来做,给了我们用AJAX做一些试验和原型的任务,可是当我们的技术组在预研时,才发现到了web上完全不是那么回事呀,仅仅通过form表单来操作和提交数据要实现我们的设备管理真的很麻烦,以前都是用delphi三层结构,有ClientDataSet,有DCOMMIDAS,还有我们最爱的DEV系列控件,界面以及数据的读取,操作,保存都是不需要太多程序的,我们还积累了不少框架和通用类呢。

了解了一些AJAX框架,大多是只支持java的,这次我们要用C#,也有少数.NETAJAX开源的项目,功能就是些框架和一些不完整的类,偶和菜哥、阿狼搞了几天,还是没有搭好一个能够很好支撑我们项目开发的基础,可能我的jshtml基础太差了,后来阿狼居然在网上发现有AJAXWebShop,下了看了,居然非常像delphi,也有DataSet,还有很多数据感应的控件像DBGrid什么的,试了一下,发现这个DataSet确实厉害,竟然用javascript实现了以前的ClientDataSet,而且与数据感应控件的使用也沿袭了Delphi的模式,于是决定使用它,简单的应用也很容易,那个工具提供可视化的开发方式,也有示例,不过真正开发起来,在使用过程也遇到好多问题,幸好这个工具的开发商有在线客服,有些深入使用的功能就直接找他们问,我们的设备管理系统的原型只用了15天就搭建出来啦,AJAX确实厉害,功能上和操作方便性比以前的asp程序不知道好哪去了,哈哈。好了,言归正题,我们在做原型过程中用到最多的就是DataSet,有的时候没有使用数据感应控件,有的界面用了,我就把使用DataSet的一些心得给大家讲讲:

这个DataSet是一个客户端的AJAX数据集,完全是纯js的实现,界面与后台的数据交互基本上全是通过它进行的,包括数据的读取和提交。听他们说是用js操纵XML,能够进行分页、样式无刷新查询数据、还有如果增删改了少量数据,是实现的增量数据提交,而后台对应这个DataSet需要有相应的服务端程序,我用的是3.0版,可以支持C#,VB,Java,据他们说很快要出支持PHP的版本了,不过我们是用C#,看了他们C#的例子,好像是后台要实现两个类,一个处理取数据包括查询数据,另外一个处理数据的提交,但我们觉得封装一下似乎更好,完全可以用一个类的两个方法来写嘛,然后做一个控制层来转发。通过他们的例子和代码向导,我们知道取数据包括分页的代码(demo/Simple_Query.aspx)是这样的:

using System;

using System.Data;

using System.Data.OleDb;

using System.Configuration;

using System.Collections;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;

using joyistar.eip.util;

using joyistar.eip.vo;

<o:p> </o:p>

<o:p> </o:p>

public partial class Simple_Query : System.Web.UI.Page {

    private String connString = "provider=Microsoft.Jet.OLEDB.4.0;Data Source="+System.Web.HttpContext.Current.Server.MapPath(".")+"\\demo.mdb";

    private String sql = "select * from product";

    protected void Page_Load(object sender, EventArgs e)

    {

        Response.ContentType = "text/xml";

        String xml = HttpParser.getXML(Request.InputStream);

        XmlRequest xmlRequest = new XmlRequest();

<o:p> </o:p>

        try

        {

            xmlRequest.Open(xml);

<o:p> </o:p>

            OleDbConnection conn = new OleDbConnection(connString);

            conn.Open();

            OleDbCommand cmd = new OleDbCommand(sql, conn);

            OleDbDataReader reader = cmd.ExecuteReader();

            DataTable metadata = reader.GetSchemaTable();

      

            int rowCount;//the row number of the table

            int maxRow;  //the row number displayed per page,which is one of the DataSet Propery

            int recNo;  

            maxRow = xmlRequest.MaxRows;

            recNo = xmlRequest.RecNo;

            //get rowCount

            string sqlCount = "select   count(*)   from   product";

            OleDbConnection MyConn = new OleDbConnection(connString);

            MyConn.Open();

            OleDbCommand MyComm = new OleDbCommand(sqlCount, MyConn);

            rowCount = (int)(MyComm.ExecuteScalar());

                     if(maxRow==-1) maxRow = rowCount;

            xmlRequest.SetRecordCount(rowCount);

           //fill fields

            foreach (DataRow row in metadata.Rows)

            {

                if (row["DataType"].Equals("STRING"))

                {

                    xmlRequest.AddField(System.Convert.ToString(row["ColumnName"]), System.Convert.ToString(row["DataType"]), System.Convert.ToInt32(row["ColumnSize"]));

                }

                else

                    xmlRequest.AddField(System.Convert.ToString(row["ColumnName"]), System.Convert.ToString(row["DataType"]));

            }

            //fill data  of the page    

            int count = -1;

            while (reader.Read())

            {

                count++;

                if (count >= recNo)

                {

                    if (count < (recNo + maxRow))

                    {

                        xmlRequest.Append();

<o:p> </o:p>

                        foreach (DataRow row in metadata.Rows)

                        {

                            String fieldname = System.Convert.ToString(row["ColumnName"]);

                            String fieldvalue = reader[fieldname].ToString();

                            xmlRequest.SetValue(fieldname, fieldvalue);

<o:p> </o:p>

                        }

                    }

                    else break;

                }

<o:p> </o:p>

                else

                { continue; }

<o:p> </o:p>

<o:p> </o:p>

            }

<o:p> </o:p>

<o:p> </o:p>

            Response.Write(xmlRequest.GetXml());

            Response.Flush();

<o:p> </o:p>

        }

        catch (Exception ex)

        {

            xmlRequest.SetError(ex.Message);

            Response.Write(xmlRequest.GetXml());

            Response.Flush();

        }

        finally {

<o:p> </o:p>

        }

    }

}

然后这个文件在界面上是这样使用的,选择好DataSet后,输入OpenURL属性为demo/Simple_Query.aspx,设置好这个就可以点Fields然后刷出表结构啦,当然你必须启动webserver,在那个Run里面有start webserver。对了,要能正常启动它,你需要安装有.NET Framework 2.0并在工程属性中配置好.NET路径哦:

图一

再看DataSet的其他属性,Async是设置异步还是同步模式取数据,Active是打开数据,这样页面一载入就会取数据过来,也可以在程序中调用DataSet1.Open();来打开数据,如果要做一个查询,还要先关闭数据,传入参数,再打开数据执行查询,代码类似:

function Button1onclick() {

    DataSet1.Close();

    DataSet1.Params.Clear();

    if(Edit1.value) {

        DataSet1.Params.Add(new Param('NAME',Edit1.value,'string'));

    }

    DataSet1.Open();

}

<o:p> </o:p>

当然,做查询后台也有代码,是这样写的:

            // the data search code here

            Param param1 = xmlRequest.GetParam("NAME");//get the search information

            String sql_params = "";

            if (param1 != null)

<o:p> </o:p>

            {

                sql_params = " where NAME='" + param1.Value+"' ";

                sql += sql_params;

            }

在使用Async=true的异步模式时,我们有时遇到很奇怪的问题,比如几个表同时打开总是出错,后来仔细一想才明白,原来是码表和主表同时打开,主表打开时码表数据还没有取到,所以就出错了,于是设置主表在码表的afteropen后打开就搞定了。

切换到DataSet的事件页,可以看到它的事件列表,双击进去加上这个控制代码:

<o:p>图二</o:p>

<o:p> </o:p>

function DataSet3OnAfterOpen(dataset) {

       DataSet1.Open();

}

<o:p> </o:p>

另外,DataSet有一个MaxRows属性,是指定每页取多少数据的,默认是5,如果设置成-1,就会取所有的数据哦。

DataSet要实现分页,就是使用了MaxRows,还有在后台的编程实现,根据MaxRowsRecNo来取数据,RecNo就是起始记录号,还要设置总记录数以便知道有多少页,用的xmlRequest.SetRecordCount(xxx);

这里的XmlRequest是他们封装的请求对象,后台的参数映射和数据返回都是用的它,比如XmlRequest.MaxRows, XmlRequest.RecNo, XmlRequest.AddField, XmlRequest.Append, XmlRequest.SetValue,基本上常用的就这些了。

DataSet还有一个DataSource属性似乎是只有Java才会用得到,还有如果我们自己封装后台类控制层,也可以启用这个属性。

DataSet有记录移动的方法,包括First, Prev ,Next,Last,SetPos这些,然后通过DataSet.Fields.Field[“字段名”].Value, DataSet.Fields.Fieldx[“字段序号”].Value可以取或写当前记录字段的值,增加记录用Append,修改用Edit,确定用Post,提交保存用Apply,取消修改用Cancel,删除用Delete,哈哈,和resultset的操作是完全类似的。

我有些模块就是用普通Input Text,然后通过DataSet与后台交互,真是相当的方便哩,有些就直接用数据感应的Input TextDBGrid什么的,拖拉起,设置好属性就搞定啦。

最后,DataSetPostURL就是用来设置数据提交保存的服务路径,数据的提交比取数据要麻烦一些,涉及到增删改几种情况的处理,对了,这个DataSet来支持主从表的取数据和数据提交,这在我们的开发中是太有用了,不过编程处理也相对复杂一些,我要把这段时间的代码整理下了,好给项目组的其他人一起讲下,改天有空再写一些提交数据和主从表操作的经验。

  • 描述: 图一
  • 大小: 20.9 KB
  • 描述: 图二
  • 大小: 12.8 KB
分享到:
评论
3 楼 try1try 2007-01-05  
真正的AJAX 应用有哪些,不要空壳的!
2 楼 try1try 2006-12-28  
netfly 写道
收费的
自己用就免费的赛,用于商业开发和部署就收费的--那个协议里有的。

不然人家不要喝西北风了,呵呵
1 楼 netfly 2006-12-27  
收费的

相关推荐

    ajax实现动态从数据库模糊查询显示到下拉框中(ajax方法返回Dataset的例子

    本文将详细讲解如何使用Ajax实现从数据库进行模糊查询,并将结果显示到下拉框(Dropdown List)中,这里我们将以一个具体例子——通过Ajax方法返回Dataset来阐述整个过程。 首先,我们需要在服务器端设置一个能够...

    C#将对象数组转换成DataSet使用案例 c#经典案例.pdf

    C#将对象数组转换成DataSet使用案例 本文将介绍如何将对象数组转换成DataSet,解决了在ASP.NET 2.0 beta 2开发项目中遇到的问题,即将对象数组绑定到GridView的数据源上,但GridView不支持对象数组的排序,因为...

    js处理后台函数接口,包括Dataset

    在本文中,我们将深入探讨如何在VS2008和ASP.NET环境中使用Ajax.dll来实现JavaScript调用后台函数接口,并获取Dataset数据。 首先,`Ajax.dll`是一个.NET框架下的组件,它为ASP.NET应用程序提供了对Ajax功能的支持...

    C#中,数据集DataSet使用方法大全

    1、创建DataSet对象:DataSet ds = new DataSet("DataSetName"); 2、查看调用SqlDataAdapter.Fill创建的结构 da.Fill(ds,"Orders"); DataTable tbl = ds.Table[0]; foreach(DataColumn col in tbl.Columns) ...

    DataSet 转化为List的通用方法

    DataSet转化为List的通用方法,可自动转换类型

    dataset的使用

    在.NET框架中,`DataSet`是一个非常重要的组件,主要用于存储和操作关系数据。它是一个内存中的数据缓存,可以...对于初学者来说,掌握`DataSet`的使用能提升你在数据处理方面的技能,为后续的开发工作打下坚实的基础。

    一张图让你搞明白C#中DataSet如何使用

    一张图让你搞明白C#中DataSet如何使用

    dataset

    dataset導入到excel

    使用数据绑定和DataSet

    使用数据绑定和DataSet 在软件开发中,数据绑定是指将数据集DataSet等数据对象绑定到应用程序的控件中,然后将数据显示给用户查看或者操作。数据绑定在程序开发与设计中十分重要,本章通过介绍数据绑定和数据集...

    C# DataSet和XML文件的相互转换

    当你需要将`DataSet`的内容保存到XML文件或者通过XML字符串传输时,可以使用`DataSet`的`WriteXml`方法。这个方法接受一个文件路径或者一个`Stream`对象作为参数,然后将`DataSet`的内容以XML格式写入。例如: ``...

    asp.net 使用数据绑定和DataSet

    在“第3章 使用数据绑定和DataSet”中,你可能会学到如何创建和配置DataSet,包括定义DataTable,添加和删除数据行,以及设置和处理DataColumn。你还会学习如何使用DataAdapter填充DataSet,以及如何使用Command对象...

    c# xml转dataset

    在.NET框架中,C#提供了一种方便的方式来处理XML数据,可以将XML文档转换为DataSet对象,以便于进一步的数据操作和处理。`XmlDataDocument`是这个过程中的关键类,它继承自`System.Xml.XmlDocument`,并添加了与.NET...

    DataSet详细用法(最全面)

    、可以在任何时候查看DataSet中任意行的内容,允许修改查询结果的方法。 、处理分级数据 、缓存更改 、XML的完整性:DataSet对象和XML文档几乎是可互换的。 、创建DataSet对象: 、查看调用SqlDataAdapter....

    Python库 | img2dataset-1.20.2-py3-none-any.whl

    1. 安装库:使用pip命令`pip install img2dataset-1.20.2-py3-none-any.whl`进行安装。 2. 导入库:在Python脚本中导入`import img2dataset`。 3. 创建数据集:通过调用库提供的函数,指定数据源和参数,创建数据集...

    C#中DataSet的用法(很详细)

    DataSet是ADO.NET开发人员为方便数据处理开发出来的,是数据的集合。DataSet的功能:浏览、排序、搜索、过滤、处理分级数据、缓存更改等。还可以与XML数据互换。DataSet中可包括多个DataTable,可将多个查询结构...

    C# SqlDataAdapter与DataSet的使用

    C# SqlDataAdapter与DataSet的使用

    DataSet 与Byte[]之间的相互转换

    反向转换则需要先将`Byte[]`解码回XML字符串,再使用`DataSet`的`ReadXml()`方法解析XML字符串,生成新的`DataSet`。如下所示: ```csharp Byte[] byteData = ...; // 初始化字节数组 string xmlString = ...

    dataset,datatable的使用详解

    里面包含很关于dataset和datatable的使用,还有例子

    List泛型和DataSet

    使用`DataSet`的一段示例代码可能如下: ```csharp // 创建DataAdapter和SqlCommand对象 SqlDataAdapter adapter = new SqlDataAdapter("SELECT * FROM Customers", connectionString); DataSet dataSet = new ...

    通过Web服务获取DataSet.rar

    客户端再使用JSON库(如JavaScript的fetch或jQuery的ajax)解析JSON,还原成DataSet。 在“通过Web服务获取DataSet.rar”这个压缩包中,可能包含了实现上述过程的相关代码示例或者教程文档。文件列表中的“通过Web...

Global site tag (gtag.js) - Google Analytics