怎样在程序中调用建立连接字符串的对话框

在程序中有时候需要用到连接字符串,但是有可能在配置时要改变它,手工输入是容易错的,有了这个对话框,一切就简单了,但是这个对话框可不是一个api就能调出来的,偶查了查msdn再东抄抄西抄抄再自己发了一会儿呆些了下面的这个函数。里面的东西不用你看懂,把它copy下来用就行乐,当然能看懂最好了,找出错误来请发emailto:fantong77@hotmail.com.

BOOL GetConnectString(TCHAR *lpszConnectString,HWND hWndParent)
{
 CComPtr<IDBPromptInitialize> pIDBPromptInitialize=NULL;
 CComPtr<IDBProperties > pIDBProperties = NULL;
 CComPtr<IDataInitialize> spDataInit=NULL;
 CComBSTR bstrConnectString;
 
 HRESULT hr;
 // Create an instance of the Data Links component.
 hr=CoCreateInstance(CLSID_DataLinks, NULL, CLSCTX_INPROC_SERVER,
  IID_IDBPromptInitialize, (void **)&pIDBPromptInitialize);
 if (FAILED(hr))
  return FALSE;
 

 // Prompt the user for the provider and initialization properties.
 hr=pIDBPromptInitialize->PromptDataSource(NULL, hWndParent,
    DBPROMPTOPTIONS_PROPERTYSHEET, 0, NULL, NULL, IID_IDBProperties,
  (IUnknown **)&pIDBProperties);
 if (FAILED(hr))
  return FALSE;
 hr = CoCreateInstance(CLSID_MSDAINITIALIZE, NULL, CLSCTX_INPROC_SERVER,
   IID_IDataInitialize, (void**)&spDataInit);
 if (FAILED(hr))
  return FALSE;
 
 hr=spDataInit->GetInitializationString(pIDBProperties,true,&bstrConnectString);
 if (FAILED(hr))
  return FALSE;
 
 lstrcpy(lpszConnectString,(char*)_bstr_t(bstrConnectString));
 return TRUE;
 

}

参数说明,返回值为false,用户取消

第二个为out,输入连接字符串

第三个位in,父窗口

记住先要初始化com哦

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值