ubuntu18.04 sqlite3安装及其应用

1. 安装sqlite3

sudo apt-get install sqlite3
sudo apt-get install libsqlite3-dev

2. 安装sqlite3可视化工具sqlitebrowser

sudo apt-get install sqlitebrowser

3. sqlite3简单应用

#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>static int callback(void *data, int argc, char **argv, char **azColName){int i;fprintf(stderr, "%s: \n", (const char*)data);for(i=0; i<argc; i++){printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");}printf("\n");return 0;
}int main(int argc, char* argv[]){sqlite3* db = NULL;char *zErrMsg = 0;int  rc;char *sql;const char* data = "Callback function called";/* Open database */int len = sqlite3_open("sqlite3demo", &db);if(len){fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));sqlite3_close(db);exit(0);}else{printf("You have opened a sqlite3 database successfully!\n");} /* Create SQL statement */sql = "CREATE TABLE COMPANY("  \"ID INT PRIMARY KEY     NOT NULL," \"NAME           TEXT    NOT NULL," \"AGE            INT     NOT NULL," \"ADDRESS        CHAR(50)," \"SALARY         REAL );";/* Execute SQL statement */rc = sqlite3_exec(db, sql, NULL, NULL, &zErrMsg);if( rc != SQLITE_OK ){fprintf(stderr, "SQL error: %s\n", zErrMsg);sqlite3_free(zErrMsg);}else{fprintf(stdout, "Table created successfully\n\n");}/* Create SQL statement */sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "  \"VALUES (1, 'Paul', 32, 'California', 20000.00 ); "  \"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "  \"VALUES (2, 'Allen', 25, 'Texas', 15000.00 ); "      \"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "  \"VALUES (3, 'Teddy', 23, 'Norway', 20000.00 ); "     \"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "  \"VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 ); ";/* Execute SQL statement */rc = sqlite3_exec(db, sql, NULL, NULL, &zErrMsg);if( rc != SQLITE_OK ){fprintf(stderr, "SQL error: %s\n", zErrMsg);sqlite3_free(zErrMsg);}else{fprintf(stdout, "Records created successfully\n\n");}/* Create SQL statement */sql = "SELECT * from COMPANY";/* Execute SQL statement */rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);if( rc != SQLITE_OK ){fprintf(stderr, "SQL error: %s\n", zErrMsg);sqlite3_free(zErrMsg);}else{fprintf(stdout, "Operation done successfully\n\n");}/* Create merged SQL statement */sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1; " \"SELECT * from COMPANY";/* Execute SQL statement */rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);if( rc != SQLITE_OK ){fprintf(stderr, "SQL error: %s\n", zErrMsg);sqlite3_free(zErrMsg);}else{fprintf(stdout, "Operation done successfully\n\n");}/* Create merged SQL statement */sql = "DELETE from COMPANY where ID=2; " \"SELECT * from COMPANY";/* Execute SQL statement */rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);if( rc != SQLITE_OK ){fprintf(stderr, "SQL error: %s\n", zErrMsg);sqlite3_free(zErrMsg);}else{fprintf(stdout, "Operation done successfully\n\n");}int nrow=0;int ncolumn = 0;char **azResult=NULL;       //二维数组存放结果/* Create merged SQL statement */sql="SELECT * from COMPANY";sqlite3_get_table( db , sql , &azResult , &nrow , &ncolumn , &zErrMsg );printf("nrow = %d ncolumn = %d\n", nrow, ncolumn);printf("the result is:\n");for(int i = 0; i < (nrow + 1) * ncolumn; i++){printf("azResult[%d]=%s\n", i, azResult[i]);}sqlite3_free_table(azResult);sqlite3_close(db);return 0;
}
1. sqlite3_open函数
int sqlite3_open(const char *filename,   /* Database filename (UTF-8) */sqlite3 **ppDb          /* OUT: SQLite db handle */
);

该函数打开一个指向 SQLite 数据库文件的连接,返回一个用于其他 SQLite 程序的数据库连接对象。

如果 filename 参数是 NULL 或 ‘:memory:’,那么 sqlite3_open() 将会在 RAM 中创建一个内存数据库,这只会在 session 的有效时间内持续。

如果文件名 filename 不为 NULL,那么 sqlite3_open() 将使用这个参数值尝试打开数据库文件。如果该名称的文件不存在,sqlite3_open() 将创建一个新的命名为该名称的数据库文件并打开。

2. sqlite3_exec函数
int sqlite3_exec(sqlite3*,                                  /* An open database */const char *sql,                           /* SQL to be evaluated */int (*callback)(void*,int,char**,char**),  /* Callback function */void *,                                    /* 1st argument to callback */char **errmsg                              /* Error msg written here */
);

该函数提供了一个执行 SQL 命令的快捷方式,SQL 命令由 sql 参数提供,可以由多个 SQL 命令组成。

在这里,第一个参数 sqlite3 是打开的数据库对象,sqlite_callback 是一个回调,data 作为其第一个参数,errmsg 将被返回用来获取程序生成的任何错误。
如果一些语句不需要回调函数可以直接写NULL。
如:sqlite3_exec(db, sql, NULL, NULL, &zErrMsg)

sqlite3_exec() 程序解析并执行由 sql 参数所给的每个命令,直到字符串结束或者遇到错误为止。

3. sqlite3_close函数
int sqlite3_close(sqlite3*);

该函数关闭之前调用 sqlite3_open() 打开的数据库连接。所有与连接相关的语句都应在连接关闭之前完成。

如果还有查询没有完成,sqlite3_close() 将返回 SQLITE_BUSY 禁止关闭的错误消息。

4. sqlite3_get_table,sqlite3_free_table函数
int sqlite3_get_table(sqlite3 *db,          /* An open database */const char *zSql,     /* SQL to be evaluated */char ***pazResult,    /* Results of the query */int *pnRow,           /* Number of result rows written here */int *pnColumn,        /* Number of result columns written here */char **pzErrmsg       /* Error msg written here */
);void sqlite3_free_table(char **result);

该函数不使用回调函数进行数据查询。

对比可以发现nrow=3代表三行,ncolumn=5代表有五列。
加上最上面一行,一共4*5=20个数据,存储在azResult数组中。

参考资料:

SQLite - C/C++ | 菜鸟教程
linux下C语言编程操作数据库(sqlite3)

Ubuntu18.04 sqlite3安装及其应用相关推荐

  1. 在Ubuntu18.04上安装ros2的环境,ros2的常用命令:播放包、录制包等

    在Ubuntu18.04上安装ros2的环境,ros2的常用命令:播放包.录制包等 1 添加密钥和ros2下载 2 更新源和安装ros-eloquent-desktop及其依赖 3 配置环境 3.1 ...

  2. ubuntu18.04上安装anaconda-python深度学习环境

    Anaconda是一套Python的发行版,发行版集成了必要的库,使用户可以一次性完成安装.Anaconda是一个侧重于数据分析的发行版,一些有助于数据分析的库,比如Numpy,Matplotlib, ...

  3. ubuntu18.04上安装ffmpeg

    ubuntu18.04上安装ffmpeg 下载ffmpeg wget https://johnvansickle.com/ffmpeg/builds/ffmpeg-git-amd64-static.t ...

  4. ubuntu18.04.4 安装 dlib (解决 Running setup.py install for dlib ... error错误)

    ubuntu18.04.4 安装 dlib (解决 Running setup.py install for dlib - error错误) 直接安装出现错误: Running setup.py in ...

  5. ubuntu18.04.4 安装百度硬盘

    文章目录 ubuntu18.04.4 安装百度硬盘 下载 打开网址 ubuntu18.04.4 安装百度硬盘 下载 打开网址 https://pan.baidu.com/download

  6. ubuntu18.04.4 安装 qq x64 版本

    文章目录 ubuntu18.04.4 安装 qq x64 版本 确定版本 根据你所使用的linux发行版选择格式: 1 代码安装 1 下载 2 安装qq 3 删除qq 2 图形化界面安装 1 下载 2 ...

  7. ubuntu18.04.4 安装 微信

    ubuntu18.04.4 安装 微信

  8. Ubuntu18.04下安装MySQL

    提示:以下操作均在root权限下进行. # 查看有没有安装MySQL: dpkg -l | grep mysql # 安装MySQL: apt install mysql-server 安装完成之后可 ...

  9. ubuntu18.04下安装中文输入法

    ubuntu18.04下安装中文输入法 windows下使用习惯了某款中文输入法,现在使用Ubuntu系统,也想和在windows下一样使用中文输入法,发现该输入法已经有了Linux版本,果断下载下来 ...

  10. ubuntu18.04下安装grafana6和简单使用

    ubuntu18.04下安装grafana6 环境 ubuntu18.04 下载 sudo apt-get install -y adduser libfontconfig1 # 使用wget 下载会 ...

最新文章

  1. PacBio Sequencing and Its Applications PacBio测序及其应用
  2. CH - 4901 关押罪犯(二分图判定+二分/并查集)
  3. Glass Fish 4.0.1中的Jersey SSE功能
  4. 解决WORD文档无法显示链接的图像问题
  5. 《MySQL必知必会》学习笔记——1.书中样例表的生成
  6. 使用PDFObject添加将本地磁盘pdf文件在前端页面展示
  7. python接入讯代理_[Python3网络爬虫开发实战] 9.3-付费讯代理、阿布云代理的使用...
  8. 200行代码让你找回童年的记忆,C + EasyX实现《拼图》小游戏!
  9. TIOBE 6 月编程语言排行榜:编程语言的长尾效应
  10. Vue输入框快速调出数字键盘
  11. 第29课:AD中class,设计参数,规则的设置
  12. Qt基础与Qt on Android入门-安晓辉-专题视频课程
  13. Python:利用cv2模块对图片进行灰度转换
  14. 2023年租房投影仪推荐,出租屋投影仪值得买吗?又该怎么选择?
  15. 关于机房动环监控系统
  16. 【硬核摄影2.0】用线性CCD器件制作扫描相机
  17. Android平板电脑刷机包简单解释
  18. 关于说服(一)-反抗机制
  19. 计算机类综合素质测评考什么,考事业编的综合素质测试主要考什么?是什么样子的题型?...
  20. Android 开发培训(04)--Android开发核心(三)

热门文章

  1. ucenter 用户加密方式
  2. 微信开发工具-命令行的使用
  3. 小米路由器sn算ssh密码_路由宝刷小米mini编程器固件,开SSH.
  4. 苹果开发者计划注册流程
  5. 服务器不能使用无线键盘,台式机无线键盘不能使用解决方法
  6. SpringCloud Gateway gatewayRequestUrl is missing
  7. 动态规划——1296:开餐馆
  8. rk板子linux系统安装rga,drm,mpp
  9. 全面赋能,OCR文字识别2022年多场景落地应用
  10. obs显示从服务器断开连接,obs重新连接到服务器