SQL Server ODBC數(shù)據(jù)源創(chuàng)建,用VC程序即可
以下的文章主要描述的是用VC程序來對SQL Server ODBC數(shù)據(jù)源進(jìn)行創(chuàng)建的實際操作流程,在發(fā)布與數(shù)據(jù)庫相關(guān)的軟件之時,如果你所用的程序是用ODBC方式對數(shù)據(jù)庫進(jìn)行訪問,則需要在軟件安裝時創(chuàng)建ODBC數(shù)據(jù)源。
SQL Server ODBC數(shù)據(jù)源的一些信息都存放在注冊表中。
- HKEY_LOCAL_MECHINE\Software\ODBC\ODBCINST.INI
從此鍵下可得知系統(tǒng)是否已經(jīng)安裝SQL Server驅(qū)動程序
- HKEY_LOCAL_MECHINE\Software\ODBC\ODBC.INI
從此鍵下可得知系統(tǒng)已經(jīng)建立的數(shù)據(jù)源.
實現(xiàn)函數(shù)如下:
- Function: MakeSQLServerODBCDSN
Purpose: 配置SQL Server數(shù)據(jù)源
Parameters:
[in]
strDBServer: 數(shù)據(jù)庫所在主機(jī)
strDBName: 數(shù)據(jù)庫名稱
strDSN: 數(shù)據(jù)源名稱
strUID: 登陸用戶
Return Value:
-1: 沒有安裝SQL Server驅(qū)動程序
-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;
- }
以上的相關(guān)內(nèi)容就是對用VC程序來創(chuàng)建SQL Server ODBC數(shù)據(jù)源的介紹,望你能有所收獲。
【編輯推薦】
- SQL Server復(fù)制和其相關(guān)的工作原理
- SQL Server存儲圖像數(shù)據(jù)大閱兵
- MS SQL Server 未公開的加密函數(shù)有哪些?
- 快速對SQL Server鎖機(jī)制進(jìn)行掌握的竅門
- SQL Server刪除重復(fù)數(shù)據(jù)的2個實用方案