有没有办法从Windows 2003计算机导出所有ODBC系统DSN?
答案 0 :(得分:10)
系统DSN信息存储在HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBC.INI
注册表项下。您可以将该密钥导出到.reg文件并导入另一台计算机。
更新:
您也可以通过编程方式执行此操作。以下是一些例子:
http://www.codeproject.com/KB/database/DSNAdmin.aspx
答案 1 :(得分:7)
我自己刚刚使用一个非常简单的32位ODBC源的bat脚本
完成了这项工作regedit /e c:\backup\odbc.reg "HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\ODBC\ODBC.INI"
对于64位源,或者如果您使用的是32位操作系统:
regedit /e c:\backup\odbc.reg "HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBC.INI"
这会备份所有DSN,但您可以指定所需的DNS。
答案 2 :(得分:2)
系统DSN存储在HKLM\Software\ODBC\ODBC.INI
节点下的Windows注册表中
因此,如果将此节点导出到* .reg文件并在目标计算机上运行此reg文件,它应该可以正常工作。
唯一的,这个reg文件将包含一些可能是计算机特定的文件路径,例如
c:\WINNT\System32\bla-bla-bla.dll
包括WINNT文件夹,可以在目标计算机上调用WINDOWS
。所以你需要花一点时间来确保* .reg文件中的所有路径都适用于最终导入的目标机器。
答案 3 :(得分:2)
我编写了一些Powershell函数,用于将ODBC连接从一台计算机复制到另一台计算机,它们在以下位置发布(并保持更新):
http://powershell.com/cs/media/p/32510.aspx
# Usage:
# $srcConfig = Get-OdbcConfig srcComputerName
# Import-OdbcConfig trgComputerName $scrConfig
# Only returns data when setting values
function Get-OdbcConfig {
param( $srcName )
if ( Test-Connection $srcName -Count 1 -Quiet ) {
# cycle through the odbc and odbc32 keys
$keys = "SOFTWARE\ODBC\ODBC.INI", "SOFTWARE\Wow6432Node\ODBC\ODBC.INI"
foreach ( $key in $keys ){
# open remote registry
$type = [Microsoft.Win32.RegistryHive]::LocalMachine
$srcReg = [Microsoft.Win32.RegistryKey]::OpenRemoteBaseKey( $type, $srcName )
$OdbcKey = $srcReg.OpenSubKey( $key )
# red through each key
foreach ( $oDrvr in $OdbcKey.GetSubKeyNames() ){
# form the key path
$sKey = $key + "\" + $oDrvr
$oDrvrKey = $srcReg.OpenSubKey( $sKey )
# cycle through each value, capture the key path, name, value and type
foreach ( $oDrvrVal in $oDrvrKey.GetValueNames() ) {
$regObj = New-Object psobject -Property @{
Path = $sKey
Name = $oDrvrVal
Value = $oDrvrKey.GetValue( $oDrvrVal )
Type = $oDrvrKey.GetValueKind( $oDrvrVal )
}
# dump each to the console
$regObj
}
}
}
}
# can't ping
else { Write-Host "$srcName offline" }
}
function Import-OdbcConfig {
param( $trgName, $srcConfig )
if ( Test-Connection $trgName -Count 1 -Quiet ) {
# open remote registry
$type = [Microsoft.Win32.RegistryHive]::LocalMachine
$trgReg = [Microsoft.Win32.RegistryKey]::OpenRemoteBaseKey( $type, $trgName )
# sort out the key paths and cycle through each
$paths = $srcConfig | select -Unique Path
foreach ( $key in $paths ){
# check for the key and create it if it's not there
if ( ! $trgReg.OpenSubKey( $key.Path ) ) { $writeKey = $trgReg.CreateSubKey( $key.Path ) }
# open the path for writing ($true)
$trgKey = $trgReg.OpenSubKey( $key.Path, $true )
# cycle through each value, check to see if it exists, create it if it doesn't
foreach ( $oDrvr in $srcConfig | where { $_.Path -eq $key.Path } ) {
if ( ! $trgKey.GetValue( $oDrvr.Name ) ) {
$oType = $oDrvr.Type
$writeValue = $trgKey.SetValue( $oDrvr.Name, $oDrvr.Value, [Microsoft.Win32.RegistryValueKind]::$oType )
$objObj = new-object psobject -Property @{
Path = $oDrvr.Path
Name = $oDrvr.Name
Value = $trgKey.GetValue( $oDrvr.Name )
Type = $trgKey.GetValueKind( $oDrvr.Name )
}
}
$objObj
}
}
}
# can't ping
else { Write-Host "$srcName offline" }
}
一起使用这些功能,您可以将所有一台计算机的ODBC连接复制到另一台:
$ srcConfig = Get-OdbcConfig srcComputerName
Import-OdbcConfig trgComputerName $ scrConfig
通过在路径上过滤,可以只包含您最喜欢的ODBC连接:
Import-OdbcConfig trgComputerName ( $scrKeys | where { $_.Path -eq "SOFTWARE\ODBC\ODBC.INI\GoodDatabase" } )
或过滤掉您不喜欢的ODBC连接:
Import-OdbcConfig trgComputerName ( $scrKeys | where { $_.Path -ne "SOFTWARE\ODBC\ODBC.INI\DatabaseIHate" } )
Import-OdbcConfig仅在设置值时返回数据或者无法ping目标,如果没有任何内容可以创建,则不会说任何内容。
答案 4 :(得分:1)
如果您无法在那里找到注册,具体取决于它们是否为用户DSN /系统DSN,它们可能会出现在:
[HKEY_USERS \“用户SID(不要'寻找这个,这将是一个漫长的过程 数)\ SOFTWARE \ ODBC \ ODBC.INI]