使用C#有两种方法可以动态的创建ODBC数据源,这里我用比较常用的SQL2000作为例子。
方法1:直接操作注册表,需要引用Microsoft.Win32命名空间
/// <summary>
/// 创建SQL数据源
/// </summary>
/// <param name="dns">数据源名称</param>
/// <param name="server">服务器</param>
/// <param name="database">数据库</param>
/// <returns></returns>
private bool CreateSqlODBC(string dsn, string server,string database)
{
try
{
RegistryKey regKey = Registry.LocalMachine.OpenSubKey("SOFTWARE").OpenSubKey("ODBC").OpenSubKey("ODBC.INI", true).CreateSubKey(dsn);
regKey.SetValue("Driver", @"C:\WINDOWS\system32\SQLSRV32.dll");
regKey.SetValue("Server", server);
regKey.SetValue("Database", database);
regKey = Registry.LocalMachine.OpenSubKey("SOFTWARE").OpenSubKey("ODBC").OpenSubKey("ODBC.INI", true).OpenSubKey(
"ODBC Data Sources", true);
regKey.SetValue(dns, "SQL Server");
return true;
}
catch
{
return false;
}
}
方法2:使用P/Invoke(平台调用),需要引用System.Runtime.InteropServices命名空间,具体的函数参数MSDN有比较详细的解释
创建其他类型的ODBC数据源更改相应的驱动和注册表项即可。