分享
 
 
 

利用OleDb对象,将数据库中全部表转换成XML文件

王朝other·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

利用OleDb对象,将数据库中全部表转换成XML文件

作者:孟宪会 出自:【孟宪会之精彩世界】 发布日期:2003年4月16日 12点0分0秒

ASP.NET Dataset让你在页面中使用XML格式的文件提供了便利。如果您的数据全部都在一个数据库中,该如何进行转换呢?如果你的数据库与OleDb兼容的话,下面就看看如何把数据库中的所有表转换成XML文件。文件名字与数据库中的表的名字相同。本代码包含两个版本:C#版本和VB.NET版本。

C#版本:

<%@ Page Language="C#" %>

<%@ import Namespace="System" %>

<%@ import Namespace="System.Data" %>

<%@ import Namespace="System.Data.OleDb" %>

<script runat="server">

void Page_Load(object sender, EventArgs e) {

if (!IsPostBack) {

TextBox1.Text = "PROVIDER=SQLOLEDB; Data Source=.; Initial Catalog=pubs;User ID=sa;Password=;";

Label1.Text = "";

}

}

void CreateXml(object sender, EventArgs e) {

OleDbConnection dataConn = new OleDbConnection(TextBox1.Text);

Uri Path = Request.Url;

String ServerUrl = Path.ToString();

ServerUrl = ServerUrl.Substring(0,ServerUrl.LastIndexOf("/") +1 );

try {

Literal1.Text = "已经在你的相同目录下创建了一下文件:<br/>" ;

dataConn.Open();

DataTable schemaTable = dataConn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables,new object[] {null, null, null, "TABLE"});

for(int I = 0; I < schemaTable.Rows.Count; I++){

OleDbDataAdapter dbAdapter= new OleDbDataAdapter("select * from [" + schemaTable.Rows[I].ItemArray[2].ToString() + "]",dataConn);

DataSet tableData = new DataSet();

dbAdapter.Fill(tableData,schemaTable.Rows[I].ItemArray[2].ToString());

tableData.WriteXml(HttpContext.Current.Server.MapPath(schemaTable.Rows[I].ItemArray[2].ToString() + ".xml"));

Literal1.Text = Literal1.Text + "<a href='" + ServerUrl + schemaTable.Rows[I].ItemArray[2].ToString() + ".xml'>" + schemaTable.Rows[I].ItemArray[2].ToString() + ".xml</a><br/>";

}

}

catch(Exception ex) {

Label1.Text = ex.Message.ToString();

}

finally {

dataConn.Close();

}

}

</script>

<html>

<head>

<title>leDb2XML:数据库转换成XML文件例子</title>

</head>

<body bgcolor="#FFFFFF">

<center>

<h2><font face="宋体">OleDb2XML:数据库转换成XML文件例子</font>

</h2>

</center>

<form runat="server">

<font face="宋体">

<p align="center">请输入OleDb连接字符串,然后点“生成XML文件”按钮。</p>

<p align="center">

<asp:TextBox id="TextBox1" runat="server" Width="600"></asp:TextBox>

</p>

<p align="center">

<asp:Button id="Button1" onclick="CreateXml" runat="server" Text="生成XML文件"></asp:Button>

</p>

<p align="center">

<asp:Label id="Label1" runat="server" Font-Bold="True" ForeColor="Red"></asp:Label>

</p>

<p align="center">

<asp:Literal id="Literal1" runat="server"></asp:Literal>

</p>

</font>

</form>

</body>

</html>

VB.NET版本:

<%@ Page Language="VB" %>

<%@ import Namespace="System" %>

<%@ import Namespace="System.Data" %>

<%@ import Namespace="System.Data.OleDb" %>

<script runat="server">

Sub Page_Load(sender As Object, e As EventArgs)

If Not IsPostBack Then

TextBox1.Text = "Provider=SqlOLEDB; Data Source=.; Initial Catalog=pubs;User ID=sa;Password=;"

Label1.Text = ""

End If

End Sub

Sub CreateXml(sender As Object, e As EventArgs)

Dim dataConn As New OleDbConnection(TextBox1.Text)

Dim Path As Uri = Request.Url

Dim ServerUrl As String = Path.ToString()

ServerUrl = ServerUrl.Substring(0,ServerUrl.LastIndexOf("/") + 1 )

Try

Literal1.Text = "已经在你的相同目录下创建了一下文件:<br/>"

dataConn.Open()

Dim schemaTable As DataTable = dataConn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, New Object() {Nothing, Nothing, Nothing, "TABLE"})

Dim I As Integer

For I = 0 To schemaTable.Rows.Count - 1

Dim dbAdapter As New OleDbDataAdapter("select * from [" + schemaTable.Rows(I).ItemArray(2).ToString() + "]", dataConn)

Dim tableData As New DataSet()

dbAdapter.Fill(tableData, schemaTable.Rows(I).ItemArray(2).ToString())

tableData.WriteXml(HttpContext.Current.Server.MapPath((schemaTable.Rows(I).ItemArray(2).ToString() + ".xml")))

Literal1.Text = Literal1.Text + "<a href='" + ServerUrl + schemaTable.Rows(I).ItemArray(2).ToString() + ".xml'>" + schemaTable.Rows(I).ItemArray(2).ToString() + ".xml</a><br/>"

Next I

Catch ex As Exception

Label1.Text = ex.Message.ToString()

Finally

dataConn.Close()

End Try

End Sub

</script>

<html>

<head>

<title>leDb2XML:数据库转换成XML文件例子</title>

</head>

<body bgcolor="#FFFFFF">

<center>

<h2><font face="宋体">OleDb2XML:数据库转换成XML文件例子</font>

</h2>

</center>

<form runat="server">

<font face="宋体">

<p align="center">请输入OleDb连接字符串,然后点“生成XML文件”按钮。</p>

<p align="center">

<asp:TextBox id="TextBox1" runat="server" Width="600"></asp:TextBox>

</p>

<p align="center">

<asp:Button id="Button1" onclick="CreateXml" runat="server" Text="生成XML文件"></asp:Button>

</p>

<p align="center">

<asp:Label id="Label1" runat="server" Font-Bold="True" ForeColor="Red"></asp:Label>

</p>

<p align="center">

<asp:Literal id="Literal1" runat="server"></asp:Literal>

</p>

</font>

</form>

</body>

</html>

对于数据量大的数据库,处理可能会需要更多的时间,因此有可能需要更改machine.config文件中processModel的responseDeadlockInterval 属性,比如为5分钟,默认为3分钟。 <processModel

enable="true"

timeout="Infinite"

idleTimeout="Infinite"

shutdownTimeout="0:00:05"

requestLimit="Infinite"

requestQueueLimit="5000"

restartQueueLimit="10"

memoryLimit="60"

webGarden="false"

cpuMask="0xffffffff"

userName="machine"

password="AutoGenerate"

logLevel="Errors"

clientConnectedCheck="0:00:05"

comAuthenticationLevel="Connect"

comImpersonationLevel="Impersonate"

responseRestartDeadlockInterval="00:09:00"

responseDeadlockInterval="00:05:00" default is 00:03:00

maxWorkerThreads="25"

maxIoThreads="25" />

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有