栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

将英语维基百科转储导入SQL Server

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

将英语维基百科转储导入SQL Server

使用以下

SQL查询创建数据库

Create Database Feed;GOUSE [Feed]drop table Docdrop table links;GOCREATE TABLE [dbo].[Doc](   DocID int primary key,   Title [varchar](50) NULL,   URL [varchar](50) NULL,   Abstract [varchar](50) NULL)CREATE TABLE links(   DocID int,    linkType [varchar](10) NULL,   Anchor [varchar](50) NULL,    link [varchar](50) NULL   ConSTRAINT FK_DocID FOREIGN KEY (DocID)        REFERENCES dbo.Doc (DocID))

C#代码从xml填充数据库

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Xml;using System.Xml.Linq;using System.Data;using System.Data.SqlClient;namespace ConsoleApplication1{    class Program    {        const string FILENAME = @"c:temptest.xml";        const string CONNECTION_STRING = @"Server=.SQLEXPRESS;Database=Feed;Trusted_Connection=True;";        const string INSERT_DOC = "INSERT INTO [Feed].[dbo].[Doc] (" + "DocID, Title , URL, Abstract)" + " VALUES " + "(@DocID, @Title, @URL, @Abstract)";        const string INSERT_link = "INSERT INTO [Feed].[dbo].[links] (" + "DocID, linkType , Anchor, link)" + " VALUES " + "(@DocID, @linktype, @Anchor, @link)";        static void Main(string[] args)        { SqlConnection conn = new SqlConnection(CONNECTION_STRING); conn.Open(); SqlCommand docCmd = new SqlCommand(INSERT_DOC, conn); docCmd.Parameters.Add("@DocID", SqlDbType.Int); docCmd.Parameters.Add("@Title", SqlDbType.VarChar, 50); docCmd.Parameters.Add("@URL", SqlDbType.VarChar, 50); docCmd.Parameters.Add("@Abstract", SqlDbType.VarChar, 50); SqlCommand linksCmd = new SqlCommand(INSERT_link, conn); linksCmd.Parameters.Add("@DocID", SqlDbType.Int); linksCmd.Parameters.Add("@linkType", SqlDbType.VarChar, 10); linksCmd.Parameters.Add("@Anchor", SqlDbType.VarChar, 50); linksCmd.Parameters.Add("@link", SqlDbType.VarChar, 50); XmlReader reader = XmlReader.Create(FILENAME); int id = 0; while (!reader.EOF) {     if (reader.Name != "doc")     {         reader.ReadToFollowing("doc");     }     if (!reader.EOF)     {         XElement doc = (XElement)XElement.ReadFrom(reader);         id++;         docCmd.Parameters["@DocID"].Value = id;         docCmd.Parameters["@Title"].Value = (string)doc.Element("title");         docCmd.Parameters["@URL"].Value = (string)doc.Element("url");         docCmd.Parameters["@Abstract"].Value = (string)doc.Element("abstract");         int docRowsChanged = docCmd.ExecuteNonQuery();         foreach (XElement sublink in doc.Descendants("sublink"))         {  linksCmd.Parameters["@DocID"].Value = id;  linksCmd.Parameters["@linkType"].Value = (string)sublink.Attribute("linktype");  linksCmd.Parameters["@Anchor"].Value = (string)sublink.Element("anchor");  linksCmd.Parameters["@link"].Value = (string)sublink.Element("link");  int linksRowsChanged = linksCmd.ExecuteNonQuery();         }     } }        }    }}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/634579.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号