关于事务开启与否对数据库插入数据所需时间的影响的讨论
根据sqlite3的api,在后面测试的时候发现对于sqlite3来说事务的开启与否仅插入1w条数据,时间的差距就已经非常非常明显了,先说下
最近在做sqlite3的二次开发,看到API里面关于事务的时候,萌生了测试一下事务的开启与否对插入数据所需要的时间影响的想法,根据sqlite3的api,,在后面测试的时候发现对于sqlite3来说事务的开启与否仅插入1w条数据,时间的差距就已经非常非常明显了,先说下测试环境:Ubuntu 12.04, sqlite3 3.7.14.1,测试插入1w条数据。
不开启事务时的测试代码如下:
int insert_no_trans()
{
printf(" \n"
"go into function insert_no_trans()\n");
int j = 0;
for (j = 0; j {
sprintf(sql, "INSERT INTO [dev] ([id], [name], [age])\
values (%d, '%s', %d)", j, "JGood", j);
if(SQLITE_OK != sqlite3_exec
(conn, sql, 0, 0, &err_msg))
{
fprintf(stderr, "INSERT ERROR: %s\n", err_msg);
exit(EXIT_FAILURE);
}
}
printf("INSERT all succussfully!\n");
printf("function insert_no_trans() end. \n"
" \n");
return EXIT_SUCCESS;
}
开启事务的测试代码如下:
int insert_with_trans()
{
printf(" \n"
"go into function insert_with_trans()\n");
sqlite3_exec(conn, "begin;", 0, 0, 0); //开启事务
int j = 0;
for (j = 0; j {
sprintf(sql, "INSERT INTO [dev] ([id], [name], [age])\
values (%d, '%s', %d)", j, "JGood", j);
if(SQLITE_OK != sqlite3_exec(conn, sql, 0, 0, &err_msg))
{
is_succeed = false; //失败之后把标识设为false
fprintf(stderr, "INSERT ERROR: %s\n", err_msg);
break;
}
}
if(is_succeed)
sqlite3_exec(conn, "commit;", 0, 0, 0); //提交事务
else
{
sqlite3_exec(conn, "rollback;", 0, 0, 0); //回滚事务
exit(EXIT_FAILURE);
}
printf("INSERT all succussfully!\n");
printf("function insert_with_trans() end. \n"
" \n");
return EXIT_SUCCESS;
}
测试结果大跌眼镜,时间测试我用的是linux的time命令,在开启了事务的情况下插入1w条数据的时间仅为0.4s,而在不开启事务的情况下,由于时间太长,没有等其执行完,根据.db文件的大小和已经使用的时间推测,假设单位时间插入同样多条数据,推算出来的时间高达18分钟。这已经不在一个数量级了,google了一下这个问题,看到网上有人对此是这么解释的,如果未启用事务,sqlite会每插入一条数据,就往磁盘上面写一次,在整个执行过程中我也观察到未开启事务时程序执行期间硬盘灯一直是亮的,这也映证了这一点。而在开启事务的情况下,其应该是在对数据全部处理完之后才需要执行一次IO操作,时间自然非常快。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

如何在Phalcon框架中使用資料庫事務(Transactions)引言:資料庫事務是一種重要的機制,可以確保資料庫操作的原子性和一致性。在使用Phalcon框架進行開發時,我們也經常需要使用資料庫事務來處理一系列相關的資料庫操作。本文將介紹如何在Phalcon框架中使用資料庫事務,並提供相關的程式碼範例。一、什麼是資料庫事務(Transactions)?數據

隨著網路的快速發展,資料庫的重要性日益凸顯。身為Java開發者,我們經常涉及資料庫操作,資料庫事務處理的效率直接關係到整個系統的效能和穩定性。本文將介紹一些Java開發中常用的最佳化資料庫事務處理效率的技巧,幫助開發者提升系統的效能和回應速度。在批次插入/更新操作通常情況下,一次插入或更新單一記錄到資料庫的效率遠低於批次操作。因此,在進行批量插入/更

在Web開發中,資料庫事務處理是一個重要的問題。當程式需要操作多個資料庫表格時,確保資料一致性和完整性變得尤為重要。事務處理提供了一種方法來保證這些操作要么全部成功,要么全部失敗。 PHP作為一門流行的Web開發語言,也提供了事務處理的功能。本文將介紹使用PHP進行資料庫事務處理的最佳實務。什麼是資料庫事務?在資料庫中,事務是指一系列操作作為一個整體來執行的過

如何解決Java後端功能開發中的資料庫事務問題?在Java後端功能開發中,涉及資料庫操作的功能很常見。而在資料庫操作中,事務是一項非常重要的概念。事務是指由一系列資料庫操作組成的邏輯單元,它要麼完全執行,要麼完全不執行。在實際應用中,我們經常需要確保一組相關的資料庫操作要麼全部成功執行,要麼全部回滾,以保持資料的一致性和可靠性。那麼,如何在Java後端開發

C#開發中如何處理資料庫事務問題,需要具體程式碼範例引言:在C#開發中,資料庫事務的處理是非常重要的一項技術。透過事務的處理,我們可以確保資料庫操作的一致性和完整性,提高系統的穩定性和安全性。本文將介紹C#中如何處理資料庫事務問題,並給出具體的程式碼範例。一、資料庫事務簡介資料庫事務是對資料庫操作的一個邏輯單元,它可以由一個或多個操作組成。事務有四個基本屬性,

Java開發:如何使用JPA進行資料庫事務管理在Java開發中,資料庫事務管理是非常重要且常見的需求。 JPA(JavaPersistenceAPI)是JavaEE的一部分,它提供了一種方便的方式來進行資料庫操作。本文將介紹如何使用JPA進行資料庫事務管理,並提供具體的程式碼範例。首先,我們需要在專案中引入JPA相關的依賴。常見的JPA實作有Hibern

在PHP程式設計中,資料庫事務隔離等級是一個重要的概念。事務是資料庫管理和運作的基本單位,使得資料庫可以在一致性和完整性的基礎上進行有效且安全的操作。而事務隔離等級則是指多個事務間的相互影響程度。在PHP程式設計中,了解資料庫事務隔離等級的概念和對應的應用是必不可少的。在資料庫中,有四種交易隔離等級:未提交讀取(Readuncommitted)、已提交讀取(Read

ACID屬性包括原子性、一致性、隔離性和持久性,是數據庫設計的基石。 1.原子性確保事務要么完全成功,要么完全失敗。 2.一致性保證數據庫在事務前後保持一致狀態。 3.隔離性確保事務之間互不干擾。 4.持久性確保事務提交後數據永久保存。
