老师最近给的上机题目有点变态,特别是写到最后,是需要写学生管理系统。如果C语言结合文件来操作的话,估计会比较麻烦(对文件里字符串的增删改查我都没有什么好点的算法)。那就用数据库吧,我很自然的想到。

前几天研究了Mysql与VC的交互,利用微软ODBC里面的一些API可以对数据库进行访问。不过用Mysql写这种小软件感觉还是太大,而且如果一台电脑既没联网也没安装MYSQL就不能使用我的程序了,所以我想找一款能嵌入程序里的数据库。

sqlite就是一个嵌入式的轻型数据库,感觉与这种作业类型的题目真是天作之合。到时候提交给老师就是一个exe文件和一个db文件,老师就可以直接看到我的程序和运行结果~(笑)

废话不多说(感觉自己太罗嗦了),我写这篇文章目的不是为了介绍C语言里sqlite的API(因为我自己现在暂时也没一一看过),而是先说说如何让VC和sqlite库连接起来(不连接怎么使用库里的函数)。

官方提供了源文件的下载,我们就把源文件下载下来:sqlite-amalgamation-3071502.zip,下下来后解压发现里面有四个文件,"sqlite3.h"、"sqlite3.c"、"sqlite3ext.h"、"shell.c"。

好,我们现在开始制作一个叫静态的lib文件,做好了告诉你有什么用:


1.用VC(我用是VS2010)创建一个dll工程(我的就叫dll),即点击 文件 - 新建 - 项目 - win32项目 - dll(D) - 空项目

2.将"sqlite3.h"、"sqlite3.c"、"sqlite3ext.h"拷贝到工程目录下,再一一添加到工程里,即点击 工程 - 添加 - 现有项

3.以Release编译sqlite3.c,生成了dll文件,不过我们不用它。找到工程文件夹\dll\Release\sqlite3.obj,我们需要它!

4.来到VS2010的安装目录下的VC\BIN目录(我的是D:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\bin),把这个obj文件拷贝进去。再来到\Microsoft Visual Studio 10.0\Common7\IDE文件夹,找到其中的mspdb100.dll,mspdbcore.dll,mspdbsrv.exe,msobj100.dll文件,也拷贝到bin目录下。

5.在bin目录下运行cmd,执行命令lib sqlite3.obj,完成obj的编译,生成一个2M多的sqlite3.lib文件,这就是我们的静态lib文件!!

6.最后删除复制到bin文件夹下的dll文件(重要),我们只要这个sqlite3.lib.


拿到了lib文件就好用了,以后写连接数据库的程序,只用把这个lib文件复制到工程目录下,并添加 - 新建项,选择这个lib文件。最后在代码里#include "sqlite3.h"(sqlite3.h在已经sqlite3.lib里,不用再把sqlite3.h拷贝到工程文件下)。

现在就能用sqlite里面的API了~~

到时候交作业直接把编译生成的exe文件和你的数据库文件xxx.db放在一起,其他人就能直接点击exe文件运行了。

VC++下使用SQLite数据库的更多相关文章

  1. 在4.0框架下使用Sqlite数据库

    在4.0框架下使用Sqlite数据库出现"混合模式程序集是针对"v2.0.50727"版的运行时生成的,在没有配置其他信息的情况下,无法在 4.0 运行时中加载该程序集. ...

  2. 无废话Android之android下junit测试框架配置、保存文件到手机内存、android下文件访问的权限、保存文件到SD卡、获取SD卡大小、使用SharedPreferences进行数据存储、使用Pull解析器操作XML文件、android下操作sqlite数据库和事务(2)

    1.android下junit测试框架配置 单元测试需要在手机中进行安装测试 (1).在清单文件中manifest节点下配置如下节点 <instrumentation android:name= ...

  3. Android 使用存放在存assets文件夹下的SQLite数据库

    因为这次的项目需要自带数据,所以就就把数据都放到一个SQLite的数据库文件中了,之后把该文件放到了assets文件夹下面.一开始打算每次都从assets文件夹下面把该文件夹拷贝到手机的SD卡或者手机 ...

  4. windows 下创建 sqlite 数据库

    说明:windows 下执行创建 sqlite 数据库命令后数据库文件不会马上生成,需要创建表以后才会生成. 1.将 sqlite3.exe 文件放在任何位置(如放在 d:\tools )2.在 CM ...

  5. 42、使用存放在存assets文件夹下的SQLite数据库

    因为这次的项目需要自带数据,所以就就把数据都放到一个SQLite的数据库文件中了,之后把该文件放到了assets文件夹下面.一开始打算每次都从assets文件夹下面把该文件夹拷贝到手机的SD卡或者手机 ...

  6. Android下利用SQLite数据库实现增删改查

    1: 首先介绍如何利用adb查看数据库 1: adb shell 2: cd /data/data/包名/databases 3:  sqlite3 数据库 4   接下来就可以进行数据库的sql语法 ...

  7. Android下的SQLite数据库的相关操作及AndroidTestCase测试

    一:创建数据库 package com.itcode.mysqlite; import android.content.Context; import android.database.sqlite. ...

  8. 在Android中afinal框架下实现sqlite数据库版本升级的办法

    上一篇文章采用的是SQLiteOpenHelper中的onUpgrade方法实现数据库的升级. 首先获取Context: private Context mContext=this; 然后实现Fina ...

  9. Android下用Sqlite数据库存储数据

    第一步:  写个类 ,继承 SQLiteOpenHelper public class MyDatabaseOpenHelper extends SQLiteOpenHelper { } 第二步:   ...

随机推荐

  1. win7下安装搭建PHP环境

    由于最近新找的工作要求php,所以在电脑上安装搭建了PHP环境.主要参考了这篇文章http://www.leapsoul.cn/?p=695(之前第一次搭建时由于版本问题没有弄好) 1.先装apach ...

  2. 汉诺塔问题C++实现

    大家好,我是小鸭酱,博客地址为:http://www.cnblogs.com/xiaoyajiang 以下进行汉诺塔问题的递归实现 #include <iostream.h> int gb ...

  3. Java添加自定义注解

    今天在整合MyBatis过程中,我使用扫描的方式去扫描DAO目录下的Java文件,但是在Service层使用Autowired的时候报错,但是工程能正常运行,此处有Bug! 解决方案: 1.创建 an ...

  4. contentInset,contentsize和contentOffset区别

    contentInset,contentsize和contentOffset区别   今天看别人用到了contentInset,觉得很迷糊,于是gogle了一下,搜到了一篇分析的很好的文章,转在这里, ...

  5. zlog使用手册,小靠谱啊

    http://hardysimpson.github.io/zlog/UsersGuide-CN.html Chapter 1 zlog是什么? zlog是一个高可靠性.高性能.线程安全.灵活.概念清 ...

  6. [POJ] 1274 The Perfect Stall(二分图最大匹配)

    题目地址:http://poj.org/problem?id=1274 把每个奶牛ci向它喜欢的畜栏vi连边建图.那么求最大安排数就变成求二分图最大匹配数. #include<cstdio> ...

  7. repo sync 时的自动续接脚本[转]

    按理说在repo init  ....之后使用repo sync就可以开始下载源码了,但是在下载过程中经常会出现没网速“死”的情况.当然,我修改了/etc/hosts文件之后就再也么有死过.在没网速提 ...

  8. 树莓派入门教程——使用Qt开发界面程序

    前言        Qt是一个1991年由奇趣科技开发的跨平台C++图形用户界面应用程序开发框架.它既可以开发GUI程序,也可用于开发非GUI程序,比如控制台工具和服务器.Qt是面向对象的框架,使用特 ...

  9. C++11 in Qt5

    本文转载自:http://woboq.com/blog/cpp11-in-qt5.html   C++11 in Qt5 Posted by Olivier Goffart on 11 June 20 ...

  10. B树叶子节点split

    一.B-Tree索引的分裂 1. 创建测试表 SQL> create table split_tab (id number, name varchar2(100)); 表已创建. SQL> ...