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

首頁 > 編程 > C# > 正文

C# SQLite序列操作實現方法詳解

2020-01-24 00:34:54
字體:
來源:轉載
供稿:網友

本文實例講述了C# SQLite序列操作實現方法。分享給大家供大家參考,具體如下:

sqlite 不能直接創建自定義函數,不能像 sql server中那樣方便創建并使用。不過我們照樣可以創建它,創建成功后,我們照樣可以隨心所欲(比如批量更新等)

序列是一個數據庫中很常用的操作,在其它關系型數據庫創建是相當簡單的,但Sqlite不是很方便,因為它不能直接創建自定義函數

1.先創建一個表示序列的表:

CREATE TABLE SEQUENCE (SEQ_NAME      VARCHAR(50) NOT NULL,MIN_VAL        DECIMAL(12,0) NOT NULL,CURRENT_VAL    DECIMAL(12,0) NOT NULL,MAX_VAL        DECIMAL(12,0) NOT NULL DEFAULT 1,INCREMENT      INT NOT NULL DEFAULT 1,PRIMARY KEY (SEQ_NAME));

定義序列的最小值、最大值、步長、序列的名稱以及當前值

2.創建觸發器

CREATE TRIGGER [SEQ_RESET_TRG]AFTER UPDATEON [SEQUENCE]FOR EACH ROWbegin    UPDATE SEQUENCE SET CURRENT_VAL=MIN_VAL WHERE CURRENT_VAL-INCREMENT>=MAX_VAL;end;

當當前值大于最大值時,重置為最小值,達到序號循環使用的目的。

在C#中使用代碼創建函數,SqliteHelper 是訪問Sqlite的公共類庫,在前面的文章《C#操作SQLite數據庫幫助類詳解》中有介紹。

3.獲取當前序列值

[SQLiteFunction(Name = "GetCurrentValue", Arguments = 1, FuncType = FunctionType.Scalar)]public class GetCurrentValue : SQLiteFunction{    public override object Invoke(object[] args)    {      Dictionary<String, String> data = new Dictionary<string, string>();      data.Add("V_SEQ_NAME", args[0].ToString());      string sql = "SELECT CURRENT_VAL FROM SEQUENCE WHERE SEQ_NAME = @V_SEQ_NAME; ";      return SqliteHelper.ExecuteScalar(sql,data);    }}

4.獲取下一個序列值

[SQLiteFunction(Name = "GetNextValue", Arguments = 1, FuncType = FunctionType.Scalar)]public class GetNextValue : SQLiteFunction{    public override object Invoke(object[] args)    {      Dictionary<String, String> data = new Dictionary<string, string>();      data.Add("V_SEQ_NAME", args[0].ToString());      string sql = "UPDATE SEQUENCE SET CURRENT_VAL = CURRENT_VAL + INCREMENT WHERE SEQ_NAME = @V_SEQ_NAME; ";      SqliteHelper.ExecuteNonQuery(sql, data);      return SqliteHelper.ExecuteScalar(string.Format("SELECT GetCurrentValue('{0}')",args[0].ToString()),null);    }}

5.設置當前序列值

[SQLiteFunction(Name = "SetValue", Arguments = 2, FuncType = FunctionType.Scalar)]public class SetValue : SQLiteFunction{    public override object Invoke(object[] args)    {      Dictionary<String, String> data = new Dictionary<string, string>();      data.Add("V_SEQ_NAME", args[0].ToString());      data.Add("V_VALUE", args[1].ToString());      string sql = "UPDATE SEQUENCE SET CURRENT_VAL = @V_VALUE WHERE SEQ_NAME= @V_SEQ_NAME; ";      SqliteHelper.ExecuteScalar(sql, data);      return SqliteHelper.ExecuteScalar(string.Format("SELECT GetCurrentValue('{0}')", args[0].ToString()), null);    }}

6.測試:

在序列表SEQUENCE中添加一行數據

定義序列名稱為PURCHASE_IN_ORDER,最小值為2000,當前值為2000,最大值值為9999,步長為1.

執行語句:

string sql = string.Format("Select GetNextValue('PURCHASE_IN_ORDER')");SqliteHelper.ExecuteNonQuery(sql,null);

去數據庫中查看當前值是否增加

更多關于C#相關內容感興趣的讀者可查看本站專題:《C#常見數據庫操作技巧匯總》、《C#常見控件用法教程》、《C#窗體操作技巧匯總》、《C#數據結構與算法教程》、《C#面向對象程序設計入門教程》及《C#程序設計之線程使用技巧總結

希望本文所述對大家C#程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情国产日韩精品一区18| 久久精品久久久久久| 久久久精品视频在线观看| 成人午夜激情免费视频| 97视频人免费观看| 精品视频偷偷看在线观看| 日韩av影片在线观看| 国产va免费精品高清在线| 久久久久久久国产精品| 欧美插天视频在线播放| 国产一区二区免费| 国产精品成熟老女人| 欧美日韩激情美女| 国产精品亚洲аv天堂网| 欧美日韩国产999| 国产成人综合一区二区三区| 奇门遁甲1982国语版免费观看高清| 91精品国产综合久久久久久久久| 国产91精品高潮白浆喷水| 中文字幕精品一区二区精品| 欧洲永久精品大片ww免费漫画| 91丨九色丨国产在线| 欧美日韩中文字幕在线| 最近2019中文字幕mv免费看| 福利二区91精品bt7086| 久久久久久久久网站| 91成人性视频| 久久久亚洲网站| 在线观看日韩视频| 国内精品模特av私拍在线观看| 91国在线精品国内播放| 九九热这里只有精品免费看| 91九色视频在线| 国内偷自视频区视频综合| 国产热re99久久6国产精品| 亚洲精品午夜精品| 成人性生交大片免费观看嘿嘿视频| 538国产精品一区二区免费视频| 欧洲成人免费aa| 亚洲人成亚洲人成在线观看| 亚洲精品v欧美精品v日韩精品| 成人有码在线播放| 欧美在线一区二区三区四| 欧美视频在线免费看| 久久99国产综合精品女同| 成人久久一区二区| 国产成人精品一区二区在线| 亚洲欧美在线第一页| 久久亚洲精品中文字幕冲田杏梨| 91超碰中文字幕久久精品| 日韩av电影在线网| 精品女同一区二区三区在线播放| 欧美日韩在线免费观看| 57pao成人国产永久免费| 亚洲成成品网站| 欧美极品美女电影一区| 精品亚洲一区二区三区四区五区| 欧美大片免费观看在线观看网站推荐| 亚洲伊人一本大道中文字幕| 亚洲黄色免费三级| 九色91av视频| 性欧美暴力猛交69hd| 亚洲精品按摩视频| 欧美性一区二区三区| 欧美华人在线视频| 成人免费在线视频网址| 日韩最新在线视频| 久久久久女教师免费一区| 色无极亚洲影院| 性色av一区二区三区在线观看| 亚洲精品久久久久| 亚洲天堂视频在线观看| 国产欧美中文字幕| 萌白酱国产一区二区| 日韩av一区在线观看| 欧美精品一本久久男人的天堂| 亚洲女人天堂色在线7777| 色综合伊人色综合网站| 一本一道久久a久久精品逆3p| 久久久亚洲网站| 日韩一区二区欧美| 久久免费视频这里只有精品| 91wwwcom在线观看| 在线播放国产一区中文字幕剧情欧美| 欧美激情亚洲视频| 国产精品6699| 日韩中文字幕亚洲| 国产欧美日韩专区发布| 久久亚洲精品视频| 狠狠久久亚洲欧美专区| 欧美一级免费视频| 亚洲mm色国产网站| 欧美国产乱视频| 国产亚洲aⅴaaaaaa毛片| 亚洲一区美女视频在线观看免费| 日韩欧美国产成人| 亚洲综合视频1区| 热门国产精品亚洲第一区在线| 亚洲视频欧洲视频| 欧美日韩中文字幕综合视频| 亚洲国产成人精品女人久久久| 国产精品男女猛烈高潮激情| 久久精品视频免费播放| 欧美黑人巨大xxx极品| 亚洲综合视频1区| 久久久久亚洲精品| 亚洲国产天堂久久综合| 国产成人精品视频在线| 国产精品69精品一区二区三区| 亚洲毛片在线观看| 欧美一区二区影院| 欧美性在线观看| 亚洲欧美日韩国产中文专区| 久久视频这里只有精品| 自拍亚洲一区欧美另类| 91精品久久久久久久久中文字幕| 日韩电影在线观看免费| 中文字幕久精品免费视频| 美女精品久久久| 欧美性开放视频| 亚洲黄色av女优在线观看| 亚洲欧美日韩区| 一区二区三区精品99久久| 久久精品电影网| 国产97色在线| 欧美激情综合色| 亚洲免费精彩视频| 伊人亚洲福利一区二区三区| 91人人爽人人爽人人精88v| 久久亚洲欧美日韩精品专区| 日韩视频免费大全中文字幕| 亚洲成av人影院在线观看| 亚洲欧美日韩精品久久奇米色影视| 91在线直播亚洲| 日韩在线视频网| 日韩高清人体午夜| 欧美精品18videos性欧美| 亚洲欧美激情在线视频| 中文字幕国产亚洲2019| 国外视频精品毛片| 成人激情视频小说免费下载| 久久久女人电视剧免费播放下载| 国产精品中文在线| 国产精品亚洲第一区| 91极品视频在线| 奇米四色中文综合久久| 欧美成人精品h版在线观看| 日韩欧美高清视频| www.久久草.com| 亚州成人av在线| 国语自产精品视频在线看抢先版图片| 精品人伦一区二区三区蜜桃网站| 亚洲最新中文字幕| 国产欧美中文字幕| 日韩在线观看免费全| 久久精品电影一区二区| 久久久中精品2020中文| 成人情趣片在线观看免费| 久久综合伊人77777尤物| 26uuu国产精品视频| 亚洲人a成www在线影院| 在线精品高清中文字幕| 欧美xxxx综合视频| 国产精品一区二区三区成人|