久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

          <bdo id='9uYa6'></bdo><ul id='9uYa6'></ul>
        <legend id='9uYa6'><style id='9uYa6'><dir id='9uYa6'><q id='9uYa6'></q></dir></style></legend>

      1. <i id='9uYa6'><tr id='9uYa6'><dt id='9uYa6'><q id='9uYa6'><span id='9uYa6'><b id='9uYa6'><form id='9uYa6'><ins id='9uYa6'></ins><ul id='9uYa6'></ul><sub id='9uYa6'></sub></form><legend id='9uYa6'></legend><bdo id='9uYa6'><pre id='9uYa6'><center id='9uYa6'></center></pre></bdo></b><th id='9uYa6'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='9uYa6'><tfoot id='9uYa6'></tfoot><dl id='9uYa6'><fieldset id='9uYa6'></fieldset></dl></div>
        <tfoot id='9uYa6'></tfoot>

        <small id='9uYa6'></small><noframes id='9uYa6'>

      2. 通過非制表符分隔符的非結構化 XML?

        Unstructured XML via non-tab deliminator?(通過非制表符分隔符的非結構化 XML?)

          • <bdo id='hRuQq'></bdo><ul id='hRuQq'></ul>
          • <legend id='hRuQq'><style id='hRuQq'><dir id='hRuQq'><q id='hRuQq'></q></dir></style></legend>

              <tbody id='hRuQq'></tbody>
            <tfoot id='hRuQq'></tfoot>
                <i id='hRuQq'><tr id='hRuQq'><dt id='hRuQq'><q id='hRuQq'><span id='hRuQq'><b id='hRuQq'><form id='hRuQq'><ins id='hRuQq'></ins><ul id='hRuQq'></ul><sub id='hRuQq'></sub></form><legend id='hRuQq'></legend><bdo id='hRuQq'><pre id='hRuQq'><center id='hRuQq'></center></pre></bdo></b><th id='hRuQq'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='hRuQq'><tfoot id='hRuQq'></tfoot><dl id='hRuQq'><fieldset id='hRuQq'></fieldset></dl></div>
              • <small id='hRuQq'></small><noframes id='hRuQq'>

                1. 本文介紹了通過非制表符分隔符的非結構化 XML?的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

                  問題描述

                  限時送ChatGPT賬號..

                  我們有一個復雜的 XML 結構,而且確實很大 (>500 MB).結構的 XSD 是:

                  有了 jdweng 的好回答,我們想要提取所有信息.

                  解決方案

                  決定艱難地創建SQL數據庫.沒有一個工具能很好地工作.我只裝了幾張桌子.如果需要,您可以添加更多.

                  步驟 1 在 SQL Server Management Studio 中使用以下查詢創建數據庫.如果您多次運行并且數據庫或表已經存在,則查詢可能會出錯.

                  運行以下c#項目:

                  使用系統;使用 System.Collections.Generic;使用 System.Linq;使用 System.Text;使用 System.Threading.Tasks;使用 System.Data;使用 System.Data.SqlClient;使用 System.Xml;使用 System.Xml.Linq;使用 System.IO;命名空間 DrubBank{課堂節目{常量字符串 FILENAME = @"c:	empfull database.xml";靜態無效主要(字符串 [] 參數){新的 UploadXml(文件名);}}公共類 UploadXml{常量字符串 INSERT_DRUG ="插入 [DrugBank].[dbo].[Drugs] (" +"[類型],[創建],[更新],[ID],[名稱],[描述],[案例編號],[Unii],[狀態]," +"【合成參考】、【適應癥】、【藥效學】、【作用機制】、【毒性】,"+"[代謝] , [吸收] ,[半衰期], [蛋白質結合],, +【淘汰路線】、【分發量】、【清倉】)"+"價值觀" +"(@Type、@Created、@Updated、@ID、@Name、@Description、@Case_Number、@Unii、@State,"+@Synthesis_Reference,@Indication,@Pharmacodynamics,@Mechanism_of_Action,@Toxicity,"+@代謝,@吸收,@Half_Life,@Protein_Binding,"+@Route_of_Elimination,@Volume_of_Distribution,@Clearance)";常量字符串 INSERT_DRUG_LINK ="插入 [DrugBank].[dbo].[Links] (" +"[ID],[標題],[URL])" +"價值觀" +"(@ID,@Title,@URL)";常量字符串 INSERT_DRUG_ARTICLE ="插入 [DrugBank].[dbo].[Articles] (" +"[ID],[Pubmed ID],[Citation])" +"價值觀" +"(@ID,@Pubmed_ID, @Citation)";常量字符串 INSERT_DRUG_INTERACTION ="插入 [DrugBank].[dbo].[交互] (" +"[ID],[交互 ID],[描述])" +"價值觀" +"(@ID,@Interaction_ID, @Description)";常量字符串 INSERT_DRUG_ID ="插入 [DrugBank].[dbo].[ID] (" +"[ID],[ALT ID])" +"價值觀" +(@ID,@ALT_ID)";常量字符串 INSERT_DRUG_PRODUCT ="插入 [DrugBank].[dbo].[Products] (" +"[ID],[Name],[Labeller], [NDC ID], [NDC Product Code], [DPD ID]," +[EMA 產品代碼]、[EMA MA 編號]、[開始營銷時間]、[結束營銷時間]、[劑型]",+"[Strength],[Route],[FDA Application Number],[Generic],[Over the Counter],[Approved],[Country],[Source])" +"價值觀" +"(@ID,@Name,@Labeller,@NDC_ID,@NDC_Product_Code,@DPD_ID," +"@EMA_Product_Code、@EMA_MA_Number、@Started_Marketing_On、@Ended_Marketing_On、@Dosage_Form," +@Strength,@Route,@FDA_Application_Number,@Generic,@Over_the_Counter,@Approved,@Country,@Source)";常量字符串 INSERT_DRUG_MIXTURE ="插入 [DrugBank].[dbo].[混合物] (" +"[ID]、[姓名]、[成分])" +"價值觀" +"(@ID, @Name, @ingredients)";常量字符串 INSERT_DRUG_PACKAGER ="插入 [DrugBank].[dbo].[Packagers] (" +"[ID]、[名稱]、[URL])" +"價值觀" +"(@ID, @Name, @URL)";常量字符串 INSERT_DRUG_PRICE ="插入 [DrugBank].[dbo].[價格] (" +"[ID]、[描述]、[成本]、[貨幣]、[單位])" +"價值觀" +(@ID,@Description,@Cost,@Currency,@Unit)";常量字符串 INSERT_DRUG_CATEGORY ="插入 [DrugBank].[dbo].[Categories] (" +"[ID]、[類別]、[網格 ID])" +"價值觀" +(@ID,@Category,@Mesh_ID)";常量字符串 INSERT_DRUG_ORGANISM ="插入 [DrugBank].[dbo].[有機體] (" +"[ID],[有機體])" +"價值觀" +(@ID,@Organism)";常量字符串 INSERT_DRUG_PATENT ="插入 [DrugBank].[dbo].[專利] (" +"[ID]、[Number]、[Country]、[Approved]、[Expires]、[Pediatric Extension])" +"價值觀" +(@ID、@Number、@Country、@Approved、@Expires、@Pediatric_Extension)";常量字符串 INSERT_DRUG_SEQUENCE ="插入 [DrugBank].[dbo].[Sequences] (" +"[ID]、[格式]、[類型]、[序列])" +"價值觀" +(@ID,@Format,@Type,@Sequence)";常量字符串 INSERT_DRUG_PROPERTY ="插入 [DrugBank].[dbo].[Properties] (" +"[ID]、[種類]、[值]、[來源])" +"價值觀" +(@ID,@Kind,@Value,@Source)";常量字符串 INSERT_DRUG_IDENTIFIER ="插入 [DrugBank].[dbo].[標識符] (" +"[ID]、[資源]、[標識符])" +"價值觀" +(@ID,@Resource,@Identifier)";常量字符串 INSERT_DRUG_ENZYM ="插入 [藥物庫].[dbo].[酶] (" +"[ID], [UniprotID])" +"價值觀" +(@ID,@UniprotID)";SqlCommand productCmd = null;SqlCommand 交互Cmd = null;SqlCommand articleCmd = null;SqlCommand linkCmd = null;SqlCommand drugCmd = null;SqlCommand idCmd = null;SqlCommand mixCmd = null;SqlCommand packagerCmd = null;SqlCommand priceCmd = null;SqlCommand categoryCmd = null;SqlCommand有機體Cmd = null;SqlCommand 專利Cmd = null;SqlCommand sequenceCmd = null;SqlCommand propertyCmd = null;SqlCommand 標識符Cmd = null;SqlCommand enzymCmd = null;公共 UploadXml(字符串文件名){字符串 connStr = DrugBank.Properties.Settings.Default.DrugBankConnectionString;SqlConnection conn = new SqlConnection(connStr);conn.Open();drugCmd = new SqlCommand(INSERT_DRUG, conn);drugCmd.Parameters.Add("@Type", SqlDbType.VarChar, 20);drugCmd.Parameters.Add("@Created", SqlDbType.DateTime);drugCmd.Parameters.Add("@Updated", SqlDbType.DateTime);drugCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);drugCmd.Parameters.Add("@Name", SqlDbType.VarChar, 50);drugCmd.Parameters.Add("@Description", SqlDbType.VarChar);drugCmd.Parameters.Add("@Case_Number", SqlDbType.VarChar, 20);drugCmd.Parameters.Add("@Unii", SqlDbType.VarChar, 20);drugCmd.Parameters.Add("@State", SqlDbType.VarChar, 20);drugCmd.Parameters.Add("@Synthesis_reference", SqlDbType.VarChar, 1024);drugCmd.Parameters.Add("@Indication", SqlDbType.VarChar);drugCmd.Parameters.Add("@Pharmacodynamics", SqlDbType.VarChar, 1024);drugCmd.Parameters.Add("@Mechanism_of_Action", SqlDbType.VarChar, 1024);drugCmd.Parameters.Add("@Toxicity", SqlDbType.VarChar, 1024);drugCmd.Parameters.Add("@Metabolism", SqlDbType.VarChar);drugCmd.Parameters.Add("@Absorption", SqlDbType.VarChar, 1024);drugCmd.Parameters.Add("@Half_Life", SqlDbType.VarChar, 256);drugCmd.Parameters.Add("@Protein_Binding", SqlDbType.VarChar, 64);drugCmd.Parameters.Add("@Route_of_Elimination", SqlDbType.VarChar);drugCmd.Parameters.Add("@Volume_of_Distribution", SqlDbType.VarChar);drugCmd.Parameters.Add("@Clearance", SqlDbType.VarChar);idCmd = new SqlCommand(INSERT_DRUG_ID, conn);idCmd.Parameters.Add("@ID", SqlDbType.VarChar, 256);idCmd.Parameters.Add("@ALT_ID", SqlDbType.VarChar, 20);articleCmd = new SqlCommand(INSERT_DRUG_ARTICLE, conn);articleCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);articleCmd.Parameters.Add("@Pubmed_ID", SqlDbType.VarChar, 256);articleCmd.Parameters.Add("@Citation", SqlDbType.VarChar, 20);linkCmd = new SqlCommand(INSERT_DRUG_LINK, conn);linkCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);linkCmd.Parameters.Add("@Title", SqlDbType.VarChar, 256);linkCmd.Parameters.Add("@URL", SqlDbType.VarChar, 64);interactionCmd = new SqlCommand(INSERT_DRUG_INTERACTION, conn);interactionCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);interactionCmd.Parameters.Add("@Interaction_ID", SqlDbType.VarChar, 20);interactionCmd.Parameters.Add("@Description", SqlDbType.VarChar, 256);productCmd = new SqlCommand(INSERT_DRUG_PRODUCT, conn);productCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);productCmd.Parameters.Add("@Name", SqlDbType.VarChar, 128);productCmd.Parameters.Add("@Labeller", SqlDbType.VarChar, 64);productCmd.Parameters.Add("@NDC_ID", SqlDbType.VarChar, 20);productCmd.Parameters.Add("@NDC_Product_Code", SqlDbType.VarChar, 20);productCmd.Parameters.Add("@DPD_ID", SqlDbType.VarChar, 20);productCmd.Parameters.Add("@EMA_Product_Code", SqlDbType.VarChar, 20);productCmd.Parameters.Add("@EMA_MA_Number", SqlDbType.VarChar, 20);productCmd.Parameters.Add("@Started_Marketing_On", SqlDbType.DateTime2, 20);productCmd.Parameters.Add("@Ended_Marketing_On", SqlDbType.DateTime2, 20);productCmd.Parameters.Add("@Dosage_Form", SqlDbType.VarChar, 64);productCmd.Parameters.Add("@Strength", SqlDbType.VarChar, 20);productCmd.Parameters.Add("@Route", SqlDbType.VarChar, 20);productCmd.Parameters.Add("@FDA_Application_Number", SqlDbType.VarChar, 20);productCmd.Parameters.Add("@Generic", SqlDbType.Bit);productCmd.Parameters.Add("@Over_the_Counter", SqlDbType.Bit);productCmd.Parameters.Add("@Approved", SqlDbType.Bit);productCmd.Parameters.Add("@Country", SqlDbType.VarChar, 20);productCmd.Parameters.Add("@Source", SqlDbType.VarChar, 20);mixCmd = new SqlCommand(INSERT_DRUG_MIXTURE, conn);mixCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);mixCmd.Parameters.Add("@Name", SqlDbType.VarChar, 64);mixCmd.Parameters.Add("@Ingredients", SqlDbType.VarChar, 64);packagerCmd = new SqlCommand(INSERT_DRUG_PACKAGER, conn);packagerCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);packagerCmd.Parameters.Add("@Name", SqlDbType.VarChar, 64);packagerCmd.Parameters.Add("@URL", SqlDbType.VarChar, 64);priceCmd = new SqlCommand(INSERT_DRUG_PRICE, conn);priceCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);priceCmd.Parameters.Add("@Description", SqlDbType.VarChar, 128);priceCmd.Parameters.Add("@Cost", SqlDbType.Decimal);priceCmd.Parameters.Add("@Currency", SqlDbType.VarChar,20);priceCmd.Parameters.Add("@Unit", SqlDbType.VarChar, 20);categoryCmd = new SqlCommand(INSERT_DRUG_CATEGORY, conn);categoryCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);categoryCmd.Parameters.Add("@Category", SqlDbType.VarChar, 128);categoryCmd.Parameters.Add("@Mesh_ID", SqlDbType.VarChar, 20);OrganicCmd = new SqlCommand(INSERT_DRUG_ORGANISM, conn);有機體Cmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);OrganicCmd.Parameters.Add("@Organism", SqlDbType.VarChar, 128);PatentCmd = 新的 SqlCommand(INSERT_DRUG_PATENT, conn);PatentCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);PatentCmd.Parameters.Add("@Number", SqlDbType.VarChar, 20);PatentCmd.Parameters.Add("@Country", SqlDbType.VarChar, 20);PatentCmd.Parameters.Add("@Approved", SqlDbType.DateTime2);PatentCmd.Parameters.Add("@Expires", SqlDbType.DateTime2);PatentCmd.Parameters.Add("@Pediatric_Extension", SqlDbType.Bit);sequenceCmd = new SqlCommand(INSERT_DRUG_SEQUENCE, conn);sequenceCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);sequenceCmd.Parameters.Add("@Format", SqlDbType.VarChar, 20);sequenceCmd.Parameters.Add("@Sequence", SqlDbType.VarChar);sequenceCmd.Parameters.Add("@Type", SqlDbType.VarChar, 20);propertyCmd = new SqlCommand(INSERT_DRUG_PROPERTY, conn);propertyCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);propertyCmd.Parameters.Add("@Kind", SqlDbType.VarChar, 20);propertyCmd.Parameters.Add("@Value", SqlDbType.VarChar, 20);propertyCmd.Parameters.Add("@Source", SqlDbType.VarChar, 20);identifierCmd = new SqlCommand(INSERT_DRUG_IDENTIFIER, conn);identifierCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);identifierCmd.Parameters.Add("@Resource", SqlDbType.VarChar, 64);identifierCmd.Parameters.Add("@Identifier", SqlDbType.VarChar, 64);enzymCmd = new SqlCommand(INSERT_DRUG_ENZYM, conn);enzymCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);enzymCmd.Parameters.Add("@UniprotID", SqlDbType.VarChar, 20);XmlReader 閱讀器 = XmlReader.Create(filename);而(!reader.EOF){if (reader.Name !="drug"){reader.ReadToFollowing("藥物");}如果 (!reader.EOF){XElement 藥物 = (XElement)XElement.ReadFrom(reader);string primaryID = (string)drug.Elements().Where(x => (x.Name.LocalName == "drugbank-id") && (x.Attribute("primary") != null)).FirstOrDefault();AddDrug(conn, drug, primaryID);AddArticles(conn, drug, primaryID);AddInteractions(conn, drug, primaryID);AddProducts(conn, drug, primaryID);AddMixtures(conn, drug, primaryID);AddPackagers(conn, drug, primaryID);AddPrices(conn, drug, primaryID);AddCategories(conn, drug, primaryID);AddOrganisms(conn, drug, primaryID);AddPatents(conn, drug, primaryID);AddSequences(conn, drug, primaryID);AddProperties(conn, drug, primaryID);AddIdentifiers(conn, drug, primaryID);AddEnzymes(conn, drug, primaryID);}}}

                  We have a complex XML Structure and really a big one (>500 MB). the XSD of the structure is: This XSD

                  As we know this is a complex one. and because of size or non-tab deliminator structure, I couldn't convert it to a readable better presentation.

                  I want to read this file via C# and search the drug name. what is wrong via my code?

                          try
                          {
                              XmlReader xmlFile;
                              xmlFile = XmlReader.Create("C:\Users\Dr\Desktop\full database.xml", new XmlReaderSettings());
                              DataSet ds = new DataSet();
                              ds.ReadXml(xmlFile);
                              dataGridView1.DataSource = ds.Tables[0];
                          }
                          catch (Exception ex)
                          {
                              MessageBox.Show(ex.ToString());
                          }
                  

                  My error is as follows:

                  How I can search inside this XML and get the information around Drug name?

                  Update: Sample XML

                  The XML Structure

                  With nice answer of jdweng we want to extract all information.

                  解決方案

                  Decided to create the SQL database the hard way. None of the tools worked well. I only crate a few of the tables. You can add more if needed.

                  Step 1 Crate Database in SQL Server Management Studio using following query. Query may give errors if you run multiple times and database or table already exists.

                  The run following c# project :

                  using System;
                  using System.Collections.Generic;
                  using System.Linq;
                  using System.Text;
                  using System.Threading.Tasks;
                  using System.Data;
                  using System.Data.SqlClient;
                  using System.Xml;
                  using System.Xml.Linq;
                  using System.IO;
                  
                  namespace DrubBank
                  {
                      class Program
                      {
                          const string FILENAME = @"c:	empfull database.xml";
                          static void Main(string[] args)
                          {
                              new UploadXml(FILENAME);
                          }
                      }
                      public class UploadXml
                      {
                          const string INSERT_DRUG =
                              "INSERT INTO [DrugBank].[dbo].[Drugs] (" +
                              "[Type],[Created],[Updated],[ID],[Name],[Description],[Case Number],[Unii],[State]," +
                              "[Synthesis Reference],[Indication] ,[Pharmacodynamics] ,[Mechanism of Action], [Toxicity]," +
                              "[Metabolism] , [Absorption] ,[Half Life], [Protein Binding]," +
                              "[Route of Eelimination], [Volume of Distribution] ,[Clearance])" +
                              " VALUES " +
                              "(@Type, @Created, @Updated, @ID, @Name, @Description, @Case_Number, @Unii, @State," +
                               "@Synthesis_Reference,@Indication ,@Pharmacodynamics ,@Mechanism_of_Action, @Toxicity," +
                               "@Metabolism , @Absorption ,@Half_Life, @Protein_Binding," +
                               "@Route_of_Elimination, @Volume_of_Distribution ,@Clearance)";
                  
                          const string INSERT_DRUG_LINK =
                              "INSERT INTO [DrugBank].[dbo].[Links] (" +
                              "[ID],[Title],[URL])" +
                              " VALUES " +
                              "(@ID,@Title, @URL)";
                  
                          const string INSERT_DRUG_ARTICLE =
                              "INSERT INTO [DrugBank].[dbo].[Articles] (" +
                              "[ID],[Pubmed ID],[Citation])" +
                              " VALUES " +
                              "(@ID,@Pubmed_ID, @Citation)";
                  
                          const string INSERT_DRUG_INTERACTION =
                              "INSERT INTO [DrugBank].[dbo].[Interactions] (" +
                              "[ID],[Interaction ID],[Description])" +
                              " VALUES " +
                              "(@ID,@Interaction_ID, @Description)";
                  
                          const string INSERT_DRUG_ID =
                              "INSERT INTO [DrugBank].[dbo].[IDs] (" +
                              "[ID],[ALT ID])" +
                              " VALUES " +
                              "(@ID, @ALT_ID)";
                  
                          const string INSERT_DRUG_PRODUCT =
                              "INSERT INTO [DrugBank].[dbo].[Products] (" +
                              "[ID],[Name],[Labeller], [NDC ID], [NDC Product Code], [DPD ID]," +
                              "[EMA Product Code],[EMA MA Number],[Started Marketing On], [Ended Marketing On], [Dosage Form]," +
                              "[Strength],[Route],[FDA Application Number],[Generic],[Over the Counter],[Approved],[Country],[Source])" +
                              " VALUES " +
                              "(@ID,@Name,@Labeller, @NDC_ID, @NDC_Product_Code,@DPD_ID," +
                              "@EMA_Product_Code,@EMA_MA_Number,@Started_Marketing_On, @Ended_Marketing_On, @Dosage_Form," +
                              "@Strength,@Route,@FDA_Application_Number,@Generic,@Over_the_Counter,@Approved,@Country,@Source)";
                  
                          const string INSERT_DRUG_MIXTURE =
                              "INSERT INTO [DrugBank].[dbo].[Mixtures] (" +
                              "[ID], [Name] , [ingredients])" +
                              " VALUES " +
                              "(@ID, @Name, @ingredients)";
                  
                          const string INSERT_DRUG_PACKAGER =
                               "INSERT INTO [DrugBank].[dbo].[Packagers] (" +
                               "[ID], [Name], [URL])" +
                               " VALUES " +
                               "(@ID, @Name, @URL)";
                  
                          const string INSERT_DRUG_PRICE = 
                               "INSERT INTO [DrugBank].[dbo].[Prices] (" +
                               "[ID], [Description], [Cost], [Currency], [Unit])" +
                               " VALUES " +
                               "(@ID, @Description, @Cost, @Currency, @Unit)";
                  
                          const string INSERT_DRUG_CATEGORY =
                              "INSERT INTO [DrugBank].[dbo].[Categories] (" +
                              "[ID], [Category], [Mesh ID])" +
                              " VALUES " +
                              "(@ID, @Category, @Mesh_ID)";
                  
                          const string INSERT_DRUG_ORGANISM =
                              "INSERT INTO [DrugBank].[dbo].[Organisms] (" +
                              "[ID], [Organism])" +
                              " VALUES " +
                              "(@ID, @Organism)";
                  
                          const string INSERT_DRUG_PATENT =
                              "INSERT INTO [DrugBank].[dbo].[Patents] (" +
                              "[ID], [Number], [Country], [Approved], [Expires], [Pediatric Extension]) " +
                              " VALUES " +
                              "(@ID, @Number, @Country, @Approved, @Expires, @Pediatric_Extension) ";
                  
                          const string INSERT_DRUG_SEQUENCE =
                              "INSERT INTO [DrugBank].[dbo].[Sequences] (" +
                              "[ID], [Format], [Type], [Sequence])" +
                              " VALUES " +
                              "(@ID, @Format, @Type, @Sequence)";
                  
                          const string INSERT_DRUG_PROPERTY =
                              "INSERT INTO [DrugBank].[dbo].[Properties] (" +
                              "[ID], [Kind], [Value], [Source])" +
                              " VALUES " +
                              "(@ID, @Kind, @Value, @Source)";
                  
                          const string INSERT_DRUG_IDENTIFIER =
                              "INSERT INTO [DrugBank].[dbo].[Identifiers] (" +
                              "[ID], [Resource], [Identifier])" +
                              " VALUES " +
                              "(@ID, @Resource, @Identifier)";
                  
                          const string INSERT_DRUG_ENZYM =
                              "INSERT INTO [DrugBank].[dbo].[Enzymes] (" +
                              "[ID], [UniprotID])" +
                              " VALUES " +
                              "(@ID, @UniprotID)";
                  
                          SqlCommand productCmd = null;
                          SqlCommand interactionCmd = null;
                          SqlCommand articleCmd = null;
                          SqlCommand linkCmd = null;
                          SqlCommand drugCmd = null;
                          SqlCommand idCmd = null;
                          SqlCommand mixtureCmd = null;
                          SqlCommand packagerCmd = null;
                          SqlCommand priceCmd = null;
                          SqlCommand categoryCmd = null;
                          SqlCommand organismCmd = null;
                          SqlCommand patentCmd = null;
                          SqlCommand sequenceCmd = null;
                          SqlCommand propertyCmd = null;
                          SqlCommand identifierCmd = null;
                          SqlCommand enzymCmd = null;
                  
                          public UploadXml(string filename)
                          {
                              string connStr = DrugBank.Properties.Settings.Default.DrugBankConnectionString;
                              SqlConnection conn = new SqlConnection(connStr);
                              conn.Open();
                  
                              drugCmd = new SqlCommand(INSERT_DRUG, conn);
                  
                              drugCmd.Parameters.Add("@Type", SqlDbType.VarChar, 20);
                              drugCmd.Parameters.Add("@Created", SqlDbType.DateTime);
                              drugCmd.Parameters.Add("@Updated", SqlDbType.DateTime);
                              drugCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              drugCmd.Parameters.Add("@Name", SqlDbType.VarChar, 50);
                              drugCmd.Parameters.Add("@Description", SqlDbType.VarChar);
                              drugCmd.Parameters.Add("@Case_Number", SqlDbType.VarChar, 20);
                              drugCmd.Parameters.Add("@Unii", SqlDbType.VarChar, 20);
                              drugCmd.Parameters.Add("@State", SqlDbType.VarChar, 20);
                  
                              drugCmd.Parameters.Add("@Synthesis_reference", SqlDbType.VarChar, 1024);
                              drugCmd.Parameters.Add("@Indication", SqlDbType.VarChar);
                              drugCmd.Parameters.Add("@Pharmacodynamics", SqlDbType.VarChar, 1024);
                              drugCmd.Parameters.Add("@Mechanism_of_Action", SqlDbType.VarChar, 1024);
                              drugCmd.Parameters.Add("@Toxicity", SqlDbType.VarChar, 1024);
                              drugCmd.Parameters.Add("@Metabolism", SqlDbType.VarChar);
                              drugCmd.Parameters.Add("@Absorption", SqlDbType.VarChar, 1024);
                              drugCmd.Parameters.Add("@Half_Life", SqlDbType.VarChar, 256);
                              drugCmd.Parameters.Add("@Protein_Binding", SqlDbType.VarChar, 64);
                              drugCmd.Parameters.Add("@Route_of_Elimination", SqlDbType.VarChar);
                              drugCmd.Parameters.Add("@Volume_of_Distribution", SqlDbType.VarChar);
                              drugCmd.Parameters.Add("@Clearance", SqlDbType.VarChar);
                  
                              idCmd = new SqlCommand(INSERT_DRUG_ID, conn);
                              idCmd.Parameters.Add("@ID", SqlDbType.VarChar, 256);
                              idCmd.Parameters.Add("@ALT_ID", SqlDbType.VarChar, 20);
                  
                              articleCmd = new SqlCommand(INSERT_DRUG_ARTICLE, conn);
                  
                              articleCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              articleCmd.Parameters.Add("@Pubmed_ID", SqlDbType.VarChar, 256);
                              articleCmd.Parameters.Add("@Citation", SqlDbType.VarChar, 20);
                  
                              linkCmd = new SqlCommand(INSERT_DRUG_LINK, conn);
                              linkCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              linkCmd.Parameters.Add("@Title", SqlDbType.VarChar, 256);
                              linkCmd.Parameters.Add("@URL", SqlDbType.VarChar, 64);
                  
                              interactionCmd = new SqlCommand(INSERT_DRUG_INTERACTION, conn);
                  
                              interactionCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              interactionCmd.Parameters.Add("@Interaction_ID", SqlDbType.VarChar, 20);
                              interactionCmd.Parameters.Add("@Description", SqlDbType.VarChar, 256);
                  
                              productCmd = new SqlCommand(INSERT_DRUG_PRODUCT, conn);
                  
                              productCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              productCmd.Parameters.Add("@Name", SqlDbType.VarChar, 128);
                              productCmd.Parameters.Add("@Labeller", SqlDbType.VarChar, 64);
                              productCmd.Parameters.Add("@NDC_ID", SqlDbType.VarChar, 20);
                              productCmd.Parameters.Add("@NDC_Product_Code", SqlDbType.VarChar, 20);
                              productCmd.Parameters.Add("@DPD_ID", SqlDbType.VarChar, 20);
                              productCmd.Parameters.Add("@EMA_Product_Code", SqlDbType.VarChar, 20);
                              productCmd.Parameters.Add("@EMA_MA_Number", SqlDbType.VarChar, 20);
                              productCmd.Parameters.Add("@Started_Marketing_On", SqlDbType.DateTime2, 20);
                              productCmd.Parameters.Add("@Ended_Marketing_On", SqlDbType.DateTime2, 20);
                              productCmd.Parameters.Add("@Dosage_Form", SqlDbType.VarChar, 64);
                              productCmd.Parameters.Add("@Strength", SqlDbType.VarChar, 20);
                              productCmd.Parameters.Add("@Route", SqlDbType.VarChar, 20);
                              productCmd.Parameters.Add("@FDA_Application_Number", SqlDbType.VarChar, 20);
                              productCmd.Parameters.Add("@Generic", SqlDbType.Bit);
                              productCmd.Parameters.Add("@Over_the_Counter", SqlDbType.Bit);
                              productCmd.Parameters.Add("@Approved", SqlDbType.Bit);
                              productCmd.Parameters.Add("@Country", SqlDbType.VarChar, 20);
                              productCmd.Parameters.Add("@Source", SqlDbType.VarChar, 20);
                  
                  
                              mixtureCmd = new SqlCommand(INSERT_DRUG_MIXTURE, conn);
                  
                              mixtureCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              mixtureCmd.Parameters.Add("@Name", SqlDbType.VarChar, 64);
                              mixtureCmd.Parameters.Add("@Ingredients", SqlDbType.VarChar, 64);
                  
                              packagerCmd = new SqlCommand(INSERT_DRUG_PACKAGER, conn);
                  
                              packagerCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              packagerCmd.Parameters.Add("@Name", SqlDbType.VarChar, 64);
                              packagerCmd.Parameters.Add("@URL", SqlDbType.VarChar, 64);
                  
                  
                              priceCmd = new SqlCommand(INSERT_DRUG_PRICE, conn);
                  
                              priceCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              priceCmd.Parameters.Add("@Description", SqlDbType.VarChar, 128);
                              priceCmd.Parameters.Add("@Cost", SqlDbType.Decimal);
                              priceCmd.Parameters.Add("@Currency", SqlDbType.VarChar,20);
                              priceCmd.Parameters.Add("@Unit", SqlDbType.VarChar, 20);
                  
                  
                              categoryCmd = new SqlCommand(INSERT_DRUG_CATEGORY, conn);
                  
                              categoryCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              categoryCmd.Parameters.Add("@Category", SqlDbType.VarChar, 128);
                              categoryCmd.Parameters.Add("@Mesh_ID", SqlDbType.VarChar, 20);
                  
                              organismCmd = new SqlCommand(INSERT_DRUG_ORGANISM, conn);
                  
                              organismCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              organismCmd.Parameters.Add("@Organism", SqlDbType.VarChar, 128);
                  
                              patentCmd = new SqlCommand(INSERT_DRUG_PATENT, conn);
                  
                              patentCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              patentCmd.Parameters.Add("@Number", SqlDbType.VarChar, 20);
                              patentCmd.Parameters.Add("@Country", SqlDbType.VarChar, 20);
                              patentCmd.Parameters.Add("@Approved", SqlDbType.DateTime2);
                              patentCmd.Parameters.Add("@Expires", SqlDbType.DateTime2);
                              patentCmd.Parameters.Add("@Pediatric_Extension", SqlDbType.Bit);
                  
                              sequenceCmd = new SqlCommand(INSERT_DRUG_SEQUENCE, conn);
                  
                              sequenceCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              sequenceCmd.Parameters.Add("@Format", SqlDbType.VarChar, 20);
                              sequenceCmd.Parameters.Add("@Sequence", SqlDbType.VarChar);
                              sequenceCmd.Parameters.Add("@Type", SqlDbType.VarChar, 20);
                  
                              propertyCmd = new SqlCommand(INSERT_DRUG_PROPERTY, conn);
                  
                              propertyCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              propertyCmd.Parameters.Add("@Kind", SqlDbType.VarChar, 20);
                              propertyCmd.Parameters.Add("@Value", SqlDbType.VarChar, 20);
                              propertyCmd.Parameters.Add("@Source", SqlDbType.VarChar, 20);
                  
                              identifierCmd = new SqlCommand(INSERT_DRUG_IDENTIFIER, conn);
                  
                              identifierCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              identifierCmd.Parameters.Add("@Resource", SqlDbType.VarChar, 64);
                              identifierCmd.Parameters.Add("@Identifier", SqlDbType.VarChar, 64);
                  
                              enzymCmd = new SqlCommand(INSERT_DRUG_ENZYM, conn);
                  
                              enzymCmd.Parameters.Add("@ID", SqlDbType.VarChar, 20);
                              enzymCmd.Parameters.Add("@UniprotID", SqlDbType.VarChar, 20);
                  
                              XmlReader reader = XmlReader.Create(filename);
                              while (!reader.EOF)
                              {
                                  if (reader.Name != "drug")
                                  {
                                      reader.ReadToFollowing("drug");
                                  }
                                  if (!reader.EOF)
                                  {
                                      XElement drug = (XElement)XElement.ReadFrom(reader);
                                      string primaryID = (string)drug.Elements().Where(x => (x.Name.LocalName == "drugbank-id") && (x.Attribute("primary") != null)).FirstOrDefault();
                  
                                      AddDrug(conn, drug, primaryID);
                                      AddArticles(conn, drug, primaryID);
                                      AddInteractions(conn, drug, primaryID);
                                      AddProducts(conn, drug, primaryID);
                                      AddMixtures(conn, drug, primaryID);
                                      AddPackagers(conn, drug, primaryID);
                                      AddPrices(conn, drug, primaryID);
                                      AddCategories(conn, drug, primaryID);
                                      AddOrganisms(conn, drug, primaryID);
                                      AddPatents(conn, drug, primaryID);
                                      AddSequences(conn, drug, primaryID);
                                      AddProperties(conn, drug, primaryID);
                                      AddIdentifiers(conn, drug, primaryID);
                                      AddEnzymes(conn, drug, primaryID);
                                  }
                              }
                  
                          }
                  

                  這篇關于通過非制表符分隔符的非結構化 XML?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

                  【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

                  相關文檔推薦

                  What are good algorithms for vehicle license plate detection?(車牌檢測有哪些好的算法?)
                  onClick event for Image in Unity(Unity中圖像的onClick事件)
                  Running Total C#(運行總 C#)
                  Deleting a directory when clicked on a hyperlink with JAvascript.ASP.NET C#(單擊帶有 JAvascript.ASP.NET C# 的超鏈接時刪除目錄)
                  asp.net listview highlight row on click(asp.net listview 在單擊時突出顯示行)
                  Calling A Button OnClick from a function(從函數調用按鈕 OnClick)
                2. <tfoot id='81bgc'></tfoot>
                      • <bdo id='81bgc'></bdo><ul id='81bgc'></ul>
                        <legend id='81bgc'><style id='81bgc'><dir id='81bgc'><q id='81bgc'></q></dir></style></legend>

                            <tbody id='81bgc'></tbody>

                          <small id='81bgc'></small><noframes id='81bgc'>

                            <i id='81bgc'><tr id='81bgc'><dt id='81bgc'><q id='81bgc'><span id='81bgc'><b id='81bgc'><form id='81bgc'><ins id='81bgc'></ins><ul id='81bgc'></ul><sub id='81bgc'></sub></form><legend id='81bgc'></legend><bdo id='81bgc'><pre id='81bgc'><center id='81bgc'></center></pre></bdo></b><th id='81bgc'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='81bgc'><tfoot id='81bgc'></tfoot><dl id='81bgc'><fieldset id='81bgc'></fieldset></dl></div>
                            主站蜘蛛池模板: 国产高清免费在线 | aⅴ色国产 欧美 | www.三级 | 免费观看一级毛片 | 精品成人 | 色先锋影音 | 成人精品一区二区三区 | 天天在线操 | 日本偷偷操| 噜噜噜色网 | 国产十日韩十欧美 | 日本久久久一区二区三区 | 天天爽夜夜骑 | 国产精品1区 | 成人欧美一区二区三区色青冈 | 亚洲精品一区二区二区 | 国产精品无码永久免费888 | 午夜av电影院 | 午夜影院在线免费观看视频 | 蜜臀久久99精品久久久久久宅男 | 久久综合久久久 | 日本激情视频中文字幕 | 91精品在线播放 | 玖玖色在线视频 | 精品国产欧美一区二区 | 国产精品久久久亚洲 | 日韩在线观看一区 | 欧美成人a | 狠狠操狠狠干 | 久久综合一区 | 玖玖视频网 | 麻豆a级片 | av激情在线 | 粉嫩粉嫩芽的虎白女18在线视频 | 国产高清在线 | www.蜜桃av.com| 91精品国产综合久久婷婷香蕉 | 91精品国产综合久久久久久漫画 | 亚洲日本视频 | a级黄色网 | 亚洲精品电影网在线观看 |