sqlite安装与封装后编译
========================安装sqlite=================
官网下载安装包*.tar.gz格式
./configure --prefix=/usr/server/sqlit 安装包目录
make
make install
测试安装成功 sqlite3 test.db
=======================编译====================
编译时 加入参数 -I /usr/server/sqlite/include
-L /usr/server/sqlite/lib
如果编译为静态 则 -static
gcc db.c test.c -o main -I /usr/server/sqlite/include -L /usr/server/sqlite/lib -lsqlite3
=======================源程序=================
网上找的
test.c
/*****************
对sqlite封装函数的测试
名称:test.c
*********************************/
#include <stdio.h>
#include "db.h"
int main(int argc, char *argv[])
{
char *dbname="dtmsg.db";
sqlite3 *db;
int iReturn=DbOpenDatabase(dbname,&db);
printf("-0->打开返回值%d<---\n",iReturn);
if(iReturn==1)
{
//新建table t_msg
char *sql="create table t_msg(msg,msg_buff)";
printf("-1-->新建sql语句 %s<--\n",sql);
int cReturn=DbChangeDataRecord(db,sql);
if (cReturn==-1)
return 0;
printf("-1-->执行新建返回值 %d<--\n",cReturn);
//增加、修改、删除
sql="insert into t_msg values ('test','测试信息11')";
//char * sql="update t_msg set msg_buff='测试信息2222222' where msg='test'";
//char * sql="delete from t_msg where msg='test'";
printf("-2-->%s<--\n",sql);
int iSqlRet=DbChangeDataRecord(db,sql);
printf("-3-->%d<--\n",iSqlRet); //查询
sql="select * from t_msg";
char **dbResult;
int nRow,nColumn,index;
int i,j;
int iQret=DbExecuteQuerySql(db,sql,&dbResult,&nRow,&nColumn);
if(iQret==1)
{
index=nColumn;
for( i = 0; i < nRow ; i++ )
{
printf( "第====================> %d 条记录\n", i+1 );
for( j = 0 ; j < nColumn; j++ )
{
printf( "字段名:%s ==>字段值:%s\n", dbResult[j],dbResult[index]?dbResult[index]:"" );
++index;
}
}
}
//不论数据库查询是否成功,都释放 char** 查询结果,使用 sqlite 提供的功能来释放
//sqlite3_free_table( dbResult );
DbFreeResources(dbResult);
}
DbCloseDatabase(db);
return 1;
}
db.c
/*************************************************
File name: db.c
Description: C语言查询sqlite3数据库的基本操作封装
Others: 需要sqlite3的动态库 gcc -o db db.c -lsqlite3
*************************************************/
#include "db.h" /*************************************************
Function: DbOpenDatabase
Description: 打开sqlite3数据库
Input: strDbName:数据库名称;hDbCon:sqlite3的句柄
Output: 无
Return: 1,数据库打开成功;0,数据库打开失败
Others: 无
*************************************************/
int DbOpenDatabase(char *strDbName, sqlite3 **hDbCon)
{
int iRet = sqlite3_open(strDbName,hDbCon); //打开数据库
if(iRet != SQLITE_OK)
{
return 0;
}
else
{
return 1;
}
}
/*************************************************
Function: DbCloseDatabase
Description: 关闭sqlite3数据库
Input: hDbCon:sqlite3的句柄
Output: 无
Return: 无
Others: 无
*************************************************/
void DbCloseDatabase(sqlite3 *hDbCon)
{
sqlite3_close(hDbCon);
}
/*************************************************
Function: DbChangeDataRecord
Description: 向数据库进行插入、修改、删除操作
Input: hDbCon:sqlite3的句柄; strSql:sql语句;
Output: 无
Return: -1,插入(或修改或删除)失败;
大于-1,执行sql后,返回响应的行数
Others: 无
*************************************************/
int DbChangeDataRecord(sqlite3 *hDbCon,char *strSql)
{
char *pErrMsg = 0; //错误信息
int iRet = sqlite3_exec(hDbCon, strSql, NULL, NULL, &pErrMsg);
if(iRet != SQLITE_OK)
{
printf("查询失败,错误码==>:%d,错误原因==>:%s\n", iRet, pErrMsg);
return -1;
}
else
{
return iRet;
}
} /*************************************************
Function: DbExecuteQuerySql
Description: 查询数据库中的记录集
Input: hDbCon:sqlite3的句柄;strSql:sql语句;
Output: strResult:结果集;iRow:行;iColumn:列;
Return: 1,查询成功;0,查询失败
Others: 无
*************************************************/
int DbExecuteQuerySql(sqlite3 *hDbCon,
char *strSql,
char ***strResult,
int *iRow,
int *iColumn)
{
char *pErrMsg = NULL; //错误日志
int iReturn = 0;
int iResult = sqlite3_get_table( hDbCon,strSql, strResult, iRow, iColumn, &pErrMsg );
if( SQLITE_OK == iResult )
{
iReturn = 1;
}
else
{
iReturn = 0;
}
return iReturn;
}
/*************************************************
Function: DbFreeResources
Description: 不论数据库查询是否成功,都释放 char**
查询结果,使用 sqlite 提供的功能来释放
Input: strResult:结果集
Output: 无
Return: 无
Others: 无
*************************************************/
void DbFreeResources(char **strResult)
{
sqlite3_free_table( strResult );
}
db.h
/*************************************************
File name: db.h
Description: C语言查询sqlite3数据库的基本操作封装
Others: 无
*************************************************/ #ifndef DB_H
#define DB_H #include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sqlite3.h> /*************************************************
Function: DbOpenDatabase
Description: 打开sqlite3数据库
Input: strDbName:数据库名称;hDbCon:sqlite3的句柄
Output: 无
Return: 1,数据库打开成功;0,数据库打开失败
Others: 无
*************************************************/
int DbOpenDatabase(char *strDbName, sqlite3 **hDbCon); /*************************************************
Function: DbCloseDatabase
Description: 关闭sqlite3数据库
Input: hDbCon:sqlite3的句柄
Output: 无
Return: 无
Others: 无
*************************************************/
void DbCloseDatabase(sqlite3 *hDbCon); /*************************************************
Function: DbChangeDataRecord
Description: 向数据库进行插入、修改、删除操作
Input: hDbCon:sqlite3的句柄; strSql:sql语句;
Output: 无
Return: -1,插入(或修改或删除)失败;
大于-1,执行sql后,返回响应的行数
Others: 无
*************************************************/
int DbChangeDataRecord(sqlite3 *hDbCon,char *strSql); /*************************************************
Function: DbExecuteQuerySql
Description: 查询数据库中的记录集
Input: hDbCon:sqlite3的句柄;strSql:sql语句;
Output: strResult:结果集;iRow:行;iColumn:列;
Return: 1,查询成功;0,查询失败
Others: 无
*************************************************/
int DbExecuteQuerySql(sqlite3 *hDbCon,
char *strSql,
char ***strResult,
int *iRow,
int *iColumn); /*************************************************
Function: DbFreeResources
Description: 不论数据库查询是否成功,都释放 char**
查询结果,使用 sqlite 提供的功能来释放
Input: strResult:结果集
Output: 无
Return: 无
Others: 无
*************************************************/
void DbFreeResources(char **strResult); #endif
/* Others: 需要sqlite3的动态库 gcc -o db db.c ./libsqlite3.so //还没弄懂
或 gcc -o db db.c -lsqlite3 //还没弄懂
*************************************************/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sqlite3.h> int DbOpenDatabase(char *strDbName, sqlite3 **hDbCon)
{
int iRet = sqlite3_open(strDbName,hDbCon); //打开数据库
if(iRet != SQLITE_OK)
{
return 0;
}
else
{
return 1;
}
} void DbCloseDatabase(sqlite3 *hDbCon)
{
sqlite3_close(hDbCon);
} int DbChangeDataRecord(sqlite3 *hDbCon,char *strSql)
{
char *pErrMsg = 0; //错误信息
int iRet = sqlite3_exec(hDbCon, strSql, NULL, NULL, &pErrMsg);
if(iRet != SQLITE_OK)
{
//printf("查询失败,错误码==>:%d,错误原因==>:%s\n", ret, errmsg );
return -1;
}
else
{
return iRet;
}
} int DbExecuteQuerySql(sqlite3 *hDbCon,
char *strSql,
char ***strResult,
int *iRow,
int *iColumn)
{
char *pErrMsg = NULL; //错误日志
int iReturn = 0;
int iResult = sqlite3_get_table( hDbCon,strSql, strResult, iRow, iColumn, &pErrMsg );
if( SQLITE_OK == iResult )
{
iReturn = 1;
}
else
{
iReturn = 0;
}
return iReturn;
} void DbFreeResources(char **strResult)
{
sqlite3_free_table( strResult );
} int DbSqliteCallBack(sqlite3 * hDbCon,const char *strSql,int (*QueryResultBack)())
{
char *pErrMsg;
int iRetDb = 0;
iRetDb = sqlite3_exec(hDbCon,strSql,QueryResultBack,NULL,&pErrMsg);
if(iRetDb != SQLITE_OK)
{
return 0;
}
return 1;
} //回调函数例子测试
/*static int QueryResultBack(void *para,int iColumn,char **cValue,char **cColumnValueName)
{
int iCn;
for(iCn = 0; iCn < iColumn; iCn++)
{
//printf( "%s = %s\n" , cColumnValueName[i], cValue[i] ? cValue[i] : "NULL" );
printf( "%s = %s\n" , cColumnValueName[i], cValue[i]);
}
return 0;
}*/ int main(int argc, char *argv[])
{
char *dbname="dtmsg.db";
sqlite3 *db;
int iReturn=DbOpenDatabase(dbname,&db);
printf("-1->%d<---\n",iReturn);
if(iReturn==1)
{
//增加、修改、删除
char *sql="insert into t_msg (msg,msg_buff) values ('test','测试信息11')";
//char * sql="update t_msg set msg_buff='测试信息2222222' where msg='test'";
//char * sql="delete from t_msg where msg='test'";
printf("-2-->%s<--\n",sql);
int iSqlRet=DbChangeDataRecord(db,sql);
printf("-3-->%d<--\n",iSqlRet); //查询
//char *sql="select * from t_msg";
sql="select * from t_msg";
char **dbResult;
int nRow,nColumn,index;
int i,j;
int iQret=DbExecuteQuerySql(db,sql,&dbResult,&nRow,&nColumn);
if(iQret==1)
{
index=nColumn;
for( i = 0; i < nRow ; i++ )
{
printf( "第====================> %d 条记录\n", i+1 );
for( j = 0 ; j < nColumn; j++ )
{
printf( "字段名:%s ==>字段值:%s\n", dbResult[j],dbResult[index]?dbResult[index]:"" );
++index;
}
}
}
//不论数据库查询是否成功,都释放 char** 查询结果,使用 sqlite 提供的功能来释放
//FreeResources(dbResult);
sqlite3_free_table( dbResult );
}
DbCloseDatabase(db);
return 1;
}
sqlite安装与封装后编译的更多相关文章
- SQLite安装、编译与应用
什么是 SQLite SQLite是一款轻量级的.基于文件的嵌入式数据库,实现自包容.零配置.支持事务的SQL数据库引擎.与其他数据库管理系统不同,SQLite 的安装和运行非常简单,在大多数情况下, ...
- sqlite 安装与编译
本文简述了SQLite的概念,并详细描述了SQLite在Linux和Windows平台下的编译方法 关于 SQLite SQLite是一个进程内的库,实现了自给自足的.无服务器的.零配置的.事务性的 ...
- C++第三十四篇 -- 安装Windows Driver后,编译以前项目出现打不开lib文件
VS2017默认是没有安装WDK的,但是我们写驱动文件的话需要用到WDK.不过安装了WDK后,发现以前一些正常的项目在Release模式下编译会报LINK1104,无法打开.lib的错误 针对这个错误 ...
- Senparc.Weixin.MP SDK 微信公众平台开发教程(二十二):如何安装 Nuget(dll) 后使用项目源代码调试
最近碰到开发者问:我使用 nuget 安装了 Senparc.Weixin SDK,但是有一些已经封装好的过程想要调试,我又不想直接附加源代码项目,这样就没有办法同步更新了,我应该怎么办? 这其实是一 ...
- sass安装:webpack sass编译失败,node-sass安装失败的终极解决方
文章来源:sass安装:webpack sass编译失败,node-sass安装失败的终极解决方 sass难言之隐-sass安装的坑 之前花了很多时间折腾node-sass,发现sass老是安装不上 ...
- 安装好php后,配置httpd以便支持php3脚本
Apache是目前应用最广的Web服务器,PHP是一种类似ASP的易学的脚本语言,而且性能和功能都比ASP要强,而MySQL又是一个Linux上应用最多的数据库系统,特别是用于网站建设,这3个软件均是 ...
- C++ 升级到 Vs2013后编译设置
编译 EasyDarwin 时,Vs2008的C++升级到 Vs2013时报错: 1. 找不到 windows.h 项目->属性->配置属性->C/C++->所有选项: 附加包 ...
- 在VirtualBox中安装了Ubuntu后,Ubuntu的屏幕分辨率非常小,操作非常不便。通过安装VirtualBox提供的“增强功能组件”,-摘自网络
在VirtualBox中安装了Ubuntu后,Ubuntu的屏幕分辨率非常小,操作非常不便.通过安装VirtualBox提供的“增强功能组件”,可以解决这一问题,并且使用非常方便. 一.环境 | En ...
- 基于gulp编写的一个简单实用的前端开发环境好了,安装完Gulp后,接下来是你大展身手的时候了,在你自己的电脑上面随便哪个地方建一个目录,打开命令行,然后进入创建好的目录里面,开始撸代码,关于生成的json文件请点击这里https://docs.npmjs.com/files/package.json,打开的速度看你的网速了注意:以下是为了演示 ,我建的一个目录结构,你自己可以根据项目需求自己建目
自从Node.js出现以来,基于其的前端开发的工具框架也越来越多了,从Grunt到Gulp再到现在很火的WebPack,所有的这些新的东西的出现都极大的解放了我们在前端领域的开发,作为一个在前端领域里 ...
随机推荐
- b站视频下载技术分享
最近无聊分析了一下b站的视频流协议,简单分享下爬取的流程. 首先先要找到视频对应的aid和cid,aid就相当于av号,而av号对应网页下的每一个视频都有对应的cid,普通视频就是分p,番剧就是集数, ...
- hdp、cdh版本大数据maven仓库
Hdp版本: <repositories> <repository> <id>nexus</id> <name>local private ...
- Apache伪静态(Rewrite).htaccess文件详解
Htaccess(超文本访问)是一个简单的配置文件,它允许设计师,开发者和程序员通过它来改变Apache Web服务器的配置.这些功能包括用户重定向.URL重写(url rewrite,国内很多称为伪 ...
- EasyUI 表单插件 multiline easyui-textbox 多行换行失效问题
1.问题描述:原始html: <input class="easyui-textbox" name="myname" id="myid" ...
- TR2021_0000偶发数据库连接异常问题排查
[问题描述] 数据库连接异常是很难排查的一类问题.因为它牵涉到应用端,网络层和服务器端.任何一个组件异常,都会导致数据库连接失败.开发遇到数据库连接不上的问题,都会第一时间找DBA来协助查看,DBA除 ...
- 最新最简洁Spring Cloud Oauth2.0 Jwt 的Security方式
因为Spring Cloud 2020.0.0和Spring Boot2.4.1版本升级比较大,所以把我接入过程中的一些需要注意的地方告诉大家 我使用的版本是Spring boot 2.4.1+Spr ...
- session、cookie、token的区别
从安全性优先级来说: 1.优先级 Cookie<session<token 2. 安全性 Cookie: ①cookie不是很安全,别人可以分析存放在本地的cookie并进行cookie欺 ...
- MyBatis初级实战之三:springboot集成druid
OpenWrite版: 欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kuber ...
- 电子邮箱、邮件地址、网站地址正则表达式!几个有用的RE、regex、regexp!
几个常用的正则表达式! r"\w[-\w\.]*@\w[-\w]*(\.\w[-\w]*)+" 这个是电子邮件地址的. r"<TAG\b[^>]*<(. ...
- kubernets之secret资源
一 对于一些保密度比较高的文件,k8s又是如何存储的呢? 针对那些保密度比较高的配置文件,例如证书以及一些认证配置不能直接存储在configmap中,而是需要存储在另外一种资源中,需要对存储在里面的 ...