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

首頁 > 數據庫 > SQLite > 正文

SQLite數據庫操作速度和性能評測

2024-09-07 00:10:05
字體:
來源:轉載
供稿:網友
SQLite 作為一個輕量級嵌入式數據庫,還是非常好用的。雨痕極力推薦~~~~~~ 

今天有個朋友測試 SQLite,然后得出的結論是:SQLite 效率太低,批量插入1000條記錄,居然耗時 2 分鐘!
下面是他發給我的測試代碼。我暈~~~~~~ 
using System.Data;
using System.Data.Common;
using System.Data.SQLite;

// 創建數據庫文件
File.Delete("test1.db3");
SQLiteConnection.CreateFile("test1.db3");

DbProviderFactory factory = SQLiteFactory.Instance;
using (DbConnection conn = factory.CreateConnection())
{
  // 連接數據庫
  conn.ConnectionString = "Data Source=test1.db3";
  conn.Open();

  // 創建數據表
  string sql = "create table [test1] ([id] INTEGER PRIMARY KEY, [s] TEXT COLLATE NOCASE)";
  DbCommand cmd = conn.CreateCommand();
  cmd.Connection = conn;
  cmd.CommandText = sql;
  cmd.ExecuteNonQuery();

  // 添加參數
  cmd.Parameters.Add(cmd.CreateParameter());
  
  // 開始計時
  Stopwatch watch = new Stopwatch();
  watch.Start();
  
  // 連續插入1000條記錄
  for (int i = 0; i < 1000; i++)
  {
    cmd.CommandText = "insert into [test1] ([s]) values (?)";
    cmd.Parameters[0].Value = i.ToString();

    cmd.ExecuteNonQuery();
  }

  // 停止計時
  watch.Stop();
  Console.WriteLine(watch.Elapsed);
}

哎~~~~ 一個常識性的錯誤,我加幾行代碼 (新增代碼標記 "// <-------------------")。
using System.Data;
using System.Data.Common;
using System.Data.SQLite;

// 創建數據庫文件
File.Delete("test1.db3");
SQLiteConnection.CreateFile("test1.db3");

DbProviderFactory factory = SQLiteFactory.Instance;
using (DbConnection conn = factory.CreateConnection())
{
  // 連接數據庫
  conn.ConnectionString = "Data Source=test1.db3";
  conn.Open();

  // 創建數據表
  string sql = "create table [test1] ([id] INTEGER PRIMARY KEY, [s] TEXT COLLATE NOCASE)";
  DbCommand cmd = conn.CreateCommand();
  cmd.Connection = conn;
  cmd.CommandText = sql;
  cmd.ExecuteNonQuery();

  // 添加參數
  cmd.Parameters.Add(cmd.CreateParameter());
  
  // 開始計時
  Stopwatch watch = new Stopwatch();
  watch.Start();
  
  DbTransaction trans = conn.BeginTransaction(); // <-------------------
  try
  {
    // 連續插入1000條記錄
    for (int i = 0; i < 1000; i++)
    {
      cmd.CommandText = "insert into [test1] ([s]) values (?)";
      cmd.Parameters[0].Value = i.ToString();

      cmd.ExecuteNonQuery();
    }

    trans.Commit(); // <-------------------
  }
  catch
  {
    trans.Rollback(); // <-------------------
    throw; // <-------------------
  }

  // 停止計時
  watch.Stop();
  Console.WriteLine(watch.Elapsed);
}

執行一下,耗時 0.2 秒。這差距是不是太大了點? 

為什么只是簡單啟用了一個事務會有這么大的差距呢?很簡單,SQLite 缺省為每個操作啟動一個事務,那么原代碼 1000 次插入起碼開啟了 1000 個事務,"事務開啟 + SQL 執行 + 事務關閉" 自然耗費了大量的時間,這也是后面顯示啟動事務后為什么如此快的原因。其實這是數據庫操作的基本常識,大家要緊記,不好的代碼效率差的不是一點半點。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91久久精品在线| 久久久久北条麻妃免费看| 黑人极品videos精品欧美裸| 亚洲va男人天堂| 亚洲va欧美va在线观看| 久久精品免费电影| 中文字幕精品在线视频| 亚洲天堂av图片| 久热在线中文字幕色999舞| 懂色aⅴ精品一区二区三区蜜月| 亚洲天堂网站在线观看视频| 91精品国产综合久久香蕉922| 亚洲电影免费观看高清完整版| 富二代精品短视频| 亚洲free性xxxx护士hd| 成人福利网站在线观看11| 亚洲新中文字幕| 欧美性xxxx在线播放| 国精产品一区一区三区有限在线| 7m第一福利500精品视频| 欧美视频一区二区三区…| 色青青草原桃花久久综合| 国产视频精品xxxx| 亚洲精品午夜精品| 国产成人午夜视频网址| 日韩免费在线免费观看| 欧美精品成人91久久久久久久| 欧美午夜精品伦理| 中文字幕亚洲图片| 国产日本欧美一区二区三区在线| 91精品国产高清自在线看超| 91禁国产网站| 日韩欧美在线网址| 亚洲精品ady| 中文字幕欧美日韩在线| 97精品国产91久久久久久| 9.1国产丝袜在线观看| 欧美成人午夜激情在线| 蜜臀久久99精品久久久无需会员| 78m国产成人精品视频| 日韩在线欧美在线国产在线| 欧美日韩一区二区在线| 国产精品va在线播放我和闺蜜| 欧美激情手机在线视频| 日韩av在线免费| 一本一本久久a久久精品牛牛影视| 中文字幕免费精品一区| 57pao国产精品一区| 欧美精品在线播放| 正在播放欧美视频| 欧美激情xxxx性bbbb| 欧美日韩中文在线观看| 日韩美女福利视频| 精品国内自产拍在线观看| 久久久久久网站| 欧美一区二粉嫩精品国产一线天| 亚洲国产精品久久久久| 欧美性猛交xxxxx水多| 久久国内精品一国内精品| 日韩一区二区在线视频| 日韩av在线网站| 九九久久久久久久久激情| 亚洲在线观看视频网站| 欧美日韩另类视频| 午夜伦理精品一区| 欧美刺激性大交免费视频| 日韩av免费观影| y97精品国产97久久久久久| 成人写真视频福利网| 91大神福利视频在线| 久热精品在线视频| 欧美亚洲国产视频| 日韩美女在线看| 国产亚洲精品一区二区| 欧美黄网免费在线观看| 欧美激情18p| 欧美电影免费观看电视剧大全| 91国产高清在线| 毛片精品免费在线观看| 中文字幕久久久| 国产精品一久久香蕉国产线看观看| 亚洲国产成人爱av在线播放| 亚洲性xxxx| 欧美性xxxx18| 91免费人成网站在线观看18| 久久亚洲精品视频| 亚洲一区二区三区乱码aⅴ| 欧美日在线观看| 久久久久国产精品免费网站| 日韩美女激情视频| 国产成人高潮免费观看精品| 精品国产欧美成人夜夜嗨| 日韩中文字幕免费| 久久久久久中文字幕| 亚洲精品一区二区三区婷婷月| 亚洲电影免费观看高清完整版| 日韩欧美一区二区三区久久| 色诱女教师一区二区三区| 国产精品1区2区在线观看| 亚洲精品98久久久久久中文字幕| www.久久撸.com| 精品无码久久久久久国产| 国内精品久久久久影院优| 国产精品久久一| 亚洲一区久久久| 亚洲国产91色在线| 欧美性xxxx极品hd满灌| 日本久久91av| 日韩精品在线看| 韩国三级电影久久久久久| 亚洲一级黄色av| 国产欧洲精品视频| 精品视频偷偷看在线观看| 青青草一区二区| 自拍偷拍亚洲精品| 国产免费成人av| 国产69久久精品成人看| 不卡在线观看电视剧完整版| 国产日韩欧美影视| 欧美成人在线影院| 国产精品www网站| 色噜噜国产精品视频一区二区| 亚洲国产精品系列| 在线观看欧美日韩| 欧美激情视频播放| 性欧美xxxx视频在线观看| 日本韩国欧美精品大片卡二| 亚洲精选中文字幕| www.久久草.com| 国产综合在线视频| 一级做a爰片久久毛片美女图片| 日韩一级裸体免费视频| 欧美黄色性视频| 亚洲欧美精品在线| 亚洲aⅴ男人的天堂在线观看| 国产欧美最新羞羞视频在线观看| 国产视频自拍一区| 精品亚洲aⅴ在线观看| 精品人伦一区二区三区蜜桃免费| 久久久女人电视剧免费播放下载| 亚洲永久在线观看| 欧美日韩日本国产| 欧美做受高潮电影o| 亚洲国产另类久久精品| 青青草原成人在线视频| 国产精品丝袜久久久久久高清| 成人黄色av网| 日本19禁啪啪免费观看www| 欧美激情三级免费| 欧美片一区二区三区| 国产精品欧美日韩一区二区| 中文字幕日韩在线观看| 国产精品白嫩美女在线观看| 亚洲成人激情视频| 国产精品爱久久久久久久| 欧美精品videos性欧美| 国产精品444| 久久久av亚洲男天堂| 欧美一级大片在线观看| 国产va免费精品高清在线| 26uuu另类亚洲欧美日本一| 深夜精品寂寞黄网站在线观看| 国产一区二区三区久久精品| 最新69国产成人精品视频免费|