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

Linux系統(tǒng)上sqlite3的使用操作實(shí)例

 更新時(shí)間:2025年06月16日 10:20:32   作者:SELSL  
本文介紹了Linux下sqlite3的安裝、基本操作指令、SQL語句使用、C/C++?API調(diào)用及QT集成方法,涵蓋數(shù)據(jù)庫創(chuàng)建、表結(jié)構(gòu)定義、數(shù)據(jù)增刪改查、API執(zhí)行與回調(diào)機(jī)制等內(nèi)容,對linux?sqlite3使用感興趣的朋友一起看看吧

Linux系統(tǒng)上sqlite3的使用

一、在Linux系統(tǒng)上安裝sqlite3

首先更新軟件包索引:sudo apt-get update

下載安裝sqlite3:sudo apt-get install sqlite3

查看是否下載成功:sqlite3

這樣就說明安裝成功了

安裝sqlite3和安裝sqlite3依賴庫不是一個(gè)概念,安裝sqlite3依賴庫,需要執(zhí)行sudo apt-get install libsqlite3-dev

二、sqlite3的操作指令

常用的指令

.help, 幫助信息
.database 當(dāng)前關(guān)聯(lián)的數(shù)據(jù)庫名稱
.open 打開數(shù)據(jù)庫
.tables 顯示當(dāng)前數(shù)據(jù)庫中的表名
.schema 查看數(shù)據(jù)表結(jié)構(gòu)
.mode 設(shè)置顯示模式
.nullval 設(shè)置空白字段顯示的字符串
.headers on 顯示數(shù)據(jù)表的表頭
.exit 退出

這里對部分操作進(jìn)行了演示

對于更多操作可以使用.help查重

三、sqlite3的sql語句

sqlite3的使用命令很多,這里使用了最常用的幾個(gè)命令,所有的命令都以 ' ; ' 結(jié)束

1、新建一個(gè)以.db結(jié)尾的數(shù)據(jù)庫文件

使用:sqlite3 mydatebase.db

2、創(chuàng)建sqlite表單,其實(shí)感覺和excel表格差不多

這里sqlite3對大小寫沒有那么的敏感,所以不用刻意的區(qū)分大小寫

使用這個(gè)形式創(chuàng)建表單

CREATE TABLE table_name ( column_1 data_type constraints, column_2 data_type constraints, ..., column_n data_type constraints );

正如上面所說dictionaries是表單名字,

1框中代表第一列的名字是english,向下chinese代表第二列的名字

2框中代表這一列的數(shù)據(jù)類型,一般的數(shù)據(jù)類型有tinyint(-128~127)、int(-2147483648~2147483647)、bigint(-9223372036854775808~9223372036854775807)、real(浮點(diǎn)數(shù))、text(文本)、還有很多類型需要可以去網(wǎng)上查詢,這里因?yàn)槭谴鎲卧~,所以使用文本類型text

3框中是限制,一般填PRIMARY KEY(主鍵), 表示該列數(shù)據(jù)唯一,可以加快數(shù)據(jù)訪問、或者NOT NULL(非空), 該類數(shù)據(jù)不能為空

.table來查看表單是否創(chuàng)建成功,下圖所示,聲明我們的dictionaries表單已經(jīng)創(chuàng)建成功了

.schema + 表名 查看數(shù)據(jù)表結(jié)構(gòu)

3、插入數(shù)據(jù)

使用這個(gè)形式插入數(shù)據(jù)

方式一:

INSERT INTO table_name (column_1, column_2, ..., column_n) VALUES (value_1, value_2, ..., value_n);

方式二:

INSERT INTO table_name VALUES(value_1, value_2...);

例子:

insert into dictionaries (english, chinese)?values('main', '主要的,最大的');

english與chinese是每一列的名字

4、顯示數(shù)據(jù)

使用這個(gè)形式顯示數(shù)據(jù)

SELECT column_1, column_2, ..., column_n FROM table_name;

table_name是表單名

.headers on與.mode column可以改變顯示樣子

模糊查詢:

SELECT 列名1,列名2, ... FROM 表名 WHERE 列名 LIKE 模糊匹配條件;

模糊匹配通配符

%, 代表零個(gè)、一個(gè)或者多個(gè)數(shù)字或字符

_, 代表一個(gè)單一的數(shù)字或字符

select * from employee where ein like "1%" ;
select * from employee where name like "黃%" ;
select * from employee where name like "黃_" ;
select * from employee where ein like "1_2%" ;

5、更改數(shù)據(jù)

使用這個(gè)形式更改數(shù)據(jù)

UPDATE table_name SET column_1 = value_1, column_2 = value_2, ..., column_n = value_n WHERE condition;

這里condition是:列名=元素,表示在哪一列找到元素等于這個(gè)元素的,然后進(jìn)行更改、沒有條件表達(dá)式指定的所有列數(shù)據(jù)都被修改、多個(gè)條件可以用 and 或者 or 連接

更改之后的

6、刪除數(shù)據(jù)

使用這種格式

DELETE FROM table_name WHERE condition;

condition:沒有條件表達(dá)式刪除表中所有數(shù)據(jù)、多個(gè)條件可以用 and 或者 or 連接

7、刪除表單

采用這種形式:

DROP TABLE table_name;

8、退出

.exit

生成了數(shù)據(jù)庫了mydatebase.db

四、sqlite3常用的API(C/C++)

具體怎么使用看An Introduction To The SQLite C/C++ Interface

1、打開和關(guān)閉數(shù)據(jù)庫.db函數(shù)

打開:

int sqlite3_open(
    const char *filename,   /* 數(shù)據(jù)庫文件的文件名,如果為 ":memory:" 則表示創(chuàng)建內(nèi)存中數(shù)據(jù)庫 */
    sqlite3 **ppDb          /* 返回指向數(shù)據(jù)庫連接句柄的指針 */
);

關(guān)閉:

int sqlite3_close(sqlite3*);

下面為實(shí)例代碼:

#include <stdio.h>
#include <sqlite3.h>
?
int main() {
    sqlite3 *db;
    /*打開數(shù)據(jù)庫*/
    int rc = sqlite3_open("test.db", &db);
    if (rc == SQLITE_OK) {
        printf("已成功打開數(shù)據(jù)庫\n");
        sqlite3_close(db); // 關(guān)閉數(shù)據(jù)庫連接
    } else {
        fprintf(stderr, "無法打開數(shù)據(jù)庫: %s\n", sqlite3_errmsg(db));
        sqlite3_close(db);
        return 1;
    }
?
    return 0;
}

2、執(zhí)行sqlite3命令函數(shù)

sqlite3_exec() 函數(shù)用于在 SQLite 數(shù)據(jù)庫連接上執(zhí)行一條或多條 SQL 語句,并調(diào)用一個(gè)回調(diào)函數(shù)處理執(zhí)行結(jié)果

int sqlite3_exec(
    sqlite3*,                                  /* 執(zhí)行 SQL 命令的數(shù)據(jù)庫連接 */
    const char *sql,                           /* 待執(zhí)行的 SQL 命令 */
    int (*callback)(void*,int,char**,char**),  /* 在執(zhí)行命令時(shí)的回調(diào)函數(shù) */
    void *,                                    /* 作為第一個(gè)參數(shù)傳遞給回調(diào)函數(shù)的指針 */
    char **errmsg                              /* 用于存儲(chǔ)錯(cuò)誤消息的指針 */
);

該函數(shù)接收一個(gè)打開的數(shù)據(jù)庫連接 sqlite3*,待執(zhí)行的 SQL 命令 sql,以及一個(gè)回調(diào)函數(shù) callback,可以選擇性地傳遞一個(gè)指向用戶數(shù)據(jù)的指針作為回調(diào)函數(shù)的第一個(gè)參數(shù) 該句話的意思是,回調(diào)函數(shù)的參數(shù)列表(簽名)決定了該函數(shù)在被調(diào)用時(shí)應(yīng)接收哪些參數(shù),并指定了它們的數(shù)據(jù)類型和順序。

int (*callback)(void*, int, char**, char**);
  • 第一個(gè)參數(shù) void*,是使用者傳遞給 sqlite3_exec() 調(diào)用的 void* 參數(shù)。
  • 第二個(gè)參數(shù) int,是查詢結(jié)果所返回的列數(shù)。
  • 第三個(gè)參數(shù) char**,是包含每個(gè)結(jié)果集元素值的字符串?dāng)?shù)組。
  • 第四個(gè)參數(shù) char**,是包含每個(gè)結(jié)果集元素的列名稱的字符串?dāng)?shù)組。這通常會(huì)在 SELECT 語句中返回。

3、實(shí)例應(yīng)用一

創(chuàng)建表:

#include <sqlite3.h>
#include <stdio.h>
?
int main(int argc, char* argv[]) {
    sqlite3 *db;
    char *zErrMsg = 0;
    int rc;
    /*打開數(shù)據(jù)庫*/
    rc = sqlite3_open("test.db", &db);
    if (rc) {
        fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
        sqlite3_close(db);
        return 1;
    } else {
        fprintf(stdout, "Opened database successfully\n");
    }
?
    /*創(chuàng)建表的SQL語句*/
    char *sql = "CREATE TABLE COMPANY("
        "ID INT PRIMARY KEY     NOT NULL,"
        "NAME           TEXT    NOT NULL,"
        "AGE            INT     NOT NULL);";
?
    /*執(zhí)行SQL語句*/
    rc = sqlite3_exec(db, sql, 0, 0, &zErrMsg);
    if (rc != SQLITE_OK) {
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    } else {
        printf("Table created successfully\n");
    }
?
    /*關(guān)閉數(shù)據(jù)庫文件*/
    sqlite3_close(db);
    return 0;
}

插入數(shù)據(jù)

#include <sqlite3.h>
#include <stdio.h>
?
int main(int argc, char* argv[]) {
    sqlite3 *db;
    char *zErrMsg = 0;
    int rc;
?
    /*打開數(shù)據(jù)庫*/
    rc = sqlite3_open("test.db", &db);
    if (rc) {
        fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
        sqlite3_close(db);
        return 1;
    } else {
        fprintf(stdout, "Opened database successfully\n");
    }
?
    /*創(chuàng)建表的SQL語句*/
    char *sql = "INSERT INTO COMPANY (ID,NAME,AGE) VALUES (1, '張三', 32);"
        "INSERT INTO COMPANY (ID,NAME,AGE) VALUES (2, '李四', 33);"
        "INSERT INTO COMPANY (ID,NAME,AGE) VALUES (3, '王五', 30);"
        "INSERT INTO COMPANY (ID,NAME,AGE) VALUES (4, '王博', 32);"
        "INSERT INTO COMPANY (ID,NAME,AGE) VALUES (5, '李為', 33);"
        "INSERT INTO COMPANY (ID,NAME,AGE) VALUES (6, '趙倩', 30);";
?
    /*執(zhí)行SQL語句*/
    rc = sqlite3_exec(db, sql, 0, 0, &zErrMsg);
    if (rc != SQLITE_OK) {
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    } else {
        fprintf(stdout, "Records created successfully\n");
    }
?
    /*關(guān)閉數(shù)據(jù)庫文件*/
    sqlite3_close(db);
    return 0;
}

查詢數(shù)據(jù)

這里定義了一個(gè)回調(diào)函數(shù) callback(),該函數(shù)用于處理 sqlite3_exec() 執(zhí)行結(jié)果。

#include <sqlite3.h>
#include <stdio.h>
?
// 回調(diào)函數(shù)
int callback(void *data, int argc, char **argv, char **azColName) {
    int i;
    printf("callback:\n");
    for(i = 0; i < argc; i++) {
       printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
   }
    printf("\n");
?
    return 0;
}
?
int main () {
    sqlite3 *db;
    char *zErrMsg = 0; // 存儲(chǔ)錯(cuò)誤消息的指針
    int rc;
?
    rc = sqlite3_open("test.db", &db);
    if (rc != SQLITE_OK) {
       fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
       sqlite3_close(db);
       return 1;
   }
?
    const char* sql = "SELECT * from COMPANY";
    rc = sqlite3_exec(db, sql, callback, NULL, &zErrMsg);
?
    if (rc != SQLITE_OK) {
       fprintf(stderr, "SQL error: %s\n", zErrMsg);
       sqlite3_free(zErrMsg);
   } else {
       printf("Operation done successfully\n");
   }
?
    sqlite3_close(db);
    return rc;
}

4、實(shí)例代碼二

請參考基于UDP+sqlite3實(shí)現(xiàn)的單詞查詢器(Linux系統(tǒng)下)

五、QT中使用SQLite3

1、創(chuàng)建數(shù)據(jù)庫實(shí)例(加載對應(yīng)的驅(qū)動(dòng)), 加載的共享庫位

①、QSqlDatabase, 通過這個(gè)類添加/刪除/復(fù)制/關(guān)閉數(shù)據(jù)庫實(shí)例

/*連接SQLite數(shù)據(jù)庫*/
//創(chuàng)建數(shù)據(jù)庫實(shí)例(加載對應(yīng)的驅(qū)動(dòng)), 加載的共享庫位
于/opt/Qt5.12.0/5.12.0/gcc_64/plugins/sqldrivers/
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
//設(shè)置要使用的數(shù)據(jù)庫名稱
db.setDatabaseName("customdb");

②、連接數(shù)據(jù)庫

//連接數(shù)據(jù)庫
bool ok = db.open();

2、對數(shù)據(jù)庫進(jìn)行一系列的添、刪、查、改操作(編寫并執(zhí)行SQL語句)

QSqlQuery, 數(shù)據(jù)庫操作類

/*查詢*/
QSqlQuery query("SELECT * FROM artist");
int fieldNo = query.record().indexOf("country");
while (query.next()) {
QString country = query.value(fieldNo).toString();
doSomething(country);
}
/*插入*/
QSqlQuery query;
query.prepare("INSERT INTO person (id, forename, surname) "
"VALUES (:id, :forename, :surname)");
query.bindValue(":id", 1001);
query.bindValue(":forename", "Bart");
query.bindValue(":surname", "Simpson");
query.exec();
/*也可以自行拼接字符串*/
QSqlQuery query;
query.exec("INSERT INTO employee (id, name, salary) "
"VALUES (1001, 'Thad Beaumont', 65000)");
//刪除
QSqlQuery query;
    /*query.prepare("delete from employee where id = :id");
    query.bindValue(":id", id);*/
QString del = QString("delete from employee where id = %1").arg(id);
//修改
QSqlQuery query;
    QString sql=QString("update StuInfo set age=%1 ,score=%2 where num=%3 or name='%4';")
            .arg(ui->lineEdit_age->text())
            .arg(ui->lineEdit_score->text())
            .arg(ui->lineEdit_num->text())
            .arg(ui->lineEdit_name->text());

執(zhí)行sqlite語句

bool QSqlQuery::exec(const QString &query)

查具體的

QSqlQueryModel如果想單獨(dú)獲取查詢記錄可以使用它的record函數(shù),它有兩個(gè)重載版本。其中無參版本返回字段信息和一條空記錄,帶參版本返回字段信息和對應(yīng)的一條記錄。

rec = model.record(2);
for(int i=0; i<rec.count(); i++){
//qDebug()<<rec.fieldName(i);
qDebug()<<rec.field(i).type()<<": "<< rec.field(i).name();
qDebug()<<rec.value(i);
}

3、關(guān)閉數(shù)據(jù)庫

void QSqlDatabase::close()

參考資源:https://download.csdn.net/download/2403_82436914/90755150

到此這篇關(guān)于Linux系統(tǒng)上sqlite3的使用操作實(shí)例的文章就介紹到這了,更多相關(guān)linux sqlite3使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 為SQLite3提供一個(gè)ANSI到UTF8的互轉(zhuǎn)函數(shù)

    為SQLite3提供一個(gè)ANSI到UTF8的互轉(zhuǎn)函數(shù)

    這篇文章主要為大家分享下ANSI與UTF8的互轉(zhuǎn)函數(shù),需要的朋友可以收藏下
    2013-12-12
  • SQLite3的綁定函數(shù)族使用與其注意事項(xiàng)詳解

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

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

    SQLite教程(一):SQLite數(shù)據(jù)庫介紹

    這篇文章主要介紹了SQLite教程(一):SQLite數(shù)據(jù)庫介紹,本文講解了什么是SQLite、SQLite的主要優(yōu)點(diǎn)、和RDBMS相比SQLite的一些劣勢、個(gè)性化特征等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • SQLite3中的日期時(shí)間函數(shù)使用小結(jié)

    SQLite3中的日期時(shí)間函數(shù)使用小結(jié)

    這篇文章主要介紹了SQLite3中的日期時(shí)間函數(shù)使用小結(jié),同時(shí)介紹了一些SQLite數(shù)據(jù)庫的基本知識,需要的朋友可以參考下
    2014-05-05
  • SQLite教程(十一):臨時(shí)文件

    SQLite教程(十一):臨時(shí)文件

    這篇文章主要介紹了SQLite教程(十一):臨時(shí)文件,本文講解了七種臨時(shí)文件并對它們一一具體說明,并相關(guān)的編譯時(shí)參數(shù)和指令、其它優(yōu)化策略等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • 保護(hù)你的Sqlite數(shù)據(jù)庫(SQLite數(shù)據(jù)庫安全秘籍)

    保護(hù)你的Sqlite數(shù)據(jù)庫(SQLite數(shù)據(jù)庫安全秘籍)

    相信使用PHP開發(fā)的人員一定不會(huì)對SQLite感到陌生了,PHP5已經(jīng)集成了這個(gè)輕量型的數(shù)據(jù)庫。并且很多虛擬主機(jī)無論是win還是*nux都支持它。
    2011-08-08
  • SQLite字符串比較時(shí)的大小寫問題解決方法

    SQLite字符串比較時(shí)的大小寫問題解決方法

    這篇文章主要介紹了SQLite字符串比較時(shí)的大小寫問題解決方法,本文總結(jié)了比較字符串時(shí)的大小寫問題的3種解決方案,需要的朋友可以參考下
    2015-03-03
  • sqlite時(shí)間戳轉(zhuǎn)時(shí)間語句(時(shí)間轉(zhuǎn)時(shí)間戳)

    sqlite時(shí)間戳轉(zhuǎn)時(shí)間語句(時(shí)間轉(zhuǎn)時(shí)間戳)

    這篇文章主要介紹了sqlite時(shí)間戳轉(zhuǎn)時(shí)間、時(shí)間轉(zhuǎn)時(shí)間戳的方法,需要的朋友可以參考下
    2014-06-06
  • SQLite優(yōu)化方法

    SQLite優(yōu)化方法

    SQLite的數(shù)據(jù)庫本質(zhì)上來講就是一個(gè)磁盤上的文件,所以一切的數(shù)據(jù)庫操作其實(shí)都會(huì)轉(zhuǎn)化為對文件的操作,而頻繁的文件操作將會(huì)是一個(gè)很好時(shí)的過程,會(huì)極大地影響數(shù)據(jù)庫存取的速度。
    2008-09-09
  • SQLite數(shù)據(jù)庫安裝及基本操作指南

    SQLite數(shù)據(jù)庫安裝及基本操作指南

    SQLite 是一個(gè)開源的嵌入式關(guān)系數(shù)據(jù)庫,實(shí)現(xiàn)自包容、零配置、支持事務(wù)的SQL數(shù)據(jù)庫引擎。 其特點(diǎn)是高度便攜、使用方便、結(jié)構(gòu)緊湊、高效、可靠。今天我們主要來講解下SQLite數(shù)據(jù)庫的安裝以及基本操作指南
    2014-08-08

最新評論