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

www.sqlite.org
--》Download进入下载页面--》找到“Precompiled Binaries for Windows”,选择sqlite-shell-win32-x86-3080600,点击下载。

图形界面:SQLiteExpert_3.4.34.2256_XiaZaiBa

from:

http://blog.csdn.net/akof1314/article/details/5937103


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


SQLite封装的数据库实现 可以方便使用和调用接口 附带详细的调用说明 只使用C++ MFC 创建数据库 CppSQLite3DB db; CFileFind fFind; if fFind FindFile T "dataAcquisition 1 db" { db open T "dataAcquisition MagneticDataAcquisition db" NULL ; 创建文件 1#磁钢波峰数据 db execDML T "CREATE TABLE MagDate 1 CarID TEXT 30 AlxID INT 2 SamplingValue INT 2 Spleed INT 2 Degree INT 2 ;" ; 2#磁钢波峰数据 db execDML T "CREATE TABLE MagDate 2 CarID TEXT 30 AlxID INT 2 SamplingValue INT 2 Spleed INT 2 Degree INT 2 ;" ; 3#磁钢波峰数据 db execDML T "CREATE TABLE MagDate 3 CarID TEXT 30 AlxID INT 2 SamplingValue INT 2 Spleed INT 2 Degree INT 2 ;" ; 4#磁钢波峰数据 db execDML T "CREATE TABLE MagDate 4 CarID TEXT 30 AlxID INT 2 SamplingValue INT 2 Spleed INT 2 Degree INT 2 ;" ; 列车采样信息汇总 1# 2#磁钢得到的数据 db execDML T "CREATE TABLE TrainNode 12 TrainID TEXT 30 AlxNums 1 INT 2 AlxNums 2 INT 2 MaxSpleed INT 2 MinSpleed INT 2 AvgSpleed INT 2 SpleedDegree INT 2 MaxWaveSamp 1 INT 2 MinWaveSamp 1 INT 2 AvgWaveSamp 1 INT 2 MaxWaveSamp 2 INT 2 MinWaveSamp 2 INT 2 AvgWaveSamp 2 INT 2 YouXiao TEXT 2 ;" ; 列车采样信息汇总 3# 4#磁钢得到的数据 db execDML T "CREATE TABLE TrainNode 34 TrainID TEXT 30 AlxNums 3 INT 2 AlxNums 4 INT 2 MaxSpleed INT 2 MinSpleed INT 2 AvgSpleed INT 2 SpleedDegree INT 2 MaxWaveSamp 3 INT 2 MinWaveSamp 3 INT 2 AvgWaveSamp 3 INT 2 MaxWaveSamp 4 INT 2 MinWaveSamp 4 INT 2 AvgWaveSamp 4 INT 2 YouXiao TEXT 2 ;" ; 磁钢故障报警记录 db execDML T "CREATE TABLE GuZhangInfo TrainID TEXT 30 MagNetID INT 2 GuZhangName TEXT 100 ;" ; 列车速度最终值用于存储 可实现用户更改 db execDML T "CREATE TABLE SpleedDegree DegreeID INT 2 AvgWaveSamp 1 INT 2 AvgWaveSamp 2 INT 2 AvgWaveSamp 3 INT 2 AvgWaveSamp 4 INT 2 ;" ; 插入预先准备好的数据 for int i 0;i<m GlobalPublicManager m MaxSpleedDegree;i++ { CString
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值