欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++?sqlite3數(shù)據(jù)庫配置使用教程

 更新時(shí)間:2023年08月09日 08:37:48   作者:Frank學(xué)習(xí)路上  
SQLite 是一種嵌入式的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),它是一個(gè)開源項(xiàng)目,已經(jīng)被廣泛應(yīng)用于各種應(yīng)用程序和操作系統(tǒng)中,這篇文章主要介紹了C++?sqlite3數(shù)據(jù)庫配置使用,需要的朋友可以參考下

??1. 項(xiàng)目介紹

項(xiàng)目Github地址: https://github.com/sqlite/sqlite

SQLite 是一種嵌入式的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),它是一個(gè)開源項(xiàng)目,已經(jīng)被廣泛應(yīng)用于各種應(yīng)用程序和操作系統(tǒng)中。以下是一些 SQLite 的特點(diǎn):

1.輕量級:SQLite 是一個(gè)非常輕量級的數(shù)據(jù)庫系統(tǒng),它的設(shè)計(jì)目標(biāo)之一是簡單、高效、占用資源少。SQLite 的核心庫非常小巧,以靜態(tài)或動(dòng)態(tài)鏈接方式與應(yīng)用程序集成,使得它適用于嵌入式設(shè)備和資源受限的環(huán)境。

2.無服務(wù)器架構(gòu):SQLite 是一種無服務(wù)器架構(gòu)的數(shù)據(jù)庫,意味著它不需要單獨(dú)的數(shù)據(jù)庫服務(wù)器進(jìn)程,數(shù)據(jù)庫操作直接在應(yīng)用程序內(nèi)部進(jìn)行。這種架構(gòu)使得 SQLite 在本地應(yīng)用和單用戶場景中非常方便和易用。

3.單一文件存儲:SQLite 數(shù)據(jù)庫以單一文件的形式存儲在磁盤上,這個(gè)文件可以包含整個(gè)數(shù)據(jù)庫結(jié)構(gòu)和數(shù)據(jù)。這種單一文件存儲的特點(diǎn)使得 SQLite 數(shù)據(jù)庫非常易于備份、傳輸和部署。

4.支持標(biāo)準(zhǔn) SQL:SQLite 支持標(biāo)準(zhǔn)的 SQL 查詢語言,包括常見的增刪改查操作、視圖、觸發(fā)器、索引等功能。它遵循 ANSI-SQL 標(biāo)準(zhǔn),并且提供了豐富的數(shù)據(jù)類型和內(nèi)置函數(shù)支持。

5.ACID 事務(wù)支持:SQLite 支持 ACID(原子性、一致性、隔離性和持久性)事務(wù),可以確保數(shù)據(jù)庫操作的可靠性和一致性。它使用寫-讀鎖定來實(shí)現(xiàn)并發(fā)控制和多用戶訪問。

6.跨平臺:SQLite 是跨平臺的數(shù)據(jù)庫系統(tǒng),它可以運(yùn)行在各種操作系統(tǒng)上,包括 Windows、macOS、Linux、Android 等。

7.開源和自由:SQLite 是一個(gè)完全開源的項(xiàng)目,遵循公共領(lǐng)域(Public Domain)版權(quán)協(xié)議,可以免費(fèi)使用、復(fù)制和分發(fā)。

SQLite 具有的這些特點(diǎn)使得它成為一種非常流行的數(shù)據(jù)庫選擇,尤其適合于小型和中小型的應(yīng)用程序、移動(dòng)應(yīng)用、嵌入式設(shè)備等場景。無論是作為獨(dú)立的數(shù)據(jù)庫引擎還是與其他編程語言和框架集成,SQLite 提供了一種輕便、靈活和可靠的解決方案。

??2. 環(huán)境配置

下面進(jìn)行環(huán)境配置:

ubuntu可直接apt安裝,另外可安裝 sqlitebrowser 可視化工具便于管理。

# 安裝sqlite3
sudo apt install sqlite3 libsqlite3-dev
sqlite3 --version
sqlite3 test.db
# 安裝sqlitebrowser
sudo apt-get install sqlitebrowser
sqlitebrowser test.db

sqlite常用命令:

.databases:列出當(dāng)前連接的數(shù)據(jù)庫
.tables:列出當(dāng)前數(shù)據(jù)庫中的表
.schema tablename:顯示指定表的結(jié)構(gòu)
CREATE TABLE tablename (column1 datatype, column2 datatype, ...);:創(chuàng)建表
INSERT INTO tablename (column1, column2, ...) VALUES (value1, value2, ...);:插入數(shù)據(jù)
SELECT * FROM tablename;:查詢表中的數(shù)據(jù)
UPDATE tablename SET column1=value1, column2=value2 WHERE condition;:更新表中的數(shù)據(jù)
DELETE FROM tablename WHERE condition;:刪除表中的數(shù)據(jù)
.exit:退出命令行

??3. 使用說明

下面進(jìn)行使用分析:

數(shù)據(jù)庫創(chuàng)建、插入、查詢、關(guān)閉示例:

#include <iostream>
#include <sqlite3.h>
int main(int argc, char** argv) {
    sqlite3* db;
    char* errorMsg = nullptr;
    // 打開或創(chuàng)建數(shù)據(jù)庫文件
    int rc = sqlite3_open("example.db", &db);
    if (rc != SQLITE_OK) {
        std::cout << "無法打開數(shù)據(jù)庫: " << sqlite3_errmsg(db) << std::endl;
        return rc;
    }
    // 創(chuàng)建表
    const char* createTableQuery = "CREATE TABLE IF NOT EXISTS employees (id INTEGER PRIMARY KEY, name TEXT, age INTEGER)";
    rc = sqlite3_exec(db, createTableQuery, nullptr, nullptr, &errorMsg);
    if (rc != SQLITE_OK) {
        std::cout << "無法創(chuàng)建表: " << errorMsg << std::endl;
        sqlite3_free(errorMsg);
        sqlite3_close(db);
        return rc;
    }
    // 插入數(shù)據(jù)
    const char* insertDataQuery = "INSERT INTO employees (id, name, age) VALUES (1, 'Alice', 25)";
    rc = sqlite3_exec(db, insertDataQuery, nullptr, nullptr, &errorMsg);
    if (rc != SQLITE_OK) {
        std::cout << "無法插入數(shù)據(jù): " << errorMsg << std::endl;
        sqlite3_free(errorMsg);
        sqlite3_close(db);
        return rc;
    }
    // 查詢數(shù)據(jù)
    const char* selectDataQuery = "SELECT * FROM employees";
    rc = sqlite3_exec(
        db,
        selectDataQuery,
        [](void* data, int argc, char** argv, char** colNames) -> int {
            for (int i = 0; i < argc; i++) {
                std::cout << colNames[i] << " = " << argv[i] << std::endl;
            }
            return 0;
        },
        nullptr,
        &errorMsg
    );
    if (rc != SQLITE_OK) {
        std::cout << "無法查詢數(shù)據(jù): " << errorMsg << std::endl;
        sqlite3_free(errorMsg);
        sqlite3_close(db);
        return rc;
    }
    // 關(guān)閉數(shù)據(jù)庫連接
    sqlite3_close(db);
    return 0;
}

編譯運(yùn)行:

g++ -o main main.cpp -lsqlite3 && ./main

到此這篇關(guān)于C++ sqlite3數(shù)據(jù)庫配置使用的文章就介紹到這了,更多相關(guān)C++ sqlite3配置使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 數(shù)據(jù)結(jié)構(gòu)之?dāng)?shù)組Array實(shí)例詳解

    數(shù)據(jù)結(jié)構(gòu)之?dāng)?shù)組Array實(shí)例詳解

    這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu)之?dāng)?shù)組Array實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • C語言實(shí)現(xiàn)簡易的掃雷小游戲

    C語言實(shí)現(xiàn)簡易的掃雷小游戲

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡易的掃雷小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C++如何實(shí)現(xiàn)簡易掃雷游戲

    C++如何實(shí)現(xiàn)簡易掃雷游戲

    這篇文章主要為大家詳細(xì)介紹了C++如何實(shí)現(xiàn)簡易掃雷游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • c++中map的基本用法和嵌套用法實(shí)例分析

    c++中map的基本用法和嵌套用法實(shí)例分析

    這篇文章主要介紹了c++中map的基本用法和嵌套用法,以實(shí)例形式分析了map容器的基本使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-01-01
  • Qt中利用QTextBrowser控件設(shè)計(jì)日志窗口

    Qt中利用QTextBrowser控件設(shè)計(jì)日志窗口

    本文主要介紹了Qt中利用QTextBrowser控件設(shè)計(jì)日志窗口,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • 一文弄懂C語言EOF

    一文弄懂C語言EOF

    在 C語言中,EOF 是一個(gè)宏定義,EOF 常常用于文件的輸入輸出中,當(dāng)讀取到文件結(jié)束時(shí),會返回 EOF,本文就詳細(xì)的介紹一下具體使用方法,感興趣的可以一起來了解一下
    2023-05-05
  • C語言實(shí)現(xiàn)3*3數(shù)組對角線之和示例

    C語言實(shí)現(xiàn)3*3數(shù)組對角線之和示例

    今天小編就為大家分享一篇C語言實(shí)現(xiàn)3*3數(shù)組對角線之和示例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • C語言調(diào)用攝像頭生成avi視頻程序

    C語言調(diào)用攝像頭生成avi視頻程序

    這篇文章主要為大家詳細(xì)介紹了C語言如何調(diào)用攝像頭生成avi視頻程序,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的小伙伴可以參考一下
    2023-11-11
  • C語言排序算法之插入排序

    C語言排序算法之插入排序

    這篇文章主要為大家詳細(xì)介紹了C語言排序算法之插入排序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C++實(shí)現(xiàn)類似延時(shí)停頓的打字效果

    C++實(shí)現(xiàn)類似延時(shí)停頓的打字效果

    這篇文章主要介紹的是使用C++實(shí)現(xiàn)類似延時(shí)停頓的打字效果的代碼,非常的簡單,推薦給大家,有需要的小伙伴可以參考下。
    2015-03-03

最新評論