sqlite3数据库封装 - 动态链接库

时间:2022-07-23
本文章向大家介绍sqlite3数据库封装 - 动态链接库,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

东西在这儿 提取码:y2rz

操作说明:

安装

这里给两种方法。 不弄动态加载库。 ①同项目工程文件夹形式

将资源文件放在当前项目工程文件下,编译指令:g++ *.cpp -o name -L./ -lmydb //名字自己起 ②第三方库形式

这里不建议放在系统库底下,也不建议将头文件放在系统头文件目录下,系统有给我们提供第三方文件夹。 将.so文件放到 /usr/local/lib下,将.h文件放到/usr/local/include下,不然肯定会找不到头文件。 然后运行指令 ldconfig,刷新系统对第三方库的纪录,不然可能会找不到库。 然后,就可以向使用系统库一样使用这个第三方库。g++ *.cpp -o name -lmydb

库接口

这个库虽然文件少,但是接口比之前的线程池要多。

在test.cpp文件(测试文件)中有完整的使用示例了。但是我还是要哔哔两句。

初始化单例对象

由于数据库使用的是单例类模式,所以初始化数据库对象只能使用static DB* instance(“数据库名”)函数。 这里建议:建库建表工作独立出来,不然会直接报库/表已存在的错而直接退出。 改是可以改的,但是性价比不高,我就不改了,反正代码都给你了。

调用数据库

//总调度语句
void execute(char* order);//需要整条语句传入
int return_serch_num(char *sql);//返回查询结果数
int ireturn_serch(char *sql,int n);//获取查询结果(一行中某个数据)
char* creturn_serch(char *sql,int n);//获取查询结果(一行中某个数据)
int ireturn_multi_serch(char *sql,int r,int c); //获取查询结果(二维表中某个数据)
//r是Row,列;n是Colmn,行
  char* creturn_multi_serch(char *sql,int r,int c); //获取查询结果(二维表中某个数据)