AJAX DataSet的使用心得<o:p></o:p>
<o:p> </o:p>
作者:玉壶冰<o:p></o:p>
<o:p> </o:p>
无论是VB、Delphi、.NET还是Java,都有提供对数据结果集的操作,有了数据结果集,我们只需要使用结果集的方法移动记录,获取记录字段数据,再结合界面,就可以很容易地完成一个数据库应用的编程,现在都流行用AJAX做基于web的系统了。
老大决定新版要用AJAX来做,给了我们用AJAX做一些试验和原型的任务,可是当我们的技术组在预研时,才发现到了web上完全不是那么回事呀,仅仅通过form表单来操作和提交数据要实现我们的设备管理真的很麻烦,以前都是用delphi三层结构,有ClientDataSet,有DCOM,MIDAS,还有我们最爱的DEV系列控件,界面以及数据的读取,操作,保存都是不需要太多程序的,我们还积累了不少框架和通用类呢。
了解了一些AJAX框架,大多是只支持java的,这次我们要用C#,也有少数.NET的AJAX开源的项目,功能就是些框架和一些不完整的类,偶和菜哥、阿狼搞了几天,还是没有搭好一个能够很好支撑我们项目开发的基础,可能我的js和html基础太差了,后来阿狼居然在网上发现有AJAX的WebShop,下了看了,居然非常像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,还有在后台的编程实现,根据MaxRows和RecNo来取数据,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 Text和DBGrid什么的,拖拉起,设置好属性就搞定啦。
最后,DataSet的PostURL就是用来设置数据提交保存的服务路径,数据的提交比取数据要麻烦一些,涉及到增删改几种情况的处理,对了,这个DataSet来支持主从表的取数据和数据提交,这在我们的开发中是太有用了,不过编程处理也相对复杂一些,我要把这段时间的代码整理下了,好给项目组的其他人一起讲下,改天有空再写一些提交数据和主从表操作的经验。

- 描述: 图一
- 大小: 20.9 KB

- 描述: 图二
- 大小: 12.8 KB
分享到:
- 2006-12-27 14:30
- 浏览 3682
- 评论(3)
- 论坛回复 / 浏览 (3 / 6487)
- 查看更多
相关推荐
然而,这仍然需要Web服务器与数据库之间的交互,可能导致用户在页面间切换时感受到延迟。 2. **改进的分页原理** 利用AJAX(异步JavaScript和XML)技术,可以实现更高效的分页。在这种方案中,服务器首先通过存储...
可能使用了SQL Server作为后端数据库,通过ADO.NET的DataSet、DataTable等对象进行数据操作,或是利用Entity Framework的ORM(对象关系映射)特性简化数据库操作。 4. **安全性与权限管理** 系统的安全性至关重要...
分享个人在微服务架构、DevOps实践、前端框架React等方面的最新探索和心得。 #### 职业规划与期望 包括职业目标、技能提升方向、期望的工作环境和团队文化等,以及对未来行业的预测和个人定位。
小姐姐炫酷唯美引导页.zip
scratch少儿编程逻辑思维游戏源码-让它们跳起来.zip
少儿编程scratch项目源代码文件案例素材-战斗塔防.zip
前端开发_Vue全家桶_vw适配_vux组件库_mescroll滚动_fastclick优化_mock模拟_less预处理器_移动端脚手架_基于Vue2和Webpack3构建的移动
数据可视化分析_微信小程序开发_JavaScript_Canvas图表渲染_数据助手工具_仿微信小程序数据助手_支持线性图圆环图柱状图条形图_动态效果适配_商业数据分析_移动端数据
少儿编程scratch项目源代码文件案例素材-章鱼怪.zip
音乐流媒体_API开发_网易云音乐接口封装与数据抓取_提供完整的网易云音乐API调用解决方案_包含歌曲搜索_MP3资源获取_歌词解析_播放列表管理_歌手专辑查询_专辑详情展示_MV
物联网与健康监测_基于RISC-V架构ESP32-C3芯片与MAX30102MAX30205传感器_LVGL图形界面与WiFiBLE双模通信的智能手表系统_实时监测心率血氧体温
wangtengfei-hn_EmployeesExample_23540_1745868671962
Android开发_自定义View绘制动画效果_模仿小米手环App首页计步数据展示_实现可自定义目标步数当前步数颜色字体大小圆点尺寸的动态步数统计图表组件_用于健康运动类App展示
少儿编程scratch项目源代码文件案例素材-钻机机器人.zip
scratch少儿编程逻辑思维游戏源码-狂暴坦克.zip
scratch少儿编程逻辑思维游戏源码-拳击.zip
scratch少儿编程逻辑思维游戏源码-魔方冲刺.zip
少儿编程scratch项目源代码文件案例素材-重返危机.zip
杰奇CMS小说网站系统_php53-73_mysql5-MariaDB10_utf8mb4编码_GBK自动转码_INNODB存储引擎_多模块支持_前后台分离_电脑手机双版适配_
linyuan620_StockAnalysisAssistant_17128_1745866117970