数据源的三种访问方式

2024-09-02 12:48
文章标签 访问 三种 方式 数据源

本文主要是介绍数据源的三种访问方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数据源的三种访问方式:

1、使用OLEDB数据库连接对话框  链接到数据源

2、使用纯代码方式连接到指定的数据源

3、使用连接字符串得到一个IDBInitialize接口

代码:

#include <tchar.h>
#include <windows.h>
#include <strsafe.h>#define COM_NO_WINDOWS_H    //如果已经包含了Windows.h或不使用其他Windows库函数时
#define DBINITCONSTANTS
#define INITGUID
#define OLEDBVER 0x0260 
#include <oledb.h>
#include <oledberr.h>
#include <msdasc.h>#define GRS_ALLOC(sz)		HeapAlloc(GetProcessHeap(),0,sz)
#define GRS_CALLOC(sz)		HeapAlloc(GetProcessHeap(),HEAP_ZERO_MEMORY,sz)
#define GRS_SAFEFREE(p)		if(NULL != p){HeapFree(GetProcessHeap(),0,p);p=NULL;}#define GRS_USEPRINTF() TCHAR pBuf[1024] = {}
#define GRS_PRINTF(...) \StringCchPrintf(pBuf,1024,__VA_ARGS__);\WriteConsole(GetStdHandle(STD_OUTPUT_HANDLE),pBuf,lstrlen(pBuf),NULL,NULL);#define GRS_SAFERELEASE(I) if(NULL != I){I->Release();I=NULL;}
#define GRS_COM_CHECK(hr,...) if(FAILED(hr)){GRS_PRINTF(__VA_ARGS__);goto CLEAR_UP;}#define GRS_DEF_INTERFACE(i) i* p##i = NULL;
#define GRS_QUERYINTERFACE(i,iid) \if(FAILED(hr = (i)->QueryInterface(IID_##iid, (void **)&p##iid)) )\{\GRS_PRINTF(_T("不支持'%s'接口\n"),_T(#iid));\}\else\{\GRS_PRINTF(_T("支持'%s'接口\n"),_T(#iid));\}\GRS_SAFERELEASE(p##iid);//FAILED(hr = CLSIDFromProgID(L"SQLOLEDB", &clsid) )int _tmain()
{GRS_USEPRINTF();CoInitialize(NULL);//初始化COM组件IDBPromptInitialize*				pIDBPromptInitialize		=NULL;IDataInitialize*						pIDataInitialize				=NULL;LPOLESTR								pLinkString					=NULL;//以下是IDBInitialize接口的等价接口定义//1必须支持的接口GRS_DEF_INTERFACE(IDBInitialize);GRS_DEF_INTERFACE(IDBCreateSession);GRS_DEF_INTERFACE(IDBProperties);GRS_DEF_INTERFACE(IPersist);//2可选择支持的GRS_DEF_INTERFACE(IConnectionPointContainer);GRS_DEF_INTERFACE(IDBAsynchStatus);GRS_DEF_INTERFACE(IDBDataSourceAdmin);GRS_DEF_INTERFACE(IDBInfo);GRS_DEF_INTERFACE(IPersistFile);GRS_DEF_INTERFACE(ISupportErrorInfo);HWND hWndParent=GetDesktopWindow();CLSID clsid={};//1使用OLEDB数据库连接对话框链接到数据源HRESULT hr=CoCreateInstance(CLSID_DataLinks,NULL,CLSCTX_INPROC_SERVER,IID_IDBPromptInitialize,(void**)&pIDBPromptInitialize);//下面这句话弹出数据库连接对话框hr=pIDBPromptInitialize->PromptDataSource(NULL,hWndParent,   //DBPROMPTOPTIONS_PROPERTYSHEET,0,NULL,NULL,IID_IDBInitialize,(IUnknown**)&pIDBInitialize);hr=pIDBPromptInitialize->QueryInterface(IID_IDataInitialize,(void**)&pIDataInitialize);hr=pIDataInitialize->GetInitializationString(pIDBInitialize,TRUE,&pLinkString);hr=pIDBInitialize->Initialize();//测试都支持哪些接口/*GRS_QUERYINTERFACE(pIDBInitialize,IDBCreateSession);GRS_QUERYINTERFACE(pIDBInitialize,IDBProperties);GRS_QUERYINTERFACE(pIDBInitialize,IPersist);GRS_QUERYINTERFACE(pIDBInitialize,IConnectionPointContainer);GRS_QUERYINTERFACE(pIDBInitialize,IDBAsynchStatus);GRS_QUERYINTERFACE(pIDBInitialize,IDBDataSourceAdmin);GRS_QUERYINTERFACE(pIDBInitialize,IDBInfo);GRS_QUERYINTERFACE(pIDBInitialize,IPersistFile);GRS_QUERYINTERFACE(pIDBInitialize,ISupportErrorInfo);
*///断开数据库连接
pIDBInitialize->Uninitialize();
GRS_SAFERELEASE(pIDBInitialize);
GRS_SAFERELEASE(pIDBPromptInitialize);//2使用纯代码方式链接到指定的数据源
hr=CoCreateInstance(		CLSID_MSDAINITIALIZE,NULL,CLSCTX_INPROC_SERVER,IID_IDataInitialize,(void**)&pIDataInitialize);
hr=CLSIDFromProgID(_T("SQLOLEDB"),&clsid);
//创建数据源链接对象和初始化接口
hr=pIDataInitialize->CreateDBInstance(	clsid,NULL,CLSCTX_INPROC_SERVER,NULL,IID_IDBInitialize,(IUnknown**)&pIDBInitialize);
//准备连接属性
//虽然后面只有4个属性,但是仍然要定义和初始化4+1个属性
DBPROP InitProperties[5]={};
DBPROPSET rgInitPropSet[1]={};//指定数据库实例名
InitProperties[0].dwPropertyID			=DBPROP_INIT_DATASOURCE;
InitProperties[0].vValue.vt					=VT_BSTR;
InitProperties[0].vValue.bstrVal			=SysAllocString(L"YuZhiBo-PC");
InitProperties[0].dwOptions				=DBPROPOPTIONS_REQUIRED;
InitProperties[0].colid						=DB_NULLID;//指定数据库名
InitProperties[1].dwPropertyID			=DBPROP_INIT_CATALOG;
InitProperties[1].vValue.vt					=VT_BSTR;
InitProperties[1].vValue.bstrVal			=SysAllocString(L"scott");
InitProperties[1].dwOptions				=DBPROPOPTIONS_REQUIRED;
InitProperties[1].colid						=DB_NULLID;// user ID
InitProperties[2].dwPropertyID			=DBPROP_AUTH_USERID;
InitProperties[2].vValue.vt					=VT_BSTR;
InitProperties[2].vValue.bstrVal			=SysAllocString(OLESTR("sa"));//password
InitProperties[3].dwPropertyID			=DBPROP_AUTH_PASSWORD;
InitProperties[3].vValue.vt					=VT_BSTR;
InitProperties[3].vValue.bstrVal			=SysAllocString(OLESTR("tiger"));//创建一个GUID为DBPROPSET_DBINIT的属性集合,这样是初始化链接是需要的唯一一个属性集合
rgInitPropSet[0].guidPropertySet=DBPROPSET_DBINIT;
rgInitPropSet[0].cProperties=4;
rgInitPropSet[0].rgProperties=InitProperties;//得到数据库初始化的属性接口
hr=pIDBInitialize->QueryInterface(IID_IDBProperties,(void**)&pIDBProperties);
GRS_COM_CHECK(hr,_T("获取IDBProperties接口失败,错误码:0x%08\n"),hr);
hr=pIDBProperties->SetProperties(1,rgInitPropSet);
GRS_COM_CHECK(hr,_T("设置链接属性失败,错误码:0x%08\n"),hr);//属性一旦完成,相应的接口就可以释放了
GRS_SAFERELEASE(pIDBProperties);//根据指定的属性链接到数据库
hr=pIDBInitialize->Initialize();
GRS_COM_CHECK(hr,_T("使用属性链接到数据源失败,错误码:0x%08x\n"),hr);
GRS_PRINTF(_T("使用属性集方式链接到数据源成功!\n"));pIDBInitialize->Uninitialize();
GRS_SAFERELEASE(pIDBInitialize);//3使用链接字符串得到一个IDBInitialize接口
hr=pIDataInitialize->GetDataSource(	NULL,CLSCTX_INPROC_SERVER, //class context in process serverL"Provider=SQLOLEDB.1;Persist Security info=False;User ID=sa;Password=tiger;Initial Catalog=scott; Data Source=YuZhiBo-PC;",__uuidof(IDBInitialize),(IUnknown**)&pIDBInitialize);
GRS_COM_CHECK(hr,_T("使用连接字符串获取数据源接口IDBInitialize失败"));
//链接到数据库
hr=pIDBInitialize->Initialize();
GRS_COM_CHECK(hr,_T("使用连接字符串链接数据源失败。\n"));
GRS_PRINTF(_T("使用字符串连接到数据源成功!\n"));CLEAR_UP:if(NULL != pIDBInitialize){pIDBInitialize->Uninitialize();}GRS_SAFERELEASE(pIDBProperties);GRS_SAFERELEASE(pIDataInitialize);GRS_SAFERELEASE(pIDBInitialize);GRS_SAFERELEASE(pIDBPromptInitialize);_tsystem(_T("PAUSE"));CoUninitialize();return 0;
}


这篇关于数据源的三种访问方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1129999

相关文章

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

MySQL中的InnoDB单表访问过程

《MySQL中的InnoDB单表访问过程》:本文主要介绍MySQL中的InnoDB单表访问过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、访问类型【1】const【2】ref【3】ref_or_null【4】range【5】index【6】

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文