C++使用SQLite步骤及示例
开发环境:Windows 10+VS2013。

开发语言:C++。

 

1、 下载sqlite文件。

下载网址:http://www.sqlite.org/download.html

SQLite版本为SQLite 3.11.1,相关文件如下。
sqlite-dll-win32-x86-3110100.zip:包含sqlite3.def、sqlite3.dll文件。
sqlite-amalgamation-3110100.zip:包含sqlite3.h 文件。
sqlite-tools-win32-x86-3110100.zip:包含sqlite3.exe 文件。


2、 生成sqlite3.lib。

 sqlite-dll-win32-x86-3110100.zip文件解压到D:\ sqlite。
 运行Visual Studio 2013 lib命令行程序。
 依次执行控制台命令。

  1. cd D:\sqlite\sqlite-dll-win32-x86-3110100
  2. D:
  3. E:\Microsoft Visual Studio 12.0\VC\bin\lib.exe /def:sqlite3.def /machine:ix86

即可生成sqlite3.lib文件。

3、 创建测试数据。

 sqlite-tools-win32-x86-3110100.zip文件解压到D:\ sqlite。
 启动命令行,进入D:\ sqlite目录。
命令依次为:

  1. cd D:\sqlite
  2. d:

 创建test.db测试文件。
创建user表。

字段Code 字段类型 字段描述
id integer 主键,自增
name varchar(64) 用户名
age integer 年龄

创建命令依次如下。

  1. D:\sqlite>sqlite3.exe test.db
  2. SQLite version 3.7.13 2012-06-11 02:05:22
  3. Enter ".help" for instructions
  4. Enter SQL statements terminated with a ";"
  5. sqlite> create table user
  6. ...> (
  7. ...> id integer primary key autoincrement,
  8. ...> name varchar(64),
  9. ...> age integer
  10. ...> );
  11. sqlite> .quit


4、 创建示例工程

 创建win32控制台工程SQLiteTest。
 sqlite3.h(在sqlite-amalgamation-3071300.zip压缩包中)添加到工程。
 sqlite3.lib复制到工程文件夹下。
 工程属性中添加sqlite3.lib库依赖。
Configuration Properties->Linker->Input->Additional Dependencies添加sqlite3.lib。
 程序代码为:

  1. /*
  2. @brief 本程序测试sqlite数据库的增删改查
  3. @date 2012-09-03
  4. */
  5. // SQLiteTest.cpp : Defines the entry point for the console application.
  6. //
  7. #include "stdafx.h"
  8. #include "sqlite3.h"
  9. #include <iostream>
  10. using namespace std;
  11. sqlite3 * pDB = NULL;
  12. //增加用户
  13. bool AddUser(const string& sName, const string& sAge);
  14. //删除用户
  15. bool DeleteUser(const string& sName);
  16. //修改用户
  17. bool ModifyUser(const string& sName, const string& sAge);
  18. //查找用户
  19. bool SelectUser();
  20. int _tmain(int argc, _TCHAR* argv[])
  21. {
  22. //打开路径采用utf-8编码
  23. //如果路径中包含中文,需要进行编码转换
  24. int nRes = sqlite3_open("D:\\sqlite\\test.db", &pDB);
  25. if (nRes != SQLITE_OK)
  26. {
  27. cout<<"Open database fail: "<<sqlite3_errmsg(pDB);
  28. goto QUIT;
  29. }
  30. //添加“赵钱孙李”
  31. if (    !AddUser("zhao", "18")
  32. || !AddUser("qian", "19")
  33. || !AddUser("sun", "20")
  34. || !AddUser("li", "21"))
  35. {
  36. goto QUIT;
  37. }
  38. //删除“赵”
  39. if (!DeleteUser("zhao"))
  40. {
  41. goto QUIT;
  42. }
  43. //修改“孙”
  44. if (!ModifyUser("sun", "15"))
  45. {
  46. goto QUIT;
  47. }
  48. //查找用户
  49. if (!SelectUser())
  50. {
  51. goto QUIT;
  52. }
  53. QUIT:
  54. sqlite3_close(pDB);
  55. return 0;
  56. }
  57. bool AddUser(const string& sName, const string& sAge)
  58. {
  59. string strSql = "";
  60. strSql += "insert into user(name,age)";
  61. strSql += "values('";
  62. strSql += sName;
  63. strSql += "',";
  64. strSql += sAge;
  65. strSql += ");";
  66. char* cErrMsg;
  67. int nRes = sqlite3_exec(pDB , strSql.c_str() ,0 ,0, &cErrMsg);
  68. if (nRes != SQLITE_OK)
  69. {
  70. cout<<"add user fail: "<<cErrMsg<<endl;
  71. return false;
  72. }
  73. else
  74. {
  75. cout<<"add user success: "<<sName.c_str()<<"\t"<<sAge.c_str()<<endl;
  76. }
  77. return true;
  78. }
  79. bool DeleteUser(const string& sName)
  80. {
  81. string strSql = "";
  82. strSql += "delete from user where name='";
  83. strSql += sName;
  84. strSql += "';";
  85. char* cErrMsg;
  86. int nRes = sqlite3_exec(pDB , strSql.c_str() ,0 ,0, &cErrMsg);
  87. if (nRes != SQLITE_OK)
  88. {
  89. cout<<"delete user fail: "<<cErrMsg<<endl;
  90. return false;
  91. }
  92. else
  93. {
  94. cout<<"delete user success: "<<sName.c_str()<<endl;
  95. }
  96. return true;
  97. }
  98. bool ModifyUser(const string& sName, const string& sAge)
  99. {
  100. string strSql = "";
  101. strSql += "update user set age =";
  102. strSql += sAge;
  103. strSql += " where name='";
  104. strSql += sName;
  105. strSql += "';";
  106. char* cErrMsg;
  107. int nRes = sqlite3_exec(pDB , strSql.c_str() ,0 ,0, &cErrMsg);
  108. if (nRes != SQLITE_OK)
  109. {
  110. cout<<"modify user fail: "<<cErrMsg<<endl;
  111. return false;
  112. }
  113. else
  114. {
  115. cout<<"modify user success: "<<sName.c_str()<<"\t"<<sAge.c_str()<<endl;
  116. }
  117. return true;
  118. }
  119. static int UserResult(void *NotUsed, int argc, char **argv, char **azColName)
  120. {
  121. for(int i = 0 ; i < argc ; i++)
  122. {
  123. cout<<azColName[i]<<" = "<<(argv[i] ? argv[i] : "NULL")<<", ";
  124. }
  125. cout<<endl;
  126. return 0;
  127. }
  128. bool SelectUser()
  129. {
  130. char* cErrMsg;
  131. int res = sqlite3_exec(pDB, "select * from user;", UserResult , 0 , &cErrMsg);
  132. if (res != SQLITE_OK)
  133. {
  134. cout<<"select fail: "<<cErrMsg<<endl;
  135. return false;
  136. }
  137. return true;
  138. }

 编译成功后,将sqlite3.dll复制到SQLiteTest.exe同一目录下,运行SQLiteTest.exe。
运行结果:

  1. add user success: zhao  18
  2. add user success: qian  19
  3. add user success: sun   20
  4. add user success: li    21
  5. delete user success: zhao
  6. modify user success: sun        15
  7. id = 2, name = qian, age = 19,
  8. id = 3, name = sun, age = 15,
  9. id = 4, name = li, age = 21,

5、 SQLite管理工具

可视化管理工具,推荐使用:SQLite Expert,见:http://www.sqliteexpert.com/

  1. #include "stdafx.h"
  2. #include <stdio.h>
  3. #include "sqlite3.h"
  4. #include <process.h>
  5. #pragma comment(lib,"sqlite3.lib")
  6.  
  7. static int callback(void *NotUsed, int argc, char **argv, char **azColName){
  8. int i;
  9. for(i=; i<argc; i++){
  10. printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
  11. }
  12. printf("\n");
  13. return ;
  14. }
  15.  
  16. int _tmain(int argc, char* argv[])
  17. {
  18. sqlite3 *db;
  19. char *zErrMsg = ;
  20. int rc;
  21.  
  22. if( argc!= ){
  23. fprintf(stderr, "Usage: %s DATABASE\n", argv[]);
  24. system("pause");
  25. return();
  26. }
  27. rc = sqlite3_open(argv[], &db);
  28. if( rc ){
  29. fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
  30. sqlite3_close(db);
  31. return();
  32. }
  33.  
  34. //char* sqlstatement = "create table test(int id,varchar name);";
  35. //char* sqlstatement = "insert into test values(1,'hello');";
  36. char* sqlstatement = "select * from test;";
  37. rc = sqlite3_exec(db, sqlstatement, callback, , &zErrMsg);
  38. if( rc!=SQLITE_OK ){
  39. printf("%s\n",argv[]);
  40. fprintf(stderr, "SQL error: %s\n", zErrMsg);
  41. sqlite3_free(zErrMsg);
  42. }
  43. sqlite3_close(db);
  44.  
  45. system("pause");
  46. return ;
  47. }

C++使用SQLite步骤及示例的更多相关文章

  1. PyQt(Python+Qt)学习随笔:工具箱(QToolBox)编程使用的步骤及示例代码

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 使用toolBox开发应用时,通过Designer设计ui界面时,只能在Designer中设计too ...

  2. Android SQLite(1)简单示例-增,删,改,查

    1.主要核心类,Sqlite编程要继承SQLiteOpenHelper import android.content.Context; import android.database.sqlite.S ...

  3. Sqlite的操作示例代码

    import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.databa ...

  4. android Api操作SQLite数据库的示例代码

    import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.databa ...

  5. 用SQL语句操作Sqlite数据库的示例代码

    import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.databa ...

  6. JNI 详细使用步骤 上手示例

    1.定义本地native方法 定义本地方法,通常情况下,应单独定义一个类来封装所有native方法 /** 存放native方法的类 */ public class MyNativeMethods { ...

  7. python使用sqlite示例

    SQLite是一种嵌入式数据库,它的数据库就是一个文件.Python就内置了SQLite3,所以,在Python中使用SQLite,不需要安装任何东西,直接使用. 操作关系数据库,首先需要连接到数据库 ...

  8. SQLite -- 分页查询

    原文:http://blog.csdn.net/lu1024188315/article/details/51734514 参考:http://www.runoob.com/sqlite/sqlite ...

  9. C#操作SQLite数据库

    SQLite介绍 SQLite is a software library that implements a self-contained, serverless, zero-configurati ...

随机推荐

  1. C++ delete 两次

    转载自:http://blog.csdn.net/jxluofeng/article/details/19766801 <问题>危险的代码: int* p=new int(1);   de ...

  2. 华为上机测试题(表达式运算-java)

    PS:自己写的,自测试OK,供大家参考. 补充:数据解析的过程,评论区有更好的处理方式,可参考. /* * 输入一个表达式,3*8+7-2,没有括号 输出结果 */ /* 本程序暂不考虑容错处理 */ ...

  3. Kubernetes监控工具

    #镜像在谷歌上需要FQ#####################################监控工具#当前最新版本 heapster https://github.com/kubernetes/h ...

  4. List的set和add方法

    问题描述:[相机]打开记录拍摄地理位置后拍照详情中少“宽度”属性; 原因分析:在listview动态刷新时用set(index,elemet)方法替换了宽度及其值: 解决方法:改为add(index, ...

  5. C#实时读取数据----局部页面刷新【转】

    I)现在刚开始学习C#,对一些基本的控件了解的不够,有个实时监控的系统,需要页面中的数据每5秒钟刷新一次, 要是每5秒钟页面全部的刷新,那页面根本就没法看了,对这个问题在CSDN上也专门开了帖子,问了 ...

  6. java获取当前类名和方法名

    Description Below I present you two different ways to get the current Class: Using Thread Using getC ...

  7. 达梦数据库CAST与ROUND函数

    https://blog.csdn.net/zry1266/article/details/50856260

  8. VS217下载码云服务器项目

    按下图打开VS2017团队资源管理器的管理连接 ,本地GIT存储库下面输入远程GIT存储库URL地址和保存到本地的地址即可将远程项目下载到本地,下载完成后,关闭VS2017重新打开这个项目就可以进行源 ...

  9. Codeforces Round #306 (Div. 2) A. Two Substrings【字符串/判断所给的字符串中是否包含不重叠的“BA” “AB”两个字符串】

    A. Two Substrings time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  10. 2018 JUST Programming Contest 1.0 题解

    题目链接  gym101778 Problem A 转化成绝对值之后算一下概率.这个题有点像 2018 ZOJ Monthly March Problem D ? 不过那个题要难一些~ #includ ...