Linux C语言操作sqlite3数据库

一、环境配置

1、下载源码:sqlite-autoconf-3470200.tar.gz

2、解压,cd到源码主目录

3、配置参数

bash 复制代码
./configure --prefix=/usr/local/

如果是交叉编译环境

bash 复制代码
./configure CC=/opt/rk3288/gcc-linaro/bin/arm-linux-gnueabihf-gcc --host=arm-linux --prefix=/opt/rk3288/sqlite3/

4、编译 & 安装

bash 复制代码
make -j8
bash 复制代码
sudo make install

二、命令行操作数据库

1、创建数据库

bash 复制代码
sqlite3 test.db

2、创建数据表

bash 复制代码
sqlite> CREATE TABLE COMPANY(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL
);

3、查看数据表

bash 复制代码
sqlite>.tables
COMPANY     DEPARTMENT

4、查看表结构

bash 复制代码
sqlite>.schema COMPANY
CREATE TABLE COMPANY(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL
);

5、插入表数据

bash 复制代码
sqlite>INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
VALUES (1, 'Paul', 32, 'California', 20000.00 );

sqlite>INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
VALUES (2, 'Allen', 25, 'Texas', 15000.00 );

sqlite>INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );

5、查看表数据

bash 复制代码
sqlite> select * from COMPANY;
1|Paul|32|California|20000.0
2|Allen|25|Texas|15000.0
3|Teddy|23|Norway|20000.0

6、其他指令自行查阅

三、C语言sqlite3接口

1、接口类型和函数

sqlite常用接口函数很少,官网文档可以直接看到

另外还有一些不常用接口拓展函数,感兴趣的可以自己了解:

2、接口分类

我个人将接口分为两类

1)直接操作sql函数(初阶用法,更接近sql命令行)

sqlite3_open()打开数据库

sqlite3_exec()执行sql命令并返回结果

sqlite3_close()关闭数据库

2)sql数据绑定(高阶用法,更方便程序操作)

数据绑定分为查询绑定和插入绑定

sqlite3_prepare() 绑定sql命令

sqlite3_finalize() 结束绑定

sqlite3_reset() 重置绑定

插入绑定:

sqlite3_bind() 设置绑定列数据

sqlite3_step() 切换下一条记录

查询绑定:

sqlite3_column() 返回绑定列数据

sqlite3_step() 切换下一条记录

四、实例代码

1、打开关闭数据库

cpp 复制代码
#include <stdio.h>
#include <sqlite3.h>

int main(int argc, char* argv[])
{
   sqlite3 *db;
   char *zErrMsg = 0;
   int rc;

   rc = sqlite3_open("test.db", &db);

   if( rc ){
      fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
      exit(0);
   }else{
      fprintf(stderr, "Opened database successfully\n");
   }
   sqlite3_close(db);
}

2、执行sql指令

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h> 

static int callback(void *NotUsed, int argc, char **argv, char **azColName){
   int i;
   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;
   char *zErrMsg = 0;
   int  rc;
   char *sql;

   /* Open database */
   rc = sqlite3_open("test.db", &db);
   if( rc ){
      fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
      exit(0);
   }else{
      fprintf(stdout, "Opened 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, callback, 0, &zErrMsg);
   if( rc != SQLITE_OK ){
   fprintf(stderr, "SQL error: %s\n", zErrMsg);
      sqlite3_free(zErrMsg);
   }else{
      fprintf(stdout, "Table created successfully\n");
   }
   sqlite3_close(db);
   return 0;
}

五、文章推荐

避免重复造论子,推荐以下文章:

1、sqlite3_exec()详细用法

深入理解SQLite3之sqlite3_exec及回调函数_vs2015中使用sqlite3数据库求某列的最大值,使用回调函数-CSDN博客

2、sqlite3_bind()数据绑定的插入绑定用法

sqlite3:sqlite3_bind 函数_sqlite3 bind text-CSDN博客

3、sqlite3_column()数据绑定的查询绑定用法

sqlite3:sqlite3_column 函数-CSDN博客

相关推荐
看天走路吃雪糕9 分钟前
墨者:通过手工解决SQL手工注入漏洞测试(PostgreSQL数据库)
数据库·sql·postgresql·sql注入·墨者靶场
-XWB-15 分钟前
【安全漏洞】网络守门员:深入理解与应用iptables,守护Linux服务器安全
linux·服务器·网络
不做无法实现的梦~23 分钟前
mid360连接机载电脑,远程桌面连接不上的情况
运维·服务器·电脑
看天走路吃雪糕43 分钟前
墨者:SQL注入漏洞测试(布尔盲注)
数据库·sql·sqlmap·墨者学院·布尔盲注
*愿风载尘*43 分钟前
ksql连接数据库免输入密码交互
数据库·后端
追风少年浪子彦1 小时前
mybatis-plus实体类主键生成策略
java·数据库·spring·mybatis·mybatis-plus
运维成长记1 小时前
关于linux运维 出现高频的模块认知
运维·职场和发展·云计算
溟洵1 小时前
Qt 窗口 工具栏QToolBar、状态栏StatusBar
开发语言·前端·数据库·c++·后端·qt
kura_tsuki1 小时前
[Linux入门] Linux 远程访问及控制全解析:从入门到实战
linux·服务器·安全
lunz_fly19921 小时前
统信 UOS 安装 svn 指南
linux