亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++操作SQLite簡明教程

 更新時間:2014年06月12日 10:59:17   投稿:junjie  
這篇文章主要介紹了C++操作SQLite簡明教程,包含創(chuàng)建表、插入數(shù)據(jù)、查詢數(shù)據(jù)等常用操作,需要的朋友可以參考下

SQLite是一款輕型的本地文件數(shù)據(jù)庫,是遵守ACID的關(guān)聯(lián)式數(shù)據(jù)庫管理系統(tǒng)。它的設(shè)計目標是嵌入式的,而且目前已經(jīng)在很多嵌入式產(chǎn)品中使用了它,它的功能強、速度快,它占用資源非常的低,在嵌入式設(shè)備中,可能只需要幾百K的內(nèi)存就夠了。它能夠支持Windows/Linux/Unix等主流的操作系統(tǒng),同時能夠跟很多程序語言相結(jié)合。

一、SQLite的數(shù)據(jù)類型

在進行數(shù)據(jù)庫操作之前,有個問題需要說明,就是SQLite的數(shù)據(jù)類型,和其他的數(shù)據(jù)庫不同,Sqlite支持的數(shù)據(jù)類型有他自己的特色:Typelessness(無類型)。 SQLite是無類型的,這意味著你可以保存任何類型的數(shù)據(jù)到你所想要保存的任何表的任何列中, 無論這列聲明的數(shù)據(jù)類型是什么。

而大多數(shù)的數(shù)據(jù)庫在數(shù)據(jù)類型上都有嚴格的限制,在建立表的時候,每一列都必須制定一個數(shù)據(jù)類型,只有符合該數(shù)據(jù)類型的數(shù)據(jù)可以被保存在這一列當中。而在SQLite 2.X中,數(shù)據(jù)類型這個屬性只屬于數(shù)據(jù)本生,而不和數(shù)據(jù)被存在哪一列有關(guān),也就是說數(shù)據(jù)的類型并不受數(shù)據(jù)列限制(有一個例外:INTEGER PRIMARY KEY,該列只能存整型數(shù)據(jù))。

但是當SQLite進入到3.0版本的時候,這個問題似乎又有了新的答案,SQLite的開發(fā)者開始限制這種無類型的使用,在3.0版本當中,每一列開始擁有自己的類型,并且在數(shù)據(jù)存入該列的時候,數(shù)據(jù)庫會試圖把數(shù)據(jù)的類型向該類型轉(zhuǎn)換,然后以轉(zhuǎn)換之后的類型存儲。當然,如果轉(zhuǎn)換被認為是不可行的,SQLite仍然會存儲這個數(shù)據(jù),就像他的前任版本一樣。

舉個例子,如果你企圖向一個INTEGER類型的列中插入一個字符串,SQLite會檢查這個字符串是否有整型數(shù)據(jù)的特征, 如果有而且可以被數(shù)據(jù)庫所識別,那么該字符串會被轉(zhuǎn)換成整型再保存,如果不行,則還是作為字符串存儲。
誠然SQLite允許忽略數(shù)據(jù)類型, 但是仍然建議在你的Create Table語句中指定數(shù)據(jù)類型. 因為數(shù)據(jù)類型對于你和其他的程序員交流, 或者你準備換掉你的數(shù)據(jù)庫引擎時能起到一個提示或幫助的作用. SQLite支持常見的數(shù)據(jù)類型, 如:

1.NULL,值是NULL
2.INTEGER,值是有符號整形,根據(jù)值的大小以1,2,3,4,6或8字節(jié)存放
3.REAL,值是浮點型值,以8字節(jié)IEEE浮點數(shù)存放
4.TEXT,值是文本字符串,使用數(shù)據(jù)庫編碼(UTF-8,UTF-16BE或者UTF-16LE)
5.BLOB,只是一個數(shù)據(jù)塊,完全按照輸入存放(即沒有準換)

SQLite的操作接口

SQLite的2個重要結(jié)構(gòu)體:

sqlite3 *pdb,數(shù)據(jù)庫句柄,跟文件句柄FILE很類似
sqlite3_stmt *stmt,這個相當于ODBC的Command對象,用于保存編譯好的SQL語句

SQLite的5個主要的函數(shù):

sqlite3_open(), 打開數(shù)據(jù)庫
sqlite3_exec(),執(zhí)行非查詢的sql語句
sqlite3_prepare(),準備sql語句,執(zhí)行select語句或者要使用parameter bind時,用這個函數(shù)(封裝了sqlite3_exec).
sqlite3_step(),在調(diào)用sqlite3_prepare后,使用這個函數(shù)在記錄集中移動。
sqlite3_close(),關(guān)閉數(shù)據(jù)庫文件

還有一系列的函數(shù),用于從記錄集字段中獲取數(shù)據(jù),如:

sqlite3_column_text(),取text類型的數(shù)據(jù)
sqlite3_column_blob(),取blob類型的數(shù)據(jù)
sqlite3_column_int(),取int類型的數(shù)據(jù)

C++使用前準備

下載SQLite,分別從http://www.sqlite.org/2013/sqlite-amalgamation-3071700.zip、 http://www.sqlite.org/2013/sqlite-dll-win32-x86-3071700.zip下載SQLite的源文件和庫文件。

但是sqlite-dll-win32-x86-3071700.zip中并沒有提供SQLite的lib文件,需要自己編譯生成。解壓sqlite-dll-win32-x86-3071700.zip到sqlite-dll-win32-x86-3071700目錄,再將VS安裝目錄下VC中的LIB.EXE、LINK.EXE、mspdb80.dll(這里用的是VS2008)拷貝到sqlite-dll-win32-x86-3071700,執(zhí)行LIB.EXE /DEF:SQLITE3.DEF /MACHINE:IX86 就可以得到SQLITE3.LIB文件。

C++訪問SQLite

C++對SQLite進行操作的代碼如下:

復(fù)制代碼 代碼如下:

#include "stdafx.h"
#include <string.h>
using namespace std;

#include "sqlite3.h"
#pragma comment(lib, "SQLITE3.LIB")

static int SelectCallback(void *notUsed, int argc, char **argv, char **azColName)
{
 for (int i = 0 ; i < argc ; i++)
 {
 printf("%s = %s", azColName[i], (argv[i] ? argv[i] : "NULL"));
 if (i != argc -1)
 {
 printf(", ");
 }
 }
 printf("\n");
 return 0;
}

int _tmain(int argc, _TCHAR* argv[])
{
 sqlite3 * pDB;
 char* errMsg;

// 打開SQLite數(shù)據(jù)庫
 int res = sqlite3_open("sql.db", &pDB);
 if ( res != SQLITE_OK ){
 printf("Can't open database: %s\n", sqlite3_errmsg(pDB));
 sqlite3_close(pDB);
 return -1;
 }

// 創(chuàng)建表
 string strSQL= "create table test (id int, name text);";
 res = sqlite3_exec(pDB , strSQL.c_str() ,0 ,0, &errMsg);
 if (res != SQLITE_OK)
 {
 printf("Create table error: %s\n", errMsg);
 //return -1;
 }

// 插入數(shù)據(jù)
 res = sqlite3_exec(pDB,"begin transaction;",0,0, &errMsg);
 for (int i= 1; i < 10; ++i)
 {
 char sql[512];
 sprintf_s(sql, "insert into test values(%d, %s);", (i+10), "\"Test Name\"");

res = sqlite3_exec(pDB, sql,0,0, &errMsg);
 if (res != SQLITE_OK)
 {
 printf("Insert error: %s\n", errMsg);
 return -1;
 }
 }
 res = sqlite3_exec(pDB,"commit transaction;",0,0, &errMsg);

// 查詢數(shù)據(jù)
 strSQL= "select * from test;";
 res = sqlite3_exec(pDB, strSQL.c_str(), SelectCallback, 0 , &errMsg);
 if (res != SQLITE_OK)
 {
 printf("Select error: %s\n", errMsg);
 return -1;
 }

 // 關(guān)閉數(shù)據(jù)庫
 sqlite3_close(pDB);

return 0;
}

相關(guān)文章

  • c語言中聯(lián)合體和枚舉用法詳解

    c語言中聯(lián)合體和枚舉用法詳解

    結(jié)構(gòu)體、聯(lián)合體是C語言中的構(gòu)造類型,結(jié)構(gòu)體我們平時應(yīng)該都用得很多,下面這篇文章主要給大家介紹了關(guān)于c語言中聯(lián)合體和枚舉用法的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • 使用VScode搭建ROS開發(fā)環(huán)境的教程詳解

    使用VScode搭建ROS開發(fā)環(huán)境的教程詳解

    這篇文章主要介紹了使用VScode搭建ROS開發(fā)環(huán)境,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • 一起來練習(xí)C++的指針

    一起來練習(xí)C++的指針

    這篇文章主要為大家詳細介紹了C++的指針,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • C++程序的五大內(nèi)存分區(qū)實例詳解

    C++程序的五大內(nèi)存分區(qū)實例詳解

    C++內(nèi)存區(qū)域,一般可分為棧內(nèi)存區(qū)、堆內(nèi)存區(qū)、全局/靜態(tài)內(nèi)存區(qū)、文字常量內(nèi)存區(qū)及程序代碼區(qū)5大分區(qū),本文就帶大家深刻的理解這5大內(nèi)存分區(qū),感興趣的可以了解一下
    2021-10-10
  • 全面了解#pragma once與 #ifndef的區(qū)別

    全面了解#pragma once與 #ifndef的區(qū)別

    下面小編就為大家?guī)硪黄媪私?pragma once與 #ifndef的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • C++ 單例模式的詳解及實例

    C++ 單例模式的詳解及實例

    這篇文章主要介紹了C++ 單例模式的詳解及實例的相關(guān)資料,這里對單例中的懶漢模式和餓漢模式進行實現(xiàn)和比較,需要的朋友可以參考下
    2017-07-07
  • C++中的String的常用函數(shù)用法

    C++中的String的常用函數(shù)用法

    這篇文章主要介紹了C語言中String的常用函數(shù)用法,對學(xué)習(xí)String的小伙伴有一定的參考價值,感興趣的小伙伴可以借鑒一下
    2023-03-03
  • Qt使用流處理XML文件的示例代碼

    Qt使用流處理XML文件的示例代碼

    XML(eXtensible?Markup?Language)是一種通用的文本格式,被廣泛運用于數(shù)據(jù)交換和數(shù)據(jù)存儲。本文主要來和大家聊聊如何使用?Qt?處理?XML?格式的文檔,需要的可以參考一下
    2023-02-02
  • C/C++實現(xiàn)重置文件時間戳

    C/C++實現(xiàn)重置文件時間戳

    這篇文章主要為大家詳細介紹了C/C++實現(xiàn)重置文件時間戳的相關(guān)資料,文中的示例代碼講解詳細,具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以參考一下
    2023-11-11
  • C++中String類常見題目分享

    C++中String類常見題目分享

    這篇文章主要為大家詳細介紹了一些C++中String類的常見題目,文中的示例代碼講解詳細,對我們掌握C++有一定的幫助,感興趣的小伙伴可以了解一下
    2023-06-06

最新評論