Linux C 实现sqlite3数据库的基本操作

一、数据库简介

SQLite第一个Alpha版本诞生于2000年5月. 至今已经有10个年头了. SQLite也迎来了一个版本 SQLite 3已经发布.

SQLite是一款轻型的数据库,是遵守ACID的关系式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如Tcl、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。

二、数据库指令

创建表:create table XXX(name text, passwd text)
向表中插入数据:insert into XXX values(“jack”, “ps666”)
查询表中数据:select * from XXX;
删除指定记录项:delete from XXX where name = “rose”
删除表:drop table XXX

三、sqlite3相关接口函数

1、打开数据库——sqlite_open()

int sqlite3_open(const char *filename, sqlite3 **ppDb)
/*********************************************************************************
* Description:  打开数据库
* Input:         filename:数据库路径名  ppDb:代指打开的数据库(打开的数据库句柄)
* Return:        成功返回 SQLITE_OK
                 失败返回 错误码
* Others:        不存在,则创建
**********************************************************************************/

2、执行sql语句——sqlite_exec()

int sqlite3_exec(sqlite3* ppDb, const char *sql, sqlite_callback, void *data, char **errmsg)
/*********************************************************************************
* Description:  执行sql语句
* Input:         ppDb:为刚才使用sqlite3_open打开的数据库链接
                 sql: sql语句
                 sqlite_callback:回调函数 用于查询 不关心写NULL
                 data: 回调函数的参数  不关心写NULL
                 errmsg:返回的错误信息
* Return:        成功返回0 失败返回错误码
* Others:
**********************************************************************************/

3、关闭数据库——sqlite_close()

int sqlite3_close(sqlite3 *ppDb);
/*********************************************************************************
* Description:  关闭数据库
* Input:         ppDb:为刚才使用sqlite3_open打开的数据库链接
* Return:
* Others:
**********************************************************************************/

四、代码演示

/*===============================================================
*   Copyright (C) 2022 All rights reserved.

*
*   文件名称:sqlite3.c
*   创 建 者:QiuCC
*   创建日期:2022年08月20日
*   描    述:
*
*   更新日志:
*
================================================================*/
#include
#include
#include
#include
#include
#define N 100

int main(int argc, char *argv[])
{
    //创建数据库句柄db
    sqlite3 *db;

    //使用数据库句柄打开数据库
    int ret = sqlite3_open("./my.db", &db);
    if(ret < 0)
    {
        perror("打开数据库");
        exit(-1);
    }

    //用于存放数据库中需要执行的数据库指令
    char sql[N] = "create table if not exists stu_table(name text, score int);";

    char *errmsg;
    ret = sqlite3_exec(db, sql, NULL, NULL, &errmsg);
    if(ret != 0)
    {
        printf("sqlite3_exec:%s\n", errmsg);
        exit(-1);
    }

    //拷贝指令到sql中将数据进行写入
    strcpy(sql, "insert into stu_table values ('lisi', 86);");
    ret = sqlite3_exec(db, sql, NULL, NULL, &errmsg);
    if(ret != 0)
    {
        printf("sqlite3_exec:%s\n", errmsg);
        exit(-1);
    }

    strcpy(sql, "insert into stu_table values ('zhangsan', 91)");
    ret = sqlite3_exec(db, sql, NULL, NULL, &errmsg);
    if(ret != 0)
    {
        printf("sqlite3_exec:%s\n", errmsg);
        exit(-1);
    }

    //关闭数据库
    sqlite3_close(db);

    return 0;
}

五、结果展示

Linux C 实现sqlite3数据库的基本操作

从上述结果中可以看出,我们成功的将创建了一张成绩的表,并且内部数据均正确,这里值得注意的是,我们的数据库命令在输入完成时一定要加上分号,不然就无法正确执行。

好的,以上就是本期内容了!!!

欢迎大家参考指正!!!

Linux C 实现sqlite3数据库的基本操作

Original: https://blog.csdn.net/m0_45901455/article/details/126444939
Author: 玖尾猫
Title: Linux C 实现sqlite3数据库的基本操作

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/815862/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球