一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫 - Sqlite - SQLite3的綁定函數(shù)族使用與其注意事項詳解

SQLite3的綁定函數(shù)族使用與其注意事項詳解

2020-06-11 18:41多客博圖 Sqlite

這篇文章主要介紹了SQLite3的綁定函數(shù)族使用與其注意事項的相關(guān)資料,文中通過示例代碼介紹的非常詳細,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。

前言

本文給大家展示的代碼實際上就是如何利用Sqlite3的參數(shù)化機制做數(shù)據(jù)插入,也可以update操作,就看你怎么玩了,這里只列出代碼,然后說一些注意事項。

下面的代碼,有一個問題,插入后的東西一定是:

?
1
INSERT INTO "work" VALUES('鉿','鉿鉿鉿鉿鉿',NULL,NULL,NULL,NULL,'鉿鉿鉿鉿鉿',NULL,NULL,110.0,1.0,108.9,NULL,NULL,'鉿鉿鉿鉿鉿',NULL,NULL,NULL,'鉿鉿鉿鉿鉿',NULL,NULL,NULL);

看看有問題的代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
sqlite3_stmt *stmt;
 CString sql = "insert into work values (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)";
 int rc = sqlite3_prepare_v2(db, sql.GetString(), -1, &stmt, NULL);
 
 if(rc != SQLITE_OK)
 {
 MessageBox("sqlite3_prepare_v2 Failed!");
 return;
 }
 
 count = 0;
 p_wnd = PrevWnd;
 
 while(count++ < ID_TOTALCOUNT)
 {
 CString DbStr;
 
 p_wnd = CWnd::GetNextDlgTabItem(p_wnd, FALSE);
 if(p_wnd == NULL)
 {
  return;
 }
 
 p_wnd->GetWindowText(DbStr);
 
 do
 {
  if(!DbStr.GetLength())
  {
  rc = sqlite3_bind_null(stmt, count);
  break;
  }
 
  //日期相關(guān)
  if( count == ID_CHUDANRIQI ||
  count == ID_CHUFARIQI ||
  count == ID_HUANKUANRIQI ||
  count == ID_HUOLIRIQI)
  {
  CDateTimeCtrl *TimeCtl = (CDateTimeCtrl *)p_wnd; 
  CString time = DateTimeToString(*TimeCtl);
 
  rc = sqlite3_bind_text(stmt, count, time.GetString(), time.GetLength(), SQLITE_STATIC);
  break;
  }
  else
  {
  //金錢相關(guān)的處理real類型
  if( count == ID_BAOXIANJINE ||
   count == ID_YONGJINBILV ||
   count == ID_JINGBAOFEI ||
   count == ID_HUANKUANJINE ||
   count == ID_LIRUNBILV ||
   count == ID_LIRUNJINE)
  {
   double tMoney = 0.0;
   int rtn = sscanf_s(DbStr.GetString(), "%lf", &tMoney);
 
   ASSERT(rtn == 1);
 
   rc = sqlite3_bind_double(stmt, count, tMoney);
  }
  else
  {
   char *str = (char *)DbStr.GetString();
   int c = strlen(str);
   int c1 = DbStr.GetLength();
 
   rc = sqlite3_bind_text(stmt, count, DbStr.GetString(), -1/*DbStr.GetLength()*/, SQLITE_STATIC);
  }
  }
 }while(0);
 
 if(rc != SQLITE_OK)
 {
  CString ErrStr = sqlite3_errstr(rc);
  MessageBox(ErrStr);
 
  return;
 }
 }
 
 rc = sqlite3_step(stmt);
 
 if(rc != SQLITE_DONE)
 {
 if(rc == SQLITE_ERROR)
 {
  CString DbErr;
  DbErr.Format("Sql Insert failed, %s", sqlite3_errmsg(db));
 
  MessageBox(DbErr);
 }
 else
 {
  MessageBox("sqlite3_step Failed!");
 }
 }
 
 sqlite3_finalize(stmt);

為什么呢?

因為,sqlite3_bind_text綁定的text,需要在做:

?
1
rc = sqlite3_step(stmt);

的時候統(tǒng)一提交,而上面的代碼使用的臨時變量,rc = sqlite3_step(stmt);的時候,早就不存在了。因此亂碼也是正常的。

修改如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
sqlite3_stmt *stmt;
 CString sql = "insert into work values (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)";
 int rc = sqlite3_prepare_v2(db, sql.GetString(), -1, &stmt, NULL);
 
 if(rc != SQLITE_OK)
 {
 MessageBox("sqlite3_prepare_v2 Failed!");
 return;
 }
 
 count = 0;
 p_wnd = PrevWnd;
 
 CString DbStr[ID_TOTALCOUNT + 1];
 
 while(count++ < ID_TOTALCOUNT)
 {
 DbStr[count].Empty();
 
 p_wnd = CWnd::GetNextDlgTabItem(p_wnd, FALSE);
 if(p_wnd == NULL)
 {
  return;
 }
 
 p_wnd->GetWindowText(DbStr[count]);
 
 do
 {
  if(!DbStr[count].GetLength())
  {
  rc = sqlite3_bind_null(stmt, count);
  break;
  }
 
  //日期相關(guān)
  if( count == ID_CHUDANRIQI ||
  count == ID_CHUFARIQI ||
  count == ID_HUANKUANRIQI ||
  count == ID_HUOLIRIQI)
  {
  CDateTimeCtrl *TimeCtl = (CDateTimeCtrl *)p_wnd; 
  CString time = DateTimeToString(*TimeCtl);
 
  DbStr[count] = time;
 
  rc = sqlite3_bind_text(stmt, count, time.GetString(), time.GetLength(), SQLITE_STATIC);
  }
  else
  {
  //金錢相關(guān)的處理real類型
  if( count == ID_BAOXIANJINE ||
   count == ID_YONGJINBILV ||
   count == ID_JINGBAOFEI ||
   count == ID_HUANKUANJINE ||
   count == ID_LIRUNBILV ||
   count == ID_LIRUNJINE)
  {
   double tMoney = 0.0;
   int rtn = sscanf_s(DbStr[count].GetString(), "%lf", &tMoney);
 
   ASSERT(rtn == 1);
 
   rc = sqlite3_bind_double(stmt, count, tMoney);
  }
  else
  {
   rc = sqlite3_bind_text(stmt, count, DbStr[count].GetString(), DbStr[count].GetLength(), SQLITE_STATIC);
  }
  }
 }while(0);
 
 if(rc != SQLITE_OK)
 {
  CString ErrStr = sqlite3_errstr(rc);
  MessageBox(ErrStr);
 
  return;
 }
 }
 
 rc = sqlite3_step(stmt);
 
 if(rc != SQLITE_DONE)
 {
 if(rc == SQLITE_ERROR)
 {
  CString DbErr;
  DbErr.Format("Sql Insert failed, %s", sqlite3_errmsg(db));
 
  MessageBox(DbErr);
 }
 else
 {
  MessageBox("sqlite3_step Failed!");
 }
 }
 
 sqlite3_finalize(stmt);

附上數(shù)據(jù)庫創(chuàng)建的sql語法:

?
1
2
3
4
5
6
sqlite> .dump work
PRAGMA foreign_keys=OFF;
BEGIN TRANSACTION;
CREATE TABLE work (baodanhao text unique primary key , chudanriqi text,qudao text,lianxiren text,xiaoshou text,beibaorenxingming text,chufar
iqi text,baoxianpinpai text,baoxianjihua text,baoxianjine real,yongjinbilv real,jingbaofei real,huankuanfangshi text,haikuanjine real,huanku
anriqi text,shifouquane text,lirunbilv real,lirunjine real,huoliriqi text,fapiaojisong text,shifubaoxiangongsi text,beizhu text);

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務(wù)器之家的支持。

原文鏈接:http://www.doocr.com/articles/58a875ac8d4f1f3990989f38

延伸 · 閱讀

精彩推薦
  • Sqlite基于sqlite特殊字符轉(zhuǎn)義的實現(xiàn)方法

    基于sqlite特殊字符轉(zhuǎn)義的實現(xiàn)方法

    本篇文章是對sqlite特殊字符轉(zhuǎn)義的實現(xiàn)方法進行了詳細的分析介紹,需要的朋友參考下 ...

    sqlite數(shù)據(jù)庫教程網(wǎng)4132020-06-04
  • SqliteSQLite中的WAL機制詳細介紹

    SQLite中的WAL機制詳細介紹

    這篇文章主要介紹了SQLite中的WAL機制詳細介紹,本文講解了什么是WAL、WAL如何工作、WAL的優(yōu)點與缺點、WAL引入的兼容性問題、WAL引入的性能問題等內(nèi)容,需要...

    dodo83402020-06-08
  • SqliteSQLite速度評測代碼

    SQLite速度評測代碼

    SQLite 作為一個輕量級嵌入式數(shù)據(jù)庫,還是非常好用的。雨痕極力推薦~~~~~~ ...

    SQLite教程網(wǎng)5832020-06-01
  • SqliteSQLite中重置自動編號列的方法

    SQLite中重置自動編號列的方法

    這篇文章主要介紹了SQLite中重置自動編號列的方法,本文講解了3種情況和其對應(yīng)解決方法,需要的朋友可以參考下 ...

    dodo84492020-06-08
  • SqliteSQLite 錯誤碼整理

    SQLite 錯誤碼整理

    這篇文章主要介紹了SQLite 錯誤碼,方便大家在開發(fā)過程中快速解決問題 ...

    SQLite教程網(wǎng)5532020-06-06
  • SqliteSQLite 內(nèi)存數(shù)據(jù)庫學(xué)習(xí)手冊

    SQLite 內(nèi)存數(shù)據(jù)庫學(xué)習(xí)手冊

    這篇文章主要介紹SQLite 內(nèi)存數(shù)據(jù)庫的使用方法, 需要的朋友可以參考下 ...

    SQLite教程網(wǎng)3292020-06-06
  • Sqlite詳解SQLite中的查詢規(guī)劃器

    詳解SQLite中的查詢規(guī)劃器

    這篇文章主要介紹了詳解SQLite中的查詢規(guī)劃器,SQLite是一個開源的嵌入式數(shù)據(jù)庫,需要的朋友可以參考下...

    SQLite教程網(wǎng)8892021-10-25
  • SqliteSQLite 入門教程三 好多約束 Constraints

    SQLite 入門教程三 好多約束 Constraints

    在上一篇隨筆的結(jié)尾,我提到了SQLite的約束, 但是在那里我把它翻譯成了限定符,不太準(zhǔn)確,這里先更正一下,應(yīng)該翻譯成約束更貼切一點。 那么什么是...

    SQLite入門教程4572020-06-05
主站蜘蛛池模板: 蜜柚精彩在线观看 | 欧美一区二区三区四区在线观看 | 国产成人精品免费视频软件 | 亚洲国产精品久久网午夜小说 | 人与禽交3d动漫羞羞动漫 | 欧美疯狂做爰xx | 特黄a级三级三级野战 | 国产成人综合久久 | fquer老师 | 日本漫画被黄漫免费动 | 大妹子最新视频在线观看 | 无套插入 | 亚洲欧美一 | 亚洲春色综合另类网蜜桃 | 国产成人精品男人的天堂538 | 免费xxxx日本大片在线观看 | 精品视频在线免费观看 | 亚洲高清成人 | 麻豆网| 顶级欧美做受xxx000 | 亚洲精品国产乱码AV在线观看 | 2022国产麻豆剧传媒古装 | 欧美三茎同入 | 青青青国产手机在线播放 | 91在线老王精品免费播放 | 亚洲AV 日韩 国产 有码 | 久久精品熟女亚洲AV国产 | 成人啪啪漫画全文阅读 | 麻豆小视频在线观看 | 午夜爱爱片| 韩国最新理论片奇忧影院 | 亚洲精品青青草原avav久久qv | 日本高清视频网址 | 女人全身裸露无遮挡免费观看 | 校花小雪灌满了男人们的浓浆 | 国产亚洲精品激情一区二区三区 | 污丝瓜视频| 精品一产品大全 | 免费看一级a一片毛片 | 国产成人无精品久久久久国语 | sp啪啪调教打屁股网站 |