初学VC+数据库的总结

本文作者分享了初学VC+数据库的心得体会,包括如何添加ADO Data和DataGrid控件,设置数据源,处理数据显示,使用ADO访问数据库的步骤,以及控件与ADO访问的区别。通过实例代码展示了数据库操作过程,指出两者结合可以有效实现VC中数据库的使用。
摘要由CSDN通过智能技术生成

       我用了近三周的时间才摸清了VC与数据库结合的来龙去脉,期间由于参考书的错误便我走了不少弯路,现在虽然只还是不能有很深的理解,但是已基本上能对简单的数据库进行控制,现借CSND之宝地记我的学习历程。以便给自己和后学者一点警告和启示!

         一、添加ADO Data控件与DataGrid控件:

        ADO Data 控件是使用ADO技术访问数据库的具体实现。首先,可以用ADO Data 控件快速地建立一个到数据库的连接;其次,ADO Data控件使用RECORDSET对象对存储在数据库中数据的访问;第三,ADO Data控件可以执行大部分数据库访问操作,不过它不能显示数据库中的数据,要与其它控制结合来使用。而DataGrid以表格的形式显示结果,它要ADO  Data控件提供数据源。更详细的信息可以找相关的资料。

        这两个控件都要手动加到控件工具栏上,从工具栏上选择这两个控件放到对话框中后要对它们进行设置,要重点注意以下几点:1、ADO Data 只是用来连接数据库,所以选择不可见;2、ADO Data要设置连接属性,这里要对数据库与登录方式进行选择,因此这里要稍加注意;3、DataGrid控件要与ADO Data相连接。

         到目前我认为ADO Data与DataGrid主要用来进行数据库数据的显示。如有不对,请指正。谢谢!

        二、对数据显示的处理:

        数据显示时往往要对其进行处理才能达到用户的满意。首先,ADO Data的属性中记录源中的命令类型中选择1-adCmdText,然后在SQL编辑框中输入SQL语句,注意在这要把SQL语句写正确,我在这里因为少写了个GO而困扰了N久!(CommandType:指明形成记录集的命令的类型,为1-adCmdText表示形成记录集的是SQL命令,为2-adCmdTable表示记录集由表构成,为4-adCmdStoredProc由存储过程生成记录集,为8-adCmdUnknown未知命令类型。)

           然后在对话框初始化时对显示进行控制,可以添加初始化函数,SetRecordSource()函数功能是设置ADO Data控件的数据源,参数为SELECT语句,因此可以用AS关键字设置显示标题,接着用Refresh()函数据刷新结果集。 GetColumns()函数可以返回相应的Columns对象,使用GetItem(vIndex)可以返回指定列对应的Columns对象。 
             当然,这以上几步可以写成一个REFRES函数,方便调用。代码类似如下所列:

 m_adodc.SetRecordSource("SELECT Emp_id,Dep_name as 员工姓名,sex as 性别,title as 职务,wage as 工资 FROM Employees");
 m_adodc.Refresh();


 _variant_t vIndex;
 vIndex=long(0);
 m_datagrid.GetColumns().GetItem(vIndex).SetWidth(0);

 vIndex=long(1);
 m_datagrid.GetColumns().GetItem(vIndex).SetWidth(100);
 
 vIndex=long(2);
 m_datagrid.GetColumns().GetItem(vIndex).SetWidth(80);
 
 vIndex=long(3);
 m_datagrid.GetColumns().GetItem(vIndex).SetWidth(100);
 
 vIndex=long(4);
 m_datagrid.GetColumns().GetItem(vIndex).SetWidth(90);


           三、使用ADO访问数据库:
 
          1、导入ADO库文件。

          用#import引入ADO库文件
          #import "c:/program files/common files/system/ado/msado15.dll"no_namespaces rename("EOF" adoEOF")

  这行语句声明在工程中使用ADO,但不使用ADO的名字空间,并且为了避免常数冲突,将常数EOF改名为adoEOF。现在不需添加另外的头文件,就可以使用ADO接口了。


           2、添加类:这个类现对数据库的连接、执行、退出连接等函数据,以便在以后应用。代码如下:

#if !defined(AFX_ADOCONN_H__2BC07DB1_94D0_43A9_8C59_B5E14FBD430B__INCLUDED_)
#define AFX_ADOCONN_H__2BC07DB1_94D0_43A9_8C59_B5E14FBD430B__INCLUDED_

//#include "C:/Program Files/Common Files/System/ado/msader15.dll" no_namespace rename("EOF","adoEOF")rename("BOF","adoBOF")

#import "C:/Program Files/Common Files/System/ado/msado15.dll" no_namespace rename("EOF","adoEOF")rename("BOF","adoBOF")

#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000

class ADOConn 
{
public:
 _RecordsetPtr m_pRecordset;//指向CONNECTION对象的指针
 _ConnectionPtr m_pConnection;//返回查询结果
public:
 void ExitConnect();//关闭记录集与连接
 BOOL ExecuteSQL(_bstr_t bstrSQL);//执行没有返回结果的SQL语句
 _RecordsetPtr& GetRecordSet(_bstr_t bstrSQL);//执行查询语句可以返回结果
 void OnInitADOConn();//初始化连接数据库
 ADOConn();
 virtual ~ADOConn();

};
具体的函数据如下:

请细细地看这些代码,看代码比看注释好上几倍!


void ADOConn::OnInitADOConn()
{
 ::CoInitialize(NULL);
// AfxOleInit();
 try
 {
  m_pConnection.CreateInstance(__uuidof(Connection)); //"ADODB.Recordset");//问题就在这了
 _bstr_t strConnect = "Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial

Catalog=HrMan;Data Source=BB";
  //Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=HrMan;Data

Source=BB
  // m_pConnection->ConnectionString="Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security

Info=False;Initial Catalog=HrMan";
 
 // m_pConnection->Open("","","",adConnectUnspecified);
  
  m_pConnection->Open(strConnect,"","",adModeUnknown);
 }
 catch(_com_error e)
 {
  AfxMessageBox("连接有问题");//
  AfxMessageBox(e.Description());
 }
 

}

_RecordsetPtr& ADOConn::GetRecordSet(_bstr_t bstrSQL)
{
 try
 {
  if(m_pConnection==NULL)
   OnInitADOConn();
  m_pRecordset.CreateInstance(_uuidof(Recordset));
  m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText); 
 }
 catch(_com_error e)
 {
  AfxMessageBox("查询有错误");
  AfxMessageBox(e.Description());
 }
 return m_pRecordset;

}

BOOL ADOConn::ExecuteSQL(_bstr_t bstrSQL)
{
 try
 {
  if(m_pConnection==NULL)
   OnInitADOConn();
   //OnInitADOConn
  m_pConnection->Execute(bstrSQL,NULL,adCmdText);
  return true;
 }
 catch(_com_error e)
 {
  AfxMessageBox("插入有问题");
  AfxMessageBox(e.Description());
  return false;
 }

}

void ADOConn::ExitConnect()
{
 if(m_pRecordset!=NULL)
  m_pRecordset->Close();
 m_pConnection->Close();
 ::CoUninitialize();
}


             四、对数据库操作的过程:


            1、定义ADOCONN对象
            2、执行SQL语句
            3、关闭连接

              关于这一步可以参照以下代码理解,这是一个INSERT语句的执行过程:

 ADOConn m_AdoConn;
 m_AdoConn.OnInitADOConn();
 _bstr_t vSQL;
 vSQL="INSERT INTO Employees(Dep_Name,Sex,Title,Wage,Dep_id)VALUES('"+m_EmpName+"','"+strSex+"','"+m_Title+"','"+strWage+"',1)";
 m_AdoConn.ExecuteSQL(vSQL);
 m_AdoConn.ExitConnect();


            五、控件与ADO访问的区别:


           控件的访问只是对数据进行输出,而并没有对之旱灾行具体的操作、而ADO是对数据旱灾行操作而不对之进行显示,二者结合能很好地实现VC中使用数据库。

            六、心得:


           这是我用了近三周的时间所理解的,真的很慢,但是我真是学到了一些东西,虽然我也知我以上总结的有很多不足,但我会坚持下去的,我会用一定的时间对VC进行全面学了,这只是一个开始。万事开头难,我相信随着知识的增加我以后会以更快的速度学,以更高效的方法向VC进军,以后我的BLOG会陆续记录我的学习总结,我也相信在大家的帮助下我的总结会越写越好!谢谢你们的批评指正!

 

 

 

 

 

 

 

 


 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
编 者 的 话 5 第1篇 基础篇 6 第1章 数据库原理与访问 7 1.1 数据库基本原理 7 1.1.1 概述 7 1.1.2 桌面数据库 7 1.1.3 对象数据库 8 1.1.4 关系数据库服务器 9 1.1.5 选择适用的数据库 9 1.2 数据库访问技术 10 1.2.1 概述 10 1.2.2 ODBC API 10 1.2.3 ODBC的MFC类 11 1.2.4 DAO与RDO 11 1.2.5 OLE DB与ADO 12 1.3 数据库操纵语言SQL 13 1.3.1 SQL命令 13 1.3.2 SQL从句 13 1.3.3 SQL运算符 14 1.3.4 SQL合计函数 14 1.4 小 结 14 第2章 COM与数据库访问 15 2.1 COM的基本原理 15 2.1.1 COM历史 16 2.1.2 COM结构 16 2.1.3 COM优势 17 2.1.4 COM接口 18 2.1.5 COM与数据库访问 19 2.1.6 COM与Internet 19 2.2 ACTIVEX的数据库访问 19 2.2.1 ActiveX简介 19 2.2.2 ActiveX对数据库访问的支持 20 2.3 ATL的数据库访问 20 2.3.1 ATL目标 20 2.3.2 ATL内容简介 22 2.3.3 ATL对数据库访问的支持 22 2.4 小 结 23 第3章 数据库开发过程 23 3.1 阶段1:调查与分析 24 3.2 阶段2:数据建模 24 3.3 阶段3:功能设计 24 3.4 阶段4:选择数据库系统 25 3.5 阶段5:选择数据库访问技术 25 3.6 阶段6:代码设计 25 3.7 阶段7:测试与调试 26 3.8 阶段8:发行产品 26 第4章 VC++数据库开发基础 26 4.1 VC++ 6.0工程创建向导 26 4.2 VC++ 6.0数据库新建工具 27 4.3 VC++ 6.0的数据库工程 29 4.4 小 结 31 第2篇 实例篇 32 第5章 ODBC API编程 33 5.1 了解ODBC API 34 5.2 ODBC API编程步骤 34 5.2.1 步骤1:连接数据源 34 5.2.2 步骤2:分配语句句柄 36 5.2.3 步骤3:准备并执行SQL语句 36 5.2.4 步骤4:获取结果集 37 5.2.5 步骤5:提交事务 38 5.2.6 步骤6:断开数据源连接并释放环境句柄 39 5.3 ODBC API编程实例 39 5.3.1 实例概述 39 5.3.2 实例实现过程 40 5.3.3 编译并运行ODBCDemo1工程 97 5.3.4 ODBCDemo1实例小结 98 5.4 本 章 小 结 99 第6章 MFC ODBC编程 100 6.1 了解MFC ODBC 100 6.1.1 CDatabase类 100 6.1.2 CRecordSet类 100 6.2 MFC ODBC数据库访问技术 101 6.2.1 记录查询 101 6.2.2 记录添加 102 6.2.3 记录删除 102 6.2.4 记录修改 102 6.2.5 撤销数据库更新操作 103 6.2.6 直接执行SQL语句 103 6.2.7 MFC ODBC的数据库操作过程 103 6.3 MFC ODBC编程实例 104 6.3.1 实例概述 104 6.3.2 实例实现过程 105 6.3.3 编译并运行ODBCDemo2工程 132 6.3.4 ODBCDemo2实例小结 137 6.4 本 章 小 结 137 第7章 DAO数据库编程 138 7.1 DAO的数据访问 138 7.1.1 DAO对象 138 7.1.2 MFC对DAO的支持 139 7.1.3 DAO与ODBC的比较 139 7.1.4 MFC的DAO类简介 139 7.2 DAO编程实例 142 7.2.1 实例概述 142 7.2.2 实例实现过程 143 7.2.3 运行DAODemo工程 167 7.2.4 DAODemo实例小结 171 7.3 小 结 172 第8章 OLE DB客户数据库编程 172 8.1 OLE DB原理 172 8.1.1 OLE DB与ODBC 172 8.1.2 OLE DB的结构 173 8.1.3 OLE DB的优越性 173 8.1.4 OLE DB对象 174 8.1.5 OLE DB客户模板结构 177 8.1.6 OLE DB客户模
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值