コード例 #1
0
        //
        // Add new news feeds in db
        //
        static public void updateSts(List <News_Source> newsdata)
        {
            var connection = SqliteHelper.DBContext("NewsRss_URL.db");

            using (connection)
            {
                connection.DefaultTimeout = 60;
                //If table not exist than create one
                connection.Open();
                var createTableCmd = connection.CreateCommand();
                createTableCmd.CommandText = String.Format(@"CREATE TABLE IF NOT EXISTS NewsRssURL(
                                                            news_Id INTEGER PRIMARY KEY,
                                                            LstMntDt NUMERIC,
                                                            title VARCHAR(255),
                                                            rssURL VARCHAR(100))"
                                                           );
                createTableCmd.ExecuteNonQuery();

                // Get Last update datetime from NewsRssRUL
                var selectCmd = connection.CreateCommand();
                selectCmd.CommandText = "SELECT * FROM NewsRssURL";
                List <News_Source> tempList = new List <News_Source>();
                RssReader          rss      = new RssReader();

                using (var reader = selectCmd.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        News_Source temp = new News_Source {
                            LstMntDt = reader["LstMntDt"].ToString(),
                            title    = reader["title"].ToString()
                        };
                        tempList.Add(temp);
                    }
                }

                newsdata.ForEach(o => {
                    using (var transaction = connection.BeginTransaction())
                    {
                        var LstMntDt_his = "1911-01-01 00:00";
                        var insertCmd    = connection.CreateCommand();
                        var deleteCmd    = connection.CreateCommand();
                        var titleOs_res  = YCLib.stringHandler(o.title);

                        tempList.ForEach(x => {
                            if (x.title == titleOs_res)
                            {
                                LstMntDt_his = x.LstMntDt;
                            }
                        });
                        // Require to update NewsRssRUL or not
                        if (DateTime.Compare(Convert.ToDateTime(o.LstMntDt), Convert.ToDateTime(LstMntDt_his)) > 0)
                        {
                            deleteCmd.CommandText = String.Format(@"DELETE FROM NewsRssURL WHERE title = '{0}'", titleOs_res);
                            deleteCmd.ExecuteNonQuery();

                            insertCmd.CommandText = String.Format(@"INSERT INTO NewsRssURL (LstMntDt , title, rssURL) VALUES('{0}', '{1}', '{2}')",
                                                                  o.LstMntDt, titleOs_res, o.rssURL);
                            insertCmd.ExecuteNonQuery();

                            try{
                                transaction.Commit();
                            }
                            catch (Exception ex) {
                                Console.WriteLine("{0}", ex.ToString());
                            }
                        }
                        ;
                    }
                });
            }
        }
コード例 #2
0
        //
        // Create News Feed Table and Insert Data
        //
        static public void post(List <News_Source> newsdata)
        {
            var connection = SqliteHelper.DBContext("NewsFeeds_Main.db");

            using (connection)
            {
                updateSts(newsdata);

                connection.Open();
                //Create a table (drop if already exists first):
                newsdata.ForEach(o => {
                    var titleOs_res = YCLib.stringHandler(o.title);

                    var createTableCmd         = connection.CreateCommand();
                    createTableCmd.CommandText = String.Format(@"CREATE TABLE IF NOT EXISTS {0}(
                                                                news_Id INTEGER PRIMARY KEY,
                                                                pubDt VARCHAR(100),
                                                                title VARCHAR(255),
                                                                summary VARCHAR(255),
                                                                url VARCHAR(255))"
                                                               , titleOs_res);
                    try{
                        createTableCmd.ExecuteNonQuery();
                    }
                    catch (Exception ex) {
                        Console.WriteLine("{0}", ex.ToString());
                    }
                    //Get Lst news date
                    var lstDt = getLstDt(o) == "" ? "1911-01-01 00:00" : getLstDt(o);
                    //Seed some data:
                    using (var transaction = connection.BeginTransaction())
                    {
                        var titleOs   = String.Empty;
                        var summaryOs = String.Empty;
                        var urlOs     = String.Empty;
                        var insertCmd = connection.CreateCommand();
                        var count     = 0;
                        o.newsList.ForEach(item => {
                            if (DateTime.Compare(Convert.ToDateTime(item.pubDate), Convert.ToDateTime(lstDt)) > 0)
                            {
                                titleOs               = item.title.Replace("'", "''");
                                summaryOs             = item.summary.Replace("'", "''");
                                urlOs                 = item.url.Replace("'", "''");
                                insertCmd.CommandText = String.Format(@"INSERT INTO {4} (pubDt , title, summary, url) VALUES('{0}', '{1}', '{2}', '{3}')",
                                                                      item.pubDate, titleOs, summaryOs, urlOs, titleOs_res);
                                insertCmd.ExecuteNonQuery();
                                count++;
                            }
                        });
                        try{
                            transaction.Commit();
                            if (count == 0)
                            {
                                Console.WriteLine("NOTICE: Nothing update - {0}.", titleOs_res);
                            }
                            else
                            {
                                Console.WriteLine("SUCCESS: Inserted {0} news in {1}.", count, titleOs_res);
                            }
                        }
                        catch (Exception ex) {
                            Console.WriteLine("{0}", ex.ToString());
                        }
                    }
                });
            }
        }