用VC程序来创建SQL Server ODBC数据源

王朝vc·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

在发布与数据库相关的软件时,如果程序是用ODBC方式访问数据库,则需要在软件安装时创建ODBC数据源。

ODBC数据源的一些信息都存放在注册表中。

HKEY_LOCAL_MECHINE\Software\ODBC\ODBCINST.INI

从此键下可得知系统是否已经安装SQL Server驱动程序

HKEY_LOCAL_MECHINE\Software\ODBC\ODBC.INI

从此键下可得知系统已经建立的数据源.

实现函数如下:

//////////////////////////////////////////////////////////////////

//Function: MakeSQLServerODBCDSN

//

//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;

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航