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

程序段中对语句作了说明。主要使用xmlwriter类进行xml文件生成。
下面这是由关系数据库生成相应xml文件过程。由于xml只是中间件,所以忽略了schema或者dtd。
 1        private void page_load(object sender, system.eventargs e)
 2        {
 3            // 在此处放置用户代码以初始化页面
 4            //基本信息定义
 5            string strtablename="systypes";
 6            string strconnection="server=suntears;user id=sa;password=041210;database=webapplication1_db";
 7            string strsql="select * from "+strtablename;
 8            sqlconnection objconn=new sqlconnection(strconnection);
 9            sqldataadapter objadapter=new sqldataadapter(strsql,objconn);
10            dataset objdset=new dataset();
11            objadapter.fill(objdset,"temp");
12            xmltextwriter objxmlwriter;
13            string strtemp1=request.physicalapplicationpath;
14            string strpath=strtemp1+"qiming.xml";
15            //初始化xmlwriter.用此类写xml文件
16            objxmlwriter=new xmltextwriter(strpath,null);
17            //创建开头的xml声明
18            objxmlwriter.writestartdocument();
19            //创建根元素xml1
20            objxmlwriter.writestartelement("xml1");
21            //表名为元素名,字段名为属性,表中的记录为属性的值
22            for(int i=0;i<objdset.tables["temp"].rows.count;i++)
23            {
24            objxmlwriter.writestartelement("menu");
25                for(int j=0;j<objdset.tables["temp"].columns.count;j++)
26                {
27                    //写入属性
28                    objxmlwriter.writeattributestring(objdset.tables["temp"].columns[j].columnname,objdset.tables["temp"].rows[i][j].tostring());
29                }
30                objxmlwriter.writeendelement();
31            }
32            objxmlwriter.writeendelement();
33            objxmlwriter.writeenddocument();
34            //用close方法关闭文件,否则文件将被锁定
35            objxmlwriter.close();
36            // 在页面上显示结果
37            string strxmlresult;
38            streamreader objsr = file.opentext(strpath);
39            strxmlresult = objsr.readtoend();
40            objsr.close();
41            response.write("<pre>" + server.htmlencode(strxmlresult) + "<pre>");
42        }
下面是通过上面程序生成的xml文件生成关系数据库的代码

 1        private void page_load(object sender, system.eventargs e)
 2        {
 3            // 在此处放置用户代码以初始化页面
 4            //基本信息定义
 5            int cx=1;
 6            string strconn="server=suntears;user id=sa;password=;database=xml_example";
 7            string strappstr=request.physicalapplicationpath;
 8            string strpath=strappstr+"qiming.xml";
 9            string strtablename="xml1";
10            string strcreatetable="create table "+strtablename+"(";
11            xmltextreader objxmlreader=new xmltextreader(strpath);
12            sqlconnection objconn=new sqlconnection(strconn);
13            sqlcommand objcommand;
14            sqldataadapter objadapter;
15            dataset objdset=new dataset();
16            datarow objrow;
17            xmlnodetype objnodetype;
18            //采用xmlreader类进行xml文件访问操作
19            //xmlreader采用拉(pull)模式。因此通过read()方法迭代各个节点
20            while(objxmlreader.read())
21            {
22                objnodetype=objxmlreader.nodetype;
23                //根据节点类型进行不同操作
24                switch(objnodetype)
25                {
26                    //xml文件开头的声明
27                    case xmlnodetype.xmldeclaration:
28                        response.write("11111"+objxmlreader.name+"<br>");
29                        break;
30                    //正常节点类型
31                    case xmlnodetype.element:
32                        //根据属性个数判断是否是根元素
33                        if(objxmlreader.attributecount>0)
34                        {
35                            //cx作为标志位。第一次访问非根元素节点时根据元素结构生成数据库
36                            if(cx==1)
37                            {
38                                while(objxmlreader.movetonextattribute())
39                                {
40                                    strcreatetable=strcreatetable+objxmlreader.name+" varchar(50), ";
41                                }
42                                strcreatetable=strcreatetable+")";
43                                objcommand=new sqlcommand(strcreatetable,objconn);
44                                objconn.open();
45                                objcommand.executenonquery();
46                                objconn.close();
47                                objadapter=new sqldataadapter("select * from "+strtablename,objconn);
48                                objadapter.fill(objdset,strtablename);
49                                objxmlreader.movetofirstattribute();
50                                //更改标志为cx数值
51                                cx=0;
52                            }
53                            //将xml文件中数据转存到dataset对象中
54                            objrow=objdset.tables[strtablename].newrow();
55                            objxmlreader.movetofirstattribute();
56                            for(int j=0;j<objxmlreader.attributecount;j++)
57                            {
58                                objrow[j]=objxmlreader.value.tostring();
59                                objxmlreader.movetonextattribute();
60                            }
61                            objdset.tables[strtablename].rows.add(objrow);
62                        }
63                        break;
64                }
65            }
66            //显示转存后的数据表
67            datagrid1.datasource=objdset.tables[strtablename];
68            datagrid1.databind();
69        }将数据更新到数据库的代码没有编写,自己弄吧^_^

http://suntears.cnblogs.com/archive/2006/06/02/416207.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号