亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

我也來學著寫寫WINDOWS服務-解析xml抓取數據并插入數據庫

2019-11-17 02:21:43
字體:
來源:轉載
供稿:網友

我也來學著寫寫WINDOWS服務-解析xml抓取數據并插入數據庫

項目告一段落,快到一年時間開發了兩個系統,一個客戶已經在試用,一個進入客戶測試階段,中間突然被項目經理(更喜歡叫他W工)分派一個每隔兩小時用windows服務去抓取客戶提供的外網xml,解析該xml,然后將截取的節點字段值插入到已經建好相應結構的表中。并記錄日志。

xml結構概要如下:

<?xml version="1.0" encoding="UTF-8"?><list>  <info>    <id>93ef7c7cccd2ecb13ed01dd6e30020b4136</id>    <title>剔骨刀一握六年練過硬本領 女庖丁解牛割肉有拿手好戲</title>    <posttime class="sql-timestamp">2015-05-25 06:38:20.0</posttime>    <institution>浙江省物價局</institution>    <url>http://dsb.66wz.com/html/2015-05/25/content_1822593.htm</url>    <webName>溫州都市報數字版</webName>    <infotype>新聞</infotype>    <summary>內容</summary>    <fl>其他類</fl>  </info>  <info>    ...  </info>  <info>    ...  </info>。。。</list>

1.首先,讓我們新建一個解決方案,該解決方案中包含9個項目:

(1)由于需要操作的是Oracle數據庫系統,所以在MSDN上找了個Oracle數據操作類庫DatabaseLib和DatabaseLink直接拿來用,一個是數據庫連接類,一個是數據庫操作類,里面包含各種對數據庫的操作;

其中,DatabaseLink主要包括以下三個文件:

DbLink.cs

using%20System.Data;namespace%20DataBaseLink{%20%20%20%20///%20<summary>%20%20%20%20///%20DATA%20%20%20%20%20%20:2010-07-01%20%20%20%20///%20Author%20%20%20%20:虞健超(James.Yu)%20%20%20%20///%20Describe%20%20:數據庫連接對象%20%20%20%20///%20</summary>%20%20%20%20public%20class%20DbLink%20:%20IDbLink%20%20%20%20{%20%20%20%20%20%20%20%20public%20string%20ConnectionStr%20{%20get;%20set;%20}%20%20%20%20%20%20%20%20public%20DbLink(string%20connectStr)%20%20%20%20%20%20%20%20{%20%20%20%20%20%20%20%20%20%20%20%20ConnectionStr%20=%20connectStr;%20%20%20%20%20%20%20%20%20}#if%20MSSQL%20%20%20%20%20%20%20%20public%20IDbConnection%20CreateConnection()%20%20%20%20%20%20%20%20{%20%20%20%20%20%20%20%20%20%20%20%20return%20new%20System.Data.SqlClient.SqlConnection(ConnectionStr);%20%20%20%20%20%20%20%20}%20%20%20%20%20%20%20%20public%20IDataAdapter%20CreateAdapter(IDbCommand%20cmd)%20%20%20%20%20%20%20%20{%20%20%20%20%20%20%20%20%20%20%20%20return%20new%20System.Data.SqlClient.SqlDataAdapter((System.Data.SqlClient.SqlCommand)cmd);%20%20%20%20%20%20%20%20}#endif%20%20%20%20}}

IDbLink.cs

using%20System.Data;namespace%20DataBaseLink{%20%20%20%20///%20<summary>%20%20%20%20///%20DATA%20%20%20%20%20%20:2010-07-01%20%20%20%20///%20Author%20%20%20%20:虞健超(James.Yu)%20%20%20%20///%20Describe%20%20:連接創建對象借口%20%20%20%20///%20</summary>%20%20%20%20public%20interface%20IDbLink%20%20%20%20{%20%20%20%20%20%20%20%20///%20<summary>%20%20%20%20%20%20%20%20///%20連接字符串%20%20%20%20%20%20%20%20///%20</summary>%20%20%20%20%20%20%20%20string%20ConnectionStr%20{%20get;%20set;%20}%20%20%20%20%20%20%20%20///%20<summary>%20%20%20%20%20%20%20%20///%20創建連接%20%20%20%20%20%20%20%20///%20</summary>%20%20%20%20%20%20%20%20///%20<returns>連接</returns>%20%20%20%20%20%20%20%20IDbConnection%20CreateConnection();%20%20%20%20%20%20%20%20///%20<summary>%20%20%20%20%20%20%20%20///%20創建Adapter%20%20%20%20%20%20%20%20///%20</summary>%20%20%20%20%20%20%20%20///%20<param%20name="cmd">cmd</param>%20%20%20%20%20%20%20%20///%20<returns></returns>%20%20%20%20%20%20%20%20IDataAdapter%20CreateAdapter(IDbCommand%20cmd);%20%20%20%20}}

以及存儲過程映射類DBStore

public override unsafe int ExecuteNonQuery()        {            string[] ppOpoPrmRefCtx = null;            IntPtr[] pOpoPrmValCtx = null;            OracleParameter parameter;            int num7;            int num8;            IntPtr zero = IntPtr.Zero;            IntPtr opsSubscrCtx = IntPtr.Zero;            int isSubscrRegistered = 0;            OracleDependency dep = null;            int bQueryBasedNTFNRegistration = 0;            int bchgNTFNExcludeRowidInfo = 0;            long num4 = 0L;            int errCode = 0;            int prmCnt = 0;            bool flag = false;            int bFromPool = 0;            CmdTimeoutCtx state = null;            Timer timer = null;            if (OraTrace.m_TraceLevel != 0)            {                OraTrace.Trace(1, new string[] { " (ENTRY) OracleCommand::ExecuteNonQuery()/n" });            }            if (this.m_connection == null)            {                throw new InvalidOperationException();            }            if (this.m_cmdTxtModified && ((this.m_commandText == null) || (this.m_commandText.Length == 0)))            {                throw new InvalidOperationException(OpoErrResManager.GetErrorMesg(ErrRes.ODP_INVALID_VALUE, new string[] { "OracleCommand.CommandText" }));            }            if (this.m_xmlCommandType != OracleXmlCommandType.None)            {                if (OracleXmlCommandType.Query == this.m_xmlCommandType)                {                    this.ExecuteXmlQuery(false);                    return -1;                }                return this.ExecuteXmlSave();            }            this.CheckConStatus();            if (this.m_cmdTxtModified || (this.m_commandType == System.Data.CommandType.StoredProcedure))            {                if (this.m_commandType == System.Data.CommandType.Text)                {                    this.m_selectStmt = isSelectStatement(this.m_commandText);                    this.m_pooledCmdText = this.m_commandText;                }                else if (this.m_commandType == System.Data.CommandType.TableDirect)                {                    this.m_selectStmt = true;                    this.m_pooledCmdText = "Select * from " + this.m_commandText;                }                else if (this.m_commandType == System.Data.CommandType.StoredProcedure)                {                    this.BuildCommandText();                    this.m_selectStmt = false;                    this.m_utf8CmdText = null;                    this.m_addParam = true;                }                UTF8CommandText text = UTF8CommandText.m_pooler.Get(this.m_connection.m_internalConStr, this.m_pooledCmdText) as UTF8CommandText;                if ((text != null) && (text.m_utf8CmdText != IntPtr.Zero))                {                    this.m_utf8CmdText = text;                    this.m_addParam = this.m_utf8CmdText.m_addParam;                    this.m_parsed = this.m_utf8CmdText.m_parsed;                    bFromPool = 1;                }                if (!this.m_parsed && (this.m_commandType == System.Data.CommandType.Text))                {                    this.ParseCommandText();                }                this.m_cmdTxtModified = false;            }            if (this.m_bindByName && (this.m_commandType != System.Data.CommandType.StoredProcedure))            {                flag = true;            }            if (((this.m_NTFNReq != null) && this.m_NTFNAutoEnlist) && (!this.m_connection.m_contextConnection && (OracleNotificationRequest.s_idTable[this.m_NTFNReq.Id] != null)))            {                opsSubscrCtx = OracleNotificationRequest.PopulateChgNTFNSubscrCtx(this, this.m_addRowid, out dep);                if ((dep != null) && dep.m_bIsRegistered)                {                    isSubscrRegistered = 1;                }                if (dep != null)                {                    if (dep.m_OracleRowidInfo == OracleRowidInfo.Exclude)                    {
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲xxx视频| 91久久精品日日躁夜夜躁国产| 色婷婷综合久久久久中文字幕1| 亚洲精品98久久久久久中文字幕| 92福利视频午夜1000合集在线观看| 日韩国产欧美精品在线| 国产91精品视频在线观看| 国产一区二区三区18| 92国产精品视频| 国产91露脸中文字幕在线| 日韩成人在线电影网| 中文字幕亚洲综合久久| 欧美日韩国产限制| 欧美成人精品一区二区| 国产成人精品综合久久久| 久久精品中文字幕电影| 奇门遁甲1982国语版免费观看高清| 久久精品国产一区二区电影| 国产成人+综合亚洲+天堂| 美女扒开尿口让男人操亚洲视频网站| 亚洲天堂男人天堂女人天堂| 国产精品极品美女粉嫩高清在线| 亚洲欧美另类自拍| 亚洲精品国精品久久99热一| 欧美乱妇高清无乱码| www.国产一区| 国产91精品视频在线观看| 亚洲国产欧美在线成人app| 欧美电影免费看| 久久91超碰青草是什么| 久久久97精品| 国产日韩欧美日韩| 欧美日本高清一区| 欧美午夜丰满在线18影院| 国产日韩av在线播放| 北条麻妃一区二区三区中文字幕| 97在线日本国产| 久久精品青青大伊人av| 亚洲精品久久久久中文字幕二区| 日韩亚洲一区二区| 久久久亚洲国产天美传媒修理工| 国产精品美女久久久久av超清| 欧美日韩免费区域视频在线观看| 91综合免费在线| 精品在线小视频| 国产成人精品视频在线观看| 97成人精品区在线播放| 国产福利视频一区二区| 久久成人这里只有精品| 欧美性色视频在线| 欧美大尺度在线观看| 亚洲美女福利视频网站| 国产精品91免费在线| 亚洲精品乱码久久久久久金桔影视| 久久亚洲成人精品| 日韩视频第一页| 国产专区欧美专区| 欧美电影免费观看| 久久久久久中文| 国产精品嫩草影院一区二区| 亚洲精品网站在线播放gif| 国产欧美一区二区三区在线看| 粉嫩av一区二区三区免费野| 国产精品精品视频一区二区三区| 精品成人国产在线观看男人呻吟| 视频在线一区二区| 国产精品999| 伊人成人开心激情综合网| 日韩电影大全免费观看2023年上| 在线观看免费高清视频97| 亚洲一区二区中文| 2023亚洲男人天堂| 成人国内精品久久久久一区| 成人性教育视频在线观看| 中文字幕日韩欧美精品在线观看| 日韩中文视频免费在线观看| 欧美激情中文网| 亚洲欧美日本精品| 国产91精品久久久久久久| 中文字幕日韩精品在线观看| 欧美日韩国产一区二区三区| 亚洲日韩第一页| 日韩高清电影免费观看完整| 久久精品亚洲94久久精品| 91产国在线观看动作片喷水| 国外成人在线视频| 亚洲一区二区三区777| 亚洲美女激情视频| 亚洲最大福利视频网| 一区三区二区视频| 中文字幕少妇一区二区三区| 91精品国产综合久久香蕉最新版| 欧美一级高清免费播放| 庆余年2免费日韩剧观看大牛| 九色精品美女在线| 久久99久久99精品免观看粉嫩| 亚洲精品国产电影| 国产91露脸中文字幕在线| 国产97人人超碰caoprom| 亚洲最大的免费| 亚洲性线免费观看视频成熟| 日韩av在线网页| 日韩福利视频在线观看| 亚洲石原莉奈一区二区在线观看| 国产精品人成电影| 久久久国产精品亚洲一区| xvideos国产精品| zzijzzij亚洲日本成熟少妇| 亚洲精品一区二区三区不| 欧美疯狂性受xxxxx另类| 另类专区欧美制服同性| 久久综合久中文字幕青草| 国产97人人超碰caoprom| 综合国产在线视频| 人妖精品videosex性欧美| 欧美老少做受xxxx高潮| 国产综合香蕉五月婷在线| 夜夜嗨av一区二区三区四区| 欧美一区亚洲一区| 一区二区三区日韩在线| 亚洲第一av网站| 日韩av中文字幕在线| 欧洲日本亚洲国产区| 国产精品18久久久久久首页狼| 亚洲人成网站色ww在线| 2019中文字幕在线观看| 国自在线精品视频| 国产精品极品在线| 欧美性高潮床叫视频| 国产精品视频不卡| 超碰精品一区二区三区乱码| 国产精品第一页在线| 97超级碰碰碰| 亚洲成色777777女色窝| 97免费中文视频在线观看| 国产精品极品在线| 91色琪琪电影亚洲精品久久| 国外成人在线视频| 亚洲人免费视频| 91成人精品网站| 日韩最新中文字幕电影免费看| 欧美日韩美女在线观看| 韩曰欧美视频免费观看| 中文字幕一区二区精品| 国产精品高清在线| 亚洲国产99精品国自产| 精品久久久久人成| 不卡av日日日| 欧美日韩xxx| 国产精品白嫩美女在线观看| 亚洲福利小视频| 亚洲国产精品悠悠久久琪琪| 欧美天堂在线观看| 91国内精品久久| 日本19禁啪啪免费观看www| 欧美成人午夜剧场免费观看| 国产va免费精品高清在线观看| 欧美激情一级精品国产| 欧美国产日韩一区二区| 午夜精品久久17c| 欧洲日韩成人av| 日本久久91av| 97免费在线视频| 亚洲视频一区二区|