文档章节

CMFCADO类

大賢者
 大賢者
发布于 2017/09/11 11:32
字数 543
阅读 4
收藏 0

自己简单封装的ado.路径那个还没改。。安静

 

使用方法如下

#include "MFCADO.h"  
  
void test_query(CMFCADO& c)  
{  
  
    if(c.GetRecordSet("select * from reward"))  
    {  
        while( RS_NOT_EOF(c.m_pRS) )  
        {  
  
            printf("%s   %d  \n ",    RS_GET_STR(c.m_pRS,"name") , RS_GET_INT(c.m_pRS,"money")  );  
  
            RS_MOVE_NEXT(c.m_pRS);  
        }  
    }  
}  
  
int _tmain(int argc, _TCHAR* argv[])  
{  
    CMFCADO c;  
    if(c.OpenConn("")){  
        printf("OpenConn ok\n");  
    }  
  
  
//c.ExecuteSQL("insert into reward (name,money)values('xx',10000)");  
  
    while(1)  
    {  
        test_query(c);  
    }  
   
  
    Sleep(1000);  
  
  
    return 0;  
}  

 

 

CMFCADO.h

#pragma once


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

#define RS_NOT_EOF(rs) !rs->adoEOF
#define RS_GET_STR(rs,colname)  (char*)(_bstr_t)rs->GetCollect(colname)
#define RS_GET_INT(rs,colname)  atoi((char*)(_bstr_t)rs->GetCollect(colname))

#define RS_MOVE_NEXT(rs) rs->MoveNext();

/************************************************************************/
/* 

mfc ado

CMFCADO c;
if(c.OpenConn("")){
   printf("OpenConn ok");
}

c.ExecuteSQL("insert into table (x,b)values(7,10000)");



simawei@qq.com        
2012.8.1


*/
/************************************************************************/

class CMFCADO
{
public:
	CMFCADO(void);
	~CMFCADO(void);

	//通过文件路径打开mdb数据库
	bool OpenConn(LPCTSTR mdb_filepath);

	void CloseConn();

	bool  CMFCADO::GetRecordSet(LPCTSTR bstrSQL);

	bool CMFCADO::ExecuteSQL(LPCTSTR  bstrSQL);
 
	void CloseRecordset(void);

	_RecordsetPtr m_pRS;//添加一个指向RecordSet对象的指针

private:


	_ConnectionPtr m_pConnection;//添加一个指向Connection对象的指针

};
 

 

CMFCADO.cpp

#include "StdAfx.h"
#include ".\mfcado.h"

CMFCADO::CMFCADO(void)
{
  
	::CoInitialize(NULL);//初始化OLE/COM库环境


 
}

CMFCADO::~CMFCADO(void)
{
	CloseConn();

	 ::CoUninitialize();  

}
void CMFCADO::CloseConn()
{
	try
	{
		if ( m_pConnection!=NULL  )	
		{
			m_pConnection->Close();
			m_pConnection=NULL;
		}
	}
	catch(_com_error &e)
	{
		//printf("CADO::Close()  exception: %s\n",(char*)e.Description());//显示错误信息
	}
}

bool CMFCADO::OpenConn(LPCTSTR mdb_filepath)
{
	//m_pConnection.CreateInstance(_uuidof(Connection));
 
	//创建Connection 对象
	m_pConnection.CreateInstance("ADODB.Connection"); 

	try
	{     
		HRESULT hr=m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=x.mdb","","",adModeUnknown);
		if (FAILED(hr))
		{
			m_pConnection=NULL;

			printf("Connection->Open FAILED\n");
		}
	
	}
	catch(_com_error e)
	{
		//AfxMessageBox( (char*)e.Description() );//显示错误信息);
		printf("[%s] err [%s]\n",__FUNCTION__,(char*)e.Description());
		return false;
	}

	return true;

}

bool CMFCADO::ExecuteSQL(LPCTSTR  bstrSQL)
{
	_variant_t vRowsAffected;

	try
	{
		m_pConnection->Execute(bstrSQL,&vRowsAffected,adCmdText);

		//vRowsAffected.intVal;
	}
	catch (_com_error e)
	{
		printf("[%s] err [%s]\n",__FUNCTION__,(char*)e.Description());
		return false;
	}
	 
	return  true;
}
void CMFCADO::CloseRecordset(void)  
{  
	if(m_pRS !=NULL )  
	{	
		m_pRS->Close();
		m_pRS=NULL;
	}
}  

bool  CMFCADO::GetRecordSet(LPCTSTR bstrSQL)
{
	CloseRecordset();

	//Log(MSG_SQL,"Query [%s]\n",bstrSQL);

	//m_pRecordset.CreateInstance(__uuidof(Recordset));
	
	//创建记录集对象
	m_pRS.CreateInstance("ADODB.Recordset");

	try
	{
		/*
		lockType 表示当打开记录集时,数据提供者用于锁定数据库的类型: 
			adLockReadOnly 数据不能改变,这是缺省值! 
			adLockPessimistic 数据提供者在开始编辑数据的时候锁定记录 
			adLockOptimistic 仅当调用update方法时,数据提供者锁定记录 
			adLockBatchOptimistic 用于批处理修改 
			他们的常量值定义分别是: 
			adLockReadOnly = 1 
			adLockPessimistic = 2 
			adLockOptimistic = 3 
			adLockBatchOptimistic = 4*/

		//取得表中的记录
		HRESULT hr=	m_pRS->Open(bstrSQL,
				m_pConnection.GetInterfacePtr(),  // 获取库接库的IDispatch指针 ,
				adOpenDynamic,
				adLockReadOnly, //,adLockBatchOptimistic	adLockOptimistic
				adCmdText);
		if (FAILED(hr))
		{
			m_pRS=NULL;
		}else{
			
		}
	}
	catch (_com_error e)
	{
		printf("[%s] err [%s]\n",__FUNCTION__,(char*)e.Description());
		return false;
	} 

	return true;
}

 

© 著作权归作者所有

共有 人打赏支持
大賢者

大賢者

粉丝 11
博文 24
码字总数 21153
作品 5
武汉
程序员

暂无文章

Shiro | 实现权限验证完整版

写在前面的话 提及权限,就会想到安全,是一个十分棘手的话题。这里只是作为学校Shiro的一个记录,而不是,权限就应该这样设计之类的。 Shiro框架 1、Shiro是基于Apache开源的强大灵活的开源...

冯文议
29分钟前
0
0
linux 系统的运行级别

运行级别 运行级别 | 含义 0 关机 1 单用户模式,可以想象为windows 的安全模式,主要用于修复系统 2 不完全的命令模式,不含NFS服务 3 完全的命令行模式,就是标准的字符界面 4 系统保留 5 ...

Linux学习笔记
今天
2
0
学习设计模式——命令模式

任何模式的出现,都是为了解决一些特定的场景的耦合问题,以达到对修改封闭,对扩展开放的效果。命令模式也不例外: 命令模式是为了解决命令的请求者和命令的实现者之间的耦合关系。 解决了这...

江左煤郎
今天
3
0
字典树收集(非线程安全,后续做线程安全改进)

将500W个单词放进一个数据结构进行存储,然后进行快速比对,判断一个单词是不是这个500W单词之中的;来了一个单词前缀,给出500w个单词中有多少个单词是该前缀. 1、这个需求首先需要设计好数据结...

算法之名
昨天
15
0
GRASP设计模式

此文参考了这篇博客,建议读者阅读原文。 面向对象(Object-Oriented,OO)是当下软件开发的主流方法。在OO分析与设计中,我们首先从问题领域中抽象出领域模型,在领域模型中以适当的粒度归纳...

克虏伯
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部