SQLite使用事务更新—by command

 public void SaveToDB(DataTable dt)
        {

            /* todo:sqlite没有提供批量插入的机制,需要通过事务处理 更新所有数据
             * http://www.cnblogs.com/hbjohnsan/p/4169612.html
             * Eorr 数据库加了锁,执行不了自己的代码。
             */
        
            string connStr = @"data source=E:\YQSQLite\YQSQLite\Data\YQ.db";
            using (SQLiteConnection conn = new SQLiteConnection(connStr))
            {
                conn.Open();
                using (System.Data.SQLite.SQLiteTransaction trans = conn.BeginTransaction())
                {
                    using (System.Data.SQLite.SQLiteCommand cmd = new SQLiteCommand(conn))
                    {
                        cmd.Transaction = trans;
                        try
                        {
                            foreach (DataRow dr in dt.Rows)
                            {
                                cmd.CommandText = @"insert or ignore into RssItem() values ("+Int32.Parse(dr[0].ToString()) +",'"
                                    +dr[1].ToString()+"','"+dr[2].ToString()+"','"
                                    + dr[3].ToString() + "','" + DateTime.Parse(dr[4].ToString()) + "','"
                                    +dr[5].ToString()+"','"+dr[6].ToString()+"')";
                                cmd.ExecuteNonQuery();

                            }
                            trans.Commit();
                        }
                        catch (Exception ex)
                        {
                            MessageBox.Show(ex.Message);
                            trans.Rollback();

                        }
                    }
                }
            }
            
           
           
            
        }

  

posted @ 2015-11-22 08:00  C#&SQL  阅读(774)  评论(0编辑  收藏  举报