C#中使用SQLite數(shù)據(jù)庫的方法介紹
2024-09-07 17:05:24
供稿:網(wǎng)友
【SQLite管理工具簡(jiǎn)介】
推薦以下2款:
Navicat for SQLite:功能非常強(qiáng)大,幾乎包含了數(shù)據(jù)庫管理工具的所有必需功能,操作簡(jiǎn)單,容易上手。唯一的缺點(diǎn)是不能打開由System.Data.SQLite.dll加密過的數(shù)據(jù)庫。
Database.Net:臺(tái)灣人用.net開發(fā)的全能數(shù)據(jù)庫管理工具,可以管理多種數(shù)據(jù)庫,包括MSSQL、MYSQL、IBM DB2、Oracle、Access、Excel、OleDb、Odbc等十多種數(shù)據(jù)庫(或數(shù)據(jù)接口),功能沒有Navicat那么多,只包含最基本功能。對(duì)SQLite而言,Database.Net最大的優(yōu)點(diǎn)是支持打開由System.Data.SQLite.dll加密過的數(shù)據(jù)庫,且可以隨時(shí)對(duì)數(shù)據(jù)庫設(shè)置密碼,是.net下開發(fā)SQLite必備的小工具。下載地址:http://fishcodelib.com/Database.htm 錯(cuò)新站長(zhǎng)站下載地址 //www.49028c.com/database/41238.html
建議以Navicat for SQLite為主,Database.Net為輔,只要涉及到數(shù)據(jù)庫加密時(shí)才用后者。
【操作SQLite實(shí)例】
操作SQlite的方法基本同其他數(shù)據(jù)庫相同,但有一些區(qū)別:
『例1』整數(shù)似乎都是Int64的。
查詢出網(wǎng)站App_Data目錄下“省市.db”數(shù)據(jù)庫中city表的總記錄數(shù)
代碼如下:
SQLiteConnection cn = new SQLiteConnection("Data Source=|DataDirectory|省市.db;Version=3");
SQLiteCommand cmd = new SQLiteCommand("select count(*) from city", cn);
cn.Open();
int recordCount = (int)(Int64)cmd.ExecuteScalar();
cn.Close();
Response.Write(recordCount);
SQLite中count函數(shù)返回的是一個(gè)Int64的整數(shù),這一點(diǎn)同MSSQL、Access等不同。實(shí)際上,經(jīng)過有限的使用發(fā)現(xiàn),似乎所有INTEGER字段的返回值都是Int64,這一點(diǎn)未經(jīng)過有效證實(shí)。ExecuteScalar方法返回一個(gè)object實(shí)例,按照C#規(guī)定,拆箱時(shí)進(jìn)行標(biāo)準(zhǔn)轉(zhuǎn)換,必須轉(zhuǎn)換成該object實(shí)例實(shí)際存儲(chǔ)的格式,因此分兩步,先轉(zhuǎn)換成Int64,再轉(zhuǎn)換成int。當(dāng)然用.net中某些高級(jí)轉(zhuǎn)換器如Convert.ToInt32方法只要一步就可以了。
『例2』批量增刪改時(shí)需要用事務(wù),否則效率很低。
批量插入1000條記錄,每條記錄只有簡(jiǎn)單的id、name、password三個(gè)字段:
代碼如下:
SQLiteConnection cn = new SQLiteConnection("Data Source=c://測(cè)試.db3;Version=3;password=12345");
SQLiteCommand cmd = new SQLiteCommand("select count(*) from test", cn);
cn.Open();
int recordCount = (int)(Int64)cmd.ExecuteScalar();
Response.Write("當(dāng)前的總記錄數(shù):" + recordCount + "<br/>");
for (int i = 0; i < 1000; i++)
{
cmd.CommandText = "insert into test values(@id,@name,@password)";
cmd.Parameters.AddWithValue("@id", i);
cmd.Parameters.AddWithValue("@name", "姓名" + i);
cmd.Parameters.AddWithValue("@password", (i * 2).ToString());
cmd.ExecuteNonQuery();
}
cmd.CommandText = "select count(*) from test";
recordCount = (int)(Int64)cmd.ExecuteScalar();
cn.Close();
Response.Write("當(dāng)前的總記錄數(shù):" + recordCount + "<br/>");
經(jīng)過測(cè)試,這段代碼中的for循環(huán)花費(fèi)了70000~90000毫秒,一分鐘多!