我之前用的是SQL server數據庫,但是客戶那里覺得安裝這個大的數據庫比較卡,說是導致藍屏了,硬往SQL server上賴,沒有辦法客戶是上帝么,給他換個小點的數據庫吧!考慮Access,不行這個還是得安裝客戶端,必須找一個免安裝的。最后終於找到了SQLite,不用安裝客戶端,只需要一個文件就行,在本地新建一個文本文件,改后綴名為.db,用SQLite studio軟件打開這個.db文件。但是我之前數據是用SQL server做的,這就需要把數據從SQL server轉換成SQLite,
這是時候需要用到的一個SQL server To SQLite DB Convert這個工具,可以去百度搜下找到它,是一個開源的老外寫的軟件,很不錯,轉換很快就完成。轉換的時候需要注意下: 如果SQL server表中數據后面經常會有空格,這個時候要在SQLite studio中把后面的空格去掉,要不查詢不出來數據。
轉換完成后生成一個.db文件,然后用SQLite Studio打開,就可以了,非常簡單。然后在代碼中把sqldataadapter這種sql的前綴統統換成SQLite就可以了,SQL server數據庫操作的那幾個對象,在SQLite中都有,只是名字前綴不一樣,從Sql換成了SQlite,所以很簡單的辦法修改之前的ADO.NET對象的辦法是全工程替換,將Sql替換為SQLite。
string connectionString = "Data Source =" + Environment.CurrentDirectory + @"\Test.db";
conn = new SQLiteConnection(connectionString);
我自己測試了一下,查詢7個表,聯合查詢一共有700多萬條數據,SQLite studio中只需要用0.002秒,但是SqlServer卻需要用2分半的時間,所以嘛SQLite還是很不錯的一個數據庫。
還有一個事情就是數據安全沒有做,放到本地的.DB,別人可以直接訪問的,貌似是,所以感覺很不安全,接下來去研究研究數據文件加密的方法。