VC连接SQLite3的方法(MFC封装类)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了VC连接SQLite3的方法(MFC封装类),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3078字,纯文字阅读大概需要5分钟。
内容图文
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("创建表成功,插入数据成功!")); }View Code
第七步:“预览数据”按钮的代码:
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, 0, 0, 0, 0); } ++nRow; } } delete stmt; UpdateData(FALSE); }View Code
第八步:把“w32SQLite3.dll”放到Debug文件夹下。
完成,编译程序,结果如下图所示:
---------------------
版权声明:本文为CSDN博主「无幻」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/akof1314/article/details/5937103
内容总结
以上是互联网集市为您收集整理的VC连接SQLite3的方法(MFC封装类)全部内容,希望文章能够帮你解决VC连接SQLite3的方法(MFC封装类)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。