簡體   English   中英

MVC解析MySQL XML表導出的最佳方法

[英]MVC best way to parse MySQL XML Table Export

我正在尋找一種解決方案,可以幫助我快速讀取XML數據庫導出文件,如下所示:

<?xml version="1.0" encoding="utf-8"?>
<database name="backup_db">
    <table name="users">
        <column name="username">user1</column>
        <column name="password">pass1</column>
        <column name="email">email1</column>
        <column name="regdate">2015-01-22 23:31:59</column>
        <column name="lastlogin">2016-12-11 01:56:24</column>
        <column name="banned">0</column>
    </table>
    <table name="users">
    ...
    </table>
    ...
    200000 table rows
</database>

我提出了一種枚舉所有元素並存儲列Value的解決方案,但是執行時間很長。

        var xd = new XmlDocument();
        string path = Server.MapPath("~/App_Data/users.xml");
        var fs = new FileStream(path, FileMode.Open);
        xd.Load(fs);

        var list = xd.GetElementsByTagName("table");
        for (var i = 0; i < list.Count; i++)
        {
           ...
        }
        fs.Close()

誰願意加快工作速度?

請嘗試以下。 它僅將數據添加為字符串,並且僅在列始終處於相同順序時才起作用(沒有跳過的列)

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Xml;
using System.Xml.Linq;
namespace ConsoleApplication1
{
    class Program
    {
        const string FILENAME = @"c:\temp\test.xml";
        static void Main(string[] args)
        {
            XmlReader reader = XmlReader.Create(FILENAME);
            if (reader.Name != "database")
            {
                reader.ReadToFollowing("database");
            }
            reader.MoveToFirstAttribute();
            string databaseName = reader.Value;
            DataSet ds = new DataSet(databaseName);
            DataTable dt = null;
            while (!reader.EOF)
            {
                if (reader.Name != "table")
                {
                    reader.ReadToFollowing("table");
                }
                if (!reader.EOF)
                {
                    XElement table = (XElement)XElement.ReadFrom(reader);
                    string tableName = (string)table.Attribute("name");
                    if (!ds.Tables.Contains(tableName))
                    {
                        dt = new DataTable(tableName);
                        ds.Tables.Add(dt);
                        dt.Columns.AddRange(table.Elements("column").Select(x => new DataColumn((string)x.Attribute("name"))).ToArray());
                    }
                    DataRow newRow = ds.Tables[tableName].Rows.Add();
                    newRow.ItemArray = table.Elements("column").Select(x => (string)x).ToArray();
                }
            }

        }
    }

}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM