一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

C#——SQLite速成

 昵稱11482448 2013-04-11
為什么我需要SQLite

* 輕巧靈活,基于單個數(shù)據(jù)庫文件,方便創(chuàng)建、移動,能方便的進行數(shù)據(jù)的分類存儲(按業(yè)務、按功能、按日期、按客戶等),非常適合與靈活的系統(tǒng)搭配使用。

* 部署容易,.NET環(huán)境只需一個dll文件(Access可能需要安裝MDAC)

* 開源。

 

SQLite開發(fā)環(huán)境與開發(fā)資料的準備

.Net SQLite數(shù)據(jù)庫驅動:System.Data.SQLite.dll以及文檔

SQLite GUI數(shù)據(jù)庫工具:SQLite Expert PersonalEdition個人版免費,夠用了

.Net SQLite數(shù)據(jù)庫驅動源碼:sqlite-netFx-source-1.0.76.0

 

C#動態(tài)創(chuàng)建SQLite數(shù)據(jù)庫

調用SQLiteConnection. CreateFile靜態(tài)方法創(chuàng)建

SQLiteConnection.CreateFile(path)

 

path測試路徑:Data目錄存在,Data2目錄不存在

                var path1 = "dummy1.db";//成功

                var path2 = "Data/dummy2.db";//成功

                var path3 = "Data\\dummy3.db";//成功

                var path4 = "c:\\Data\\dummy4.db";//成功

                var path5 = "Data2//dummy5.db";//錯誤,Data2目錄不存在

           var path6 = "C:\\Data2\\dummy6.db";//錯誤,Data2目錄不存在

 

SQLiteConnection. CreateFile內部的實現(xiàn)源碼:使用了File.Create創(chuàng)建0字節(jié)文件

    /// <summary>

    /// Creates a database file.  This just creates a zero-byte file whichSQLite

    /// will turn into a database when the file is openedproperly.

    /// </summary>

    /// <paramname="databaseFileName">Thefile to create</param>

    static public void CreateFile(string databaseFileName)

    {

      FileStream fs = File.Create(databaseFileName);

      fs.Close();

    }

 

C#連接SQLite與數(shù)據(jù)庫安全

常用的連接字符串生成

                /// <summary>

                /// 生成SQLite連接字符串

                /// </summary>

                public static class SQLiteConnectionString

                {

                                public static string GetConnectionString(stringpath)

                                {

                                                return GetConnectionString(path,null);

                                }

                                public static string GetConnectionString(stringpath, string password)

                                {

                                                if (string.IsNullOrEmpty(password))

                                                                return "Data Source=" + path;

                                                return "Data Source=" + path + ";Password=" + password;

                                }

                }

修改數(shù)據(jù)庫密碼

                /// <summary>

                /// 修改密碼

                /// </summary>

                /// <paramname="path"></param>

                /// <param name="newPassword"></param>

                /// <param name="oldPassword">沒有密碼時為空</param>

                public static boolChangePassword(stringpath, string newPassword,string oldPassword = null)

                {

                                try

                                {

                                                varcon = new SQLiteConnection(SQLiteConnectionString.GetConnectionString(path, oldPassword));

                                                con.Open();

                                                con.ChangePassword(newPassword);

                                                con.Close();

                                }

                                catch (Exception ex)

                                {

                                                return false;

                                }

                                return true;

                }

 

修改密碼測試:

                var path2 = "Data/dummy2.db";//數(shù)據(jù)庫初始密碼是空值

                ChangePassword(path2, "123");//成功,數(shù)據(jù)庫密碼修改為123

                ChangePassword(path2, "234","");//錯誤,當前密碼是123

                ChangePassword(path2, "234","123");//成功,數(shù)據(jù)庫密碼修改為123

                ChangePassword(path2, "","234");//成功,數(shù)據(jù)庫密碼修改為空

 

C#常用類型與SQLite類型的映射

C#類型

SQLite類型

int

INT, INTEGER

string

CHAR, VARCHAR,VARCHAR2等字符類型

long

INT64

bool

BOOLEAN

double

DOUBLE

DateTime

DATETIME

decmial

DECIMAL

short

SMALLINT

float

FLOAT

*上述類型映射不是唯一的;已進行寫讀的測試。

 

C#SQLite數(shù)據(jù)庫插入記錄并返回自動遞增ID

SQLite設置自動遞增列:創(chuàng)建INTEGER數(shù)據(jù)類型的列,設置該列為主鍵,然后才能設置自動遞增屬性。

執(zhí)行插入的sql后,調用last_insert_rowid()函數(shù)返回自動遞增ID

                object result = null;

                IDbConnection conn = null;

                IDbCommand cmd = null;

                //

                inti = cmd.ExecuteNonQuery();

                cmd.Parameters.Clear();

                if (i> 0)

                {

                                cmd.CommandText = "SELECT last_insert_rowid()";

                                result = cmd.ExecuteScalar();

                }

                else

                {

                                result = -1;

                }

                //

 

C#下的SQLite事務控制

已在TransactionScope管道下測試事務,在內部引發(fā)異常,事務能夠終止。

                try

                {

                                using (System.Transactions.TransactionScope scope = new System.Transactions.TransactionScope())

                                {

                                                //引發(fā)異常

                                                scope.Complete();

                                }

                }

                catch (Exception)

                {

 

                }

 

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內容均由用戶發(fā)布,不代表本站觀點。請注意甄別內容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多

    丰满熟女少妇一区二区三区| 成人欧美精品一区二区三区| 成人精品一区二区三区综合 | 五月天丁香婷婷一区二区| 国产精品亚洲欧美一区麻豆| 日韩人妻中文字幕精品| 精品一区二区三区免费看| 亚洲中文字幕视频在线播放| 狠狠亚洲丁香综合久久| 欧美国产日产在线观看| 日韩国产亚洲欧美激情| 日本亚洲精品在线观看| 日本东京热视频一区二区三区| 国产精品久久久久久久久久久痴汉| 国产精品不卡高清在线观看| 加勒比人妻精品一区二区| 午夜福利黄片免费观看| 亚洲精品国男人在线视频| 久久精品视频就在久久| 天海翼精品久久中文字幕| 亚洲男人的天堂就去爱| 亚洲一区二区三区精选| 亚洲欧洲在线一区二区三区| 黄色av尤物白丝在线播放网址| 久久这里只有精品中文字幕| 日本女优一区二区三区免费| 永久福利盒子日韩日韩| 一级片二级片欧美日韩| 久久这里只有精品中文字幕| 国产精品一区二区三区黄色片| 亚洲中文字幕在线观看四区| 九九热这里有精品20| 午夜福利视频偷拍91| 日韩在线免费看中文字幕| 欧美欧美欧美欧美一区| 亚洲一区二区三区在线免费| 中文文精品字幕一区二区| 少妇成人精品一区二区| 欧美国产日本免费不卡| 国产精品不卡免费视频| 久久亚洲精品成人国产|