用VC程序對SQL Server ODBC數據源的創建流程
本文主要向你介紹的是用VC程序來對SQL Server ODBC數據源的創建,在發布與數據庫相關的軟件之時的實際操作中,假如你的程序是用ODBC方式對數據庫進行訪問,我們就需要在軟件安裝時創建ODBC數據源。
ODBC數據源的一些信息都存放在注冊表中。
HKEY_LOCAL_MECHINE\Software\SQL Server ODBC\ODBCINST.INI
從此鍵下可得知系統是否已經安裝SQL Server驅動程序
HKEY_LOCAL_MECHINE\Software\ODBC\ODBC.INI
從此鍵下可得知系統已經建立的數據源.
實現函數如下:
Function: Make SQL Server ODBCDSN
Purpose: 配置SQL Server數據源
Parameters:
[in]
strDBServer: 數據庫所在主機
strDBName: 數據庫名稱
strDSN: 數據源名稱
strUID: 登陸用戶
Return Value:
-1: 沒有安裝SQL Server驅動程序
-2: 其他錯誤
0: 成功
- int MakeSQLServerODBCDSN(LPCTSTR strDBServer,LPCTSTR strDBName,LPCTSTR strDSN,LPCTSTR strUID)
- {
- BOOL bInstallDriver=TRUE;
- CRegKey regKey;
- LONG lRet=regKey.Open(HKEY_LOCAL_MACHINE,"Software\\ODBC\\ODBCINST.INI\\SQL Server");
- if(lRet!=ERROR_SUCCESS)
- {
- bInstallDriver=FALSE;
- }
- else
- {
- char szDirverPath[MAX_PATH]="";
- DWORD dwCount=100;
- lRet=regKey.QueryValue(szDirverPath,"Driver",&dwCount);
- if((lRet!=ERROR_SUCCESS)||(dwCount<1))
- {
- DWORD dwErr=GetLastError();
- bInstallDriver=FALSE;
- }
- regKey.Close();
- }
- if(!bInstallDriver)
- {
- return -1;
- }
- CString strKeyValueName="Software\\ODBC\\ODBC.INI\\";
- strKeyValueName+=strDSN;
- lRet=regKey.Create(HKEY_LOCAL_MACHINE,strKeyValueName);
- if(lRet!=ERROR_SUCCESS)
- {
- return -2;
- }
- regKey.SetValue(strDBName,"Database");
- regKey.SetValue("SQLSrv32.dll","Driver");
- regKey.SetValue(strDBServer,"Server");
- regKey.SetValue(strUID,"LastUser");
- regKey.m_hKey=HKEY_LOCAL_MACHINE;
- regKey.SetKeyValue("Software\\ODBC\\ODBC.INI\\ODBC Data Sources","SQL Server",strDSN);
- regKey.Close();
- return 0;
- }
以上的相關內容就是對用VC程序來對SQL Server ODBC數據源的創建的介紹,望你能有所收獲。
【編輯推薦】