MFC+ODBC+SQL Server+Visual C++
利用SQL Server 和MFC实现对数据库的简单管理
工具:SQL Server,VC6.0
步骤如下:
1.建立一个数据库studentinfo,再建立一个表testtable,表设计和初始值如下(仅仅是举个例子,后面操作都是基于此表的):


2.建立ODBC数据源
步骤如下:
1.进入计算机管理工具中的ODBC数据源

2.选择添加用户DSN

选择SQL Server Driver驱动,前提是已安装SQL Server Managemant Studio等相关组件工具

然后填写数据源名称和服务器(localhost表示本机服务器)

然后一直点击下一步直到完成,此时可以看到用户DSN中已经有了刚刚添加的数据源

3.现在打开VC6.0,新建一个对话框工程(命名为ODBC)
在默认对话框中添加控件如下:

注意:列表视图控件设置属性为报表类型Report,如下:

各控件绑定变量如下:

在CODBCDlg类的OnInitDialog()中添加如下代码
m_listctrl.SetExtendedStyle(LVS_EX_GRIDLINES|LVS_EX_FULLROWSELECT);
//设置列表视图控件为网格状风格,且为全选状态(鼠标点击某一行表现为全选状态)
m_listctrl.InsertColumn(0,"ID",LVCFMT_LEFT,110);//参数分别为字段索引,字段名,对齐方式,像素(每个字段宽度)
m_listctrl.InsertColumn(1,"姓名",LVCFMT_LEFT,100);
m_listctrl.InsertColumn(2,"性别",LVCFMT_LEFT,120);
m_listctrl.InsertColumn(3,"总分",LVCFMT_LEFT,100);
CString SQL="SELECT * FROM testtable"; //可以通过更改表名达到列出同一数据源中不同表的目的
ListStuInfo(SQL); //列出指定表中所有信息
SetTimer(1,1,NULL);//计时器
return TRUE;
然后在新建ODBC记录集类CInfoSet,其基类为CRecordSet


建立方式为点击菜单中的插入,选择新建类

按照如上图设置后点击OK,弹出对话框如下:

ODBC下拉选择刚才的数据源名称DSN为stuinfo,点击OK,然后会弹出一个选择数据表的对话框,选择testtable即可
此时在类视图中可以看见数据库的testtable表中的列名对应的成员变量m_id,m_score,m_name,m_sex

然后添加CODBCDlg 类的成员函数ListStuInfo(CString strSQL),用于在初始化对话框时在列表控件中显示学生信息
注意要在ODBCDlg.cpp文件中添加InfoSet.h头文件
void CODBCDlg::ListStuInfo(CString strSQL)
{
m_listctrl.DeleteAllItems(); //首先删除所有项目
CInfoSet Infoset; //创建一个记录集对象
if(!Infoset.Open(CRecordset::dynaset,strSQL,CRecordset::readOnly))//连接数据源并执行给定的SQL语句
{
MessageBox("连接数据源失败!","警告",MB_ICONASTERISK|MB_OK);
return;
}
CString strTemp;
int i = 0;
while(!Infoset.IsEOF())
{
m_listctrl.InsertItem(i,Infoset.m_id);
m_listctrl.SetItemText(i,1,Infoset.m_name);
m_listctrl.SetItemText(i,2,Infoset.m_sex);
strTemp.Format("%d",Infoset.m_score); //将long int转为CString
m_listctrl.SetItemText(i,3,strTemp);
Infoset.MoveNext();
i++;
}
Infoset.Close(); //关闭记录集
UpdateData(FALSE); //将控件变量值传给对应控件显示
}
至此编译运行会出现错误,原因是没有在stdafx.h头文件添加afxdb.h头文件,因为使用了记录集类
然后再编译运行即可,效果如下:

此时"添加","删除","修改"按钮没有反应,因为还没有为他们添加消息函数
下面开始构建添加,删除,修改模块
添加一个"添加学生信息"对话框资源,如下:

控件绑定变量如下:

双击该对话框的确定按钮为其添加消息函数代码(CStuInfoDlg 即为添加学生信息对话框对应的类)
void CStuInfoDlg::OnOK()
{
// TODO: Add extra validation here
UpdateData(TRUE);//将控件值传给控件变量
MessageBox("添加成功!","提示");
CDialog::OnOK();
}
在主对话框(CODBCDlg)添加成员变量如下:

双击主对话框添加按钮为其添加消息响应函数如下:
{
// TODO: Add your control notification handler code here
CStuInfoDlg dlg;
if(dlg.DoModal()!=IDOK)//如果用户没有点击添加对话框的确定按钮则直接返回,函数结束
{
return;
}
m_newID = dlg.m_addID;
m_newname = dlg.m_addname;
m_newsex = dlg.m_addsex;
m_newscore = dlg.m_addscore;
if(!db.Open("stuinfo"))//直接连接数据源stuinfo
{
MessageBox("连接数据源stuinfo失败!","警告",MB_ICONASTERISK|MB_OK);
return;
}
CString strSQL;
strSQL.Format("insert into testtable values('%s','%s','%s','%s')",m_newID,m_newname,m_newsex,m_newscore);//编写SQL插入语句
db.ExecuteSQL(strSQL);//执行SQL语句
db.Close();//断开与数据源的连接
ListStuInfo("select * from testtable");//列出表中信息
}

添加后列表视图如下:

接着完成修改模块
任然要新建对话框“修改学生信息"
其他操作跟添加差不多


添加相关代码:
{
// TODO: Add your control notification handler code here
int n = m_listctrl.GetSelectionMark();//获得视图列表选择项目的索引
if(n == -1) //为-1表示没有选中任何项
return;
m_newID = m_listctrl.GetItemText(n,0);
m_newname = m_listctrl.GetItemText(n,1);
m_newsex = m_listctrl.GetItemText(n,2);
m_newscore = m_listctrl.GetItemText(n,3);
dlg.m_ID = m_newID;
dlg.m_name = m_newname;
dlg.m_sex = m_newsex;
dlg.m_score = m_newscore;
//UpdateData(FALSE);//在修改对话框显示所选中学生信息
return;
UpdateData(TRUE);
m_newID = dlg.m_ID;
m_newname = dlg.m_name;
m_newsex = dlg.m_sex;
m_newscore = dlg.m_score;
if(!db.Open("stuinfo"))//直接连接数据源stuinfo
{
MessageBox("连接数据源stuinfo失败!","警告",MB_ICONASTERISK|MB_OK);
return;
}
CString strSQL = "",strTemp;
strTemp.Format("update testtable set id='%s',name='%s',sex='%s',score='%s' where name='%s' ",m_newID,m_newname,m_newsex,m_newscore,strOldName);
strSQL+=strTemp;
db.ExecuteSQL(strSQL);
MessageBox("修改成功!","提示");
db.Close();
ListStuInfo("select * from testtable");
}
运行效果如下:(注意:点击修改按钮前先选择列表控件中的要修改项)


修改后:

最后是删除模块,不需要建立对话框,只需在CODBCDlg添加如下成员函数:
{
// TODO: Add your control notification handler code here
int n = m_listctrl.GetSelectionMark();
if(n == -1)//没有选中任何项目
{
MessageBox("请选中一个项目再点击删除!","提示");
return;
}
m_newname = m_listctrl.GetItemText(n,1);//获取选中项的主键信息name
CDatabase db;
if(!db.Open("stuinfo"))
{
MessageBox("连接数据源stuinfo失败!","警告",MB_ICONASTERISK|MB_OK);
return;
}
CString strSQL;
strSQL.Format("delete from testtable where name='%s'",m_newname);
db.ExecuteSQL(strSQL);
MessageBox("删除成功!","提示");
db.Close();
ListStuInfo("select * from testtable");
}
删除后:

为了在主对话框实时获得当前表中记录数,还要添加计时器函数OnTimer(),利用MFC ClassWizard建立该函数,鼠标右键选择MFC ClassWizard
{
// TODO: Add your message handler code here and/or call default
int count = m_listctrl.GetItemCount();//获取项目数量
m_count = count;
UpdateData(FALSE);
CDialog::OnTimer(nIDEvent);
}
若有不足欢迎指正;若有疑问鄙人也乐于解答,欢迎留言或QQ加群!
欢迎加入QQ群:735472015,群内有VC,MFC,win32API,批处理,python学习资料干货喔
逆向工程中,有时会出现如下错误 ... [Microsoft][ODBC SQL Server Driver][SQL Server]无法预定义语句 SQLSTATE = 37000 解决方案: 1. ... 原帖由 qingyun 于 2010-6-21 15:44 发表 在写pl/sql的时候,有个很重要的注意点:比如:begin update 某个sqlserver的表@dblink名字 .... ... 连接SQLServer2005失败,错误信息: 错误类型:Microsoft OLE DB Provider for ODBC Drivers (0x80004005)[Microsoft][ODBC ... 一般连接sql数据库,IP_connstr="driver={SQL Server}; server=127.0.0.1;database=数据库名字;uid=sa;pwd=密码" ... 现象描述: (1).数据库通过调用透明网络实现分布式事务,但透明网关停用后,失败的分布式事务并未清理. (2).数据库 alert 日志 Thu Sep 06 06:53:00 2018 Errors ... firedac odbc sql server driver连接占线导致另一个hstmt 原因:FDQuery.FetchOptions.Mode=fmOnDemand.好像是为了性能问题,不设置则默 ... OdbcConnection con = new OdbcConnection("Driver={SQL Server};server=PC-200201070359;uid=sa;pwd= ... http://www.jb51.net/article/98364.htm php连接微软MSSQL(sql server)完全攻略 作者:吵吵 字体:[增加 减小] 类型:转载 时间:2016-11 ... OS ENV:主机名: WIN-NO42QRNPMFAOS 名称: Microsoft Windows Server 2008 R2 Datacenter OS ... localStorage是HTML5在在客户端存储数据的新方法,存储的数据没有时间限制. localStorage的主要API: localStorage.setItem(key,value); ... 区别一: throw 是语句抛出一个异常:throws 是方法抛出一个异常: throw语法:throw <异常对象> ... 备份数据库 1.使用mysqldump命令备份 备份一个数据库:mysqldump -u 用户名 -p密码 数据库名 [表名1,表名2...]>备份文件路径及名字.sql 如 ... 第一部分:使用Axure管理团队项目 首先,你要有一个Axure账户 呵呵哒.注册地址:http://share.axure.com 发起团队项目 在浏览器登录 Axure share(网速很卡很卡) ... 如果说一个网站是一个独立的王国,那登录功能就相当于这个[王国]的大门.进出往来的人必须要通过这道[门]才能进出这个[王国],这样才能有效的达到对人流量和用户的有效监管,也可以进一步了解每个用户的喜好, ... package main import ( "net/http" "github.com/gin-gonic/gin" "github.com/jin ... 今天主要是学习了cocos2dx的scrollview的内容,把简单的菜单滑动表现做出来了.像很多游戏的下方有一槽功能按钮,角色.背包.技能.帮助等,当宽度不足以全部显示出来的时候,隐藏一部分,以滑动 ... @Test public void testSave() { Boss boss = new Boss(); boss.setName("A-老板"); Company compa ... Description 使用过Android手机的同学一定对手势解锁屏幕不陌生.Android的解锁屏幕由3x3个点组成,手指在屏幕上画一条 线将其中一些点连接起来,即可构成一个解锁图案.如下面三个例 ... 1.@ModelAttribute 1.给共享的数据设置model数据设置,贴在形参上,也可以贴在方法上,设置一个model的key值 2.当controller方法返回一个对象的时候,,缺省值会把当 ...MFC+ODBC+SQL Server+Visual C++的更多相关文章
随机推荐