簡體   English   中英

如何從XML讀取特定字段並加載到Oracle db中

[英]How to read specific fields from XML and load into Oracle db

我的XML:

- <resources start="0" count="188">-
- <resource classname="Quote">
   <field name="name">USD/GEL</field> 
   <field name="price">2.418900</field> 
   <field name="symbol">GEL=X</field> 
   <field name="ts">1488758461</field> 
   <field name="type">currency</field> 
   <field name="utctime">2017-03-06T00:01:01+0000</field> 
   <field name="volume">0</field> 
   </resource>-  
   </resources>

C#代碼:

 var xmlNodes = xElement.Descendants("resource")
            .Select(e => new
            {

                ConvertFrom = e.Attribute("symbol").Value,

                ConvRate = e.Attribute("price").Value,

                ConvDate = e.Attribute("utctime").Value
            });

我嘗試上面的代碼來獲取並加載到oracle但我收到了以下錯誤。

System.Linq.Enumerable + WhereSelectEnumerableIterator 2[System.Xml.Linq.XElement,<>f__AnonymousType0 3 [System.String,System.String,System.String]]

請幫我解決這個問題。

我認為你誤解了Attribute方法, Attribute的名稱是namesymbol是值,所以你的查詢可能是這樣的:

var xmlNodes = xElement.Descendants("resource")
                       .Select(e => new
                                    {

                                      ConvertFrom = (string)e.Elements().FistOrDefault(r=>r.Attribute("name").Value=="symbol"),
                                      ConvRate = (string)e.Elements().FistOrDefault(r=>r.Attribute("name").Value=="price"),
                                      ConvDate = (DateTime)e.Elements().FistOrDefault(r=>r.Attribute("name").Value=="utctime"),
                                     });

暫無
暫無

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

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