关闭

VC连接SQLite3的方法(MFC封装类)

标签: sqlitemfc数据库listwrapperreport
26427人阅读 评论(60) 收藏 举报
分类:

SQLite,是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,支持跨平台,操作简单,能够使用很多语言直接创建数据库。
官方网站:www.sqlite.org

在VC环境下编写连接SQLite的方法,网上有很多种,自己试验了其中一种,感觉还不错,下面记录下来,使用到的文件包括官方网站下载的文件和CodeProject上的SQLite3Wrapper封装(http://www.codeproject.com/KB/windows/SQLite3Wrapper.aspx)

测试环境:Windows 7
编程环境:Visual Studio 2008 SP1
第一步:新建基于对话框的工程,名称为SQLiteTest;
第二步:添加sqlite3.h、sqlite3i.h、DbSqlite.h、DbSqlite.cpp四个文件到工程;
第三步:在对话框上添加两个按钮,一个LIST列表控件,修改其VIEW属性为report,为其添加变量m_ListCtrl
第四步:把“w32SQLite3.lib”放到工程的目录下,右键点击解决方案里面项目的“属性”,在“链接器”的“输入”的“附加依赖项”填入“w32SQLite3.lib”;
第五步:在对话框的实现文件里面添加头文件

#include "DbSQLite.h" 

第六步:“创建一张表”按钮的代码:

void CSQLiteTestDlg::OnBnClickedCreateButton() 

    bool fTest; 
    CDbSQLite sqlite; 
    //连接打开SQLite数据库 
    fTest = sqlite.Open(_T("theTestSqlite.db")); 
    if (!fTest) 
    { 
        AfxMessageBox(_T("打不开theTestSqlite.db")); 
        return
    } 
    //执行创建表语句 
    fTest = sqlite.DirectStatement(_T("CREATE TABLE usersInfo(name varchar(30), password varchar(20))")); 
    if (!fTest) 
        AfxMessageBox(_T("不能创建表usersInfo")); 
    //新增数据 
    CString szQuery; 
    szQuery = _T("INSERT INTO usersInfo VALUES ('xiaoWang','123')"); 
    fTest = sqlite.DirectStatement(szQuery); 
    if (!fTest) 
        AfxMessageBox(_T("插入数据失败!")); 
    szQuery = _T("INSERT INTO usersInfo VALUES ('daWang','322')"); 
    fTest = sqlite.DirectStatement(szQuery); 
    if (!fTest) 
        AfxMessageBox(_T("插入数据失败!")); 
    AfxMessageBox(_T("创建表成功,插入数据成功!")); 

第七步:“预览数据”按钮的代码:

void CSQLiteTestDlg::OnBnClickedLookButton() 

    BOOL fTest; 
    CDbSQLite sqlite; 
    fTest = sqlite.Open(_T("theTestSqlite.db")); 
    if (!fTest) 
    { 
        AfxMessageBox(_T("打不开theTestSqlite.db")); 
        return
    } 
    CSqlStatement *stmt = sqlite.Statement(_T("SELECT * FROM usersInfo")); 
    //当数据不为空的时候,填充LIST控件 
    if (stmt != NULL) 
    { 
        m_ListCtrl.DeleteAllItems();  //清除LIST项 
        while(m_ListCtrl.DeleteColumn(0));//清除LIST列项 
        CRect rect; 
        m_ListCtrl.GetWindowRect(&rect);  //获得LIST控件大小 
        int nFields = stmt->Fields();  //取得数据库表的列数 
        int nWidth = (rect.Width() - rect.Width() * 0.02) / nFields; //平均分布列数 
        int nCol = 0
        int nRow = 0
        CString szText; 
        for(nCol = 0; nCol < nFields; nCol++) 
        { 
            szText = stmt->FieldName(nCol);        //得到列名 
            m_ListCtrl.InsertColumn(nCol, szText, LVCFMT_LEFT, nWidth, nCol); 
        } 
        while (stmt->NextRow()) 
        { 
            szText = stmt->ValueString(0);        //得到列值 
            m_ListCtrl.InsertItem(nRow, szText); 
            for(nCol = 1; nCol < nFields; nCol++) 
            { 
                szText = stmt->ValueString(nCol); //得到列值 
                m_ListCtrl.SetItem(nRow, nCol, LVIF_TEXT, szText, 0000); 
            } 
            ++nRow; 
        } 
    } 
    delete stmt;
    UpdateData(FALSE); 

 

第八步:把“w32SQLite3.dll”放到Debug文件夹下。
完成,编译程序,结果如下图所示:


示例下载http://download.csdn.net/source/2753306

0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

SQLite在VC环境下的使用

SQLite在VC环境下的使用涉及到单例模式、SQLite的C++接口、编码转换等,这里提供一个自以为比较完善的解决方案以供参考,欢迎拍砖指导。 注:编程环境VS2012,以动态链接方式使用SQLit...
  • pigautumn
  • pigautumn
  • 2016-08-23 14:46
  • 2343

在vc2008 mfcC++中使用sqlite的示例

http://owlman.org/?p=890 在C++中使用sqlite的示例 2011年8月5日admin发表评论阅读评论 最近因为工作原因,终于使我有机会腾出...
  • ysysbaobei
  • ysysbaobei
  • 2012-10-19 09:54
  • 7069

关于vs2010中mfc使用sqlite3

今天写下关于vs2010中mfc使用sqlite3的文章,本人水平有限,有错或改进的,尊请各位看官指出啊^_^。 不费话,不多说,有关sqlite的详细可以百度、google哈。本文是讲如何连接...
  • hjd321123
  • hjd321123
  • 2017-02-08 15:52
  • 291

vs2010中mfc使用sqlite3

  • 2013-08-18 16:14
  • 355KB
  • 下载

MFC中SQLite数据库的使用

1打开数据库 BOOL playDlg::openData() {  WCHAR a[100];  CString path;  path = m_exePath+L"sentence_ma...
  • chentongxin321
  • chentongxin321
  • 2013-11-26 18:01
  • 958

VC连接SQLite3的方法(MFC封装类)

 www.sqlite.org。 --》Download进入下载页面-“Precompiled Binaries for Windows”,选择sqlite-shell-win32-x86-...
  • lys07962000
  • lys07962000
  • 2014-09-17 10:44
  • 1655

MFC SQlite3封装工程

最近要做一个小工具,用到数据库,sql的数据库太麻烦,只是一个简单的数据库太多的功能也用不到,因此决定用sqlite3,以前在linux下玩过,但是不太深入,这次老大把活派下来了,没办法硬着头皮往前冲...
  • fz835304205
  • fz835304205
  • 2015-06-25 18:55
  • 891

MFC 使用sqlite3 例子

  • 2016-09-09 11:07
  • 7.01MB
  • 下载

在MFC中使用SQLite

一、SQLite简介 SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。它的设计目标是嵌入式的,而且...
  • Kimihong
  • Kimihong
  • 2015-06-24 20:12
  • 1352

在vc中使用sqlite3数据库

一, 在DOS命令行下: PATH = C:\Program Files\Microsoft Visual Studio 10.0\VC\bin;%PATH% PATH = C:\P...
  • lp310018931
  • lp310018931
  • 2014-06-05 22:19
  • 2989
    个人资料
    • 访问:3504944次
    • 积分:35806
    • 等级:
    • 排名:第138名
    • 原创:400篇
    • 转载:88篇
    • 译文:5篇
    • 评论:3419条
    个人说明
    联系方式:
    文章存档
    最新评论