标题: 如何查询出软件SQLServer2000的安装路径?
[打印本页]
作者: augvii
时间: 2008-9-23 19:52
标题: 如何查询出软件SQLServer2000的安装路径?
比如如何查出sqlserver安装的路径?
我用了下面的语句但是除了路径,还有其它信息,请问还有什么方法能直接查出路径吗?
-----------------------------------------------------------------------------------------------------------------
FOR /F "delims=" %%i IN ('@reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup" /v
SQLPath') DO @SET mypath=%%i
-----------------------------------------------------------------------------------------------------------------
[
Last edited by augvii on 2008-9-28 at 11:41 ]
作者: augvii
时间: 2008-9-23 20:44
难道是我没描述清楚?我想查出安装sqlserver2000的安装路径,再传给一个变量。但是按照上面的方法,得到的是“ SQLPath REG_SZ C:\Program Files\Microsoft SQL Server\MSSQL.2\MSSQL “。我想得到C:\Program Files\Microsoft SQL Server\MSSQL.2\MSSQL,批处理该如何写?(注意:后面是没带空格的)
作者: HAT
时间: 2008-9-23 20:49
@echo off
for /f "skip=4 tokens=1,2 delims=:" %%a in ('reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup" /v "SQLPath"') do (
set SQLL=%%a
set SQLR=%%b
)
set SQL=%SQLL:~-1%:%SQLR%
echo %SQL%
作者: augvii
时间: 2008-9-23 20:58
谢谢,HAT.
CN-DOS上的人果然很热心。查了一下午都没结果,没想到在这10分钟就搞定了。
作者: everest79
时间: 2008-9-24 03:43
你查下本地变量path中应有安装路径
作者: augvii
时间: 2008-9-24 09:35
To everest79:path里取的值好像不是安装路径。我是想取sqlserver数据库文件的存放目录
作者: augvii
时间: 2008-9-24 09:38
to HAT:那段代码有点奇怪,一台机器上都取得了,但在另一台机器上,就取不全了。难道reg真的会漏字符?可是不是中文路径啊?
还想问一下,%%b,是在什么时候取值的?
[
Last edited by augvii on 2008-9-24 at 09:39 AM ]
作者: HAT
时间: 2008-9-24 09:44
标题: Re 7楼
对于漏字符的机器,系统版本是什么?
你可以到注册表编辑器里面看看是否真的有中文:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup\SQLPath
另,昨晚在群里提到的那个调用VBS来读注册表的代码会不会出现同样的问题?
作者: augvii
时间: 2008-9-24 09:56
没有中文
用三楼的代码这台机器出现:
~-1SQLR\Data
--------------------------------------------------------
@echo off
>"%temp%\my.vbs"
echo Set WshShell = WScript.CreateObject("WScript.Shell")
>>"%temp%\my.vbs"
echo WScript.Echo WshShell.RegRead("HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup")
for /f "delims=" %%a in ('cscript /nologo "%temp%\my.vbs"') do set SQL=%%a
echo %SQL%
pause
--------------------------------------------------------------------------------------------
这个代码看不到效果啊,一闪而过。
作者: HAT
时间: 2008-9-24 10:13
标题: Re 9楼
出问题的机器,版本是什么?
在那台机器上运行这个代码,把结果贴出来看看:
for /f "skip=4 tokens=1,2 delims=:" %%a in ('reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup" /v "SQLPath"') do (
set SQLL=%%a
set SQLR=%%b
)
set SQL=%SQLL:~-1%:%SQLR%
echo %SQL%
pause
调用VBS的代码,是不是应该这样:
@echo off
>"%temp%\my.vbs" echo Set WshShell = WScript.CreateObject("WScript.Shell")
>>"%temp%\my.vbs" echo WScript.Echo WshShell.RegRead("HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup\SQLPath")
for /f "delims=" %%a in ('cscript /nologo "%temp%\my.vbs"') do set SQL=%%a
echo %SQL%
pause
作者: augvii
时间: 2008-9-24 10:30
第一个代码运行结果:
~-1SQLR\Data
--------------------------------------------------------------------------
第二个代码成功取出:
C:\Program Files\Microsoft SQL Server\MSSQL.2\MSSQL
---------------------------------------------------------------------------
我本想取得sqlserver目录下的Date文件的路径,即存放数据库文件的目录。
现在数据库sqlserver2000安装时数据目录和安装目录分开的。
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup\SQLPath查出的是安装目录。不知道存放数据库文件的目录应该查看注册表的哪一项?
作者: augvii
时间: 2008-9-24 10:41
sqlserver2000数据库文件存放目录对应注册表查到了
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup\SQLDataRoot
现在用VBS可以实现了。谢谢
但我想问下cscript /nologo 是什么意思啊?
作者: HAT
时间: 2008-9-24 11:16
Re 11楼:
把10楼的第一段代码保存为test.bat,双击运行,把完整结果贴出来看看。
Re 12楼:
看看帮助
cscript /?
作者: augvii
时间: 2008-9-24 12:07
C:\Documents and Settings\Administrator\桌面\sqltest-augvii>for /F "skip=4 token
s=1,2 delims=:" %a in ('reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLSe
rver\Setup" /v "SQLPath"') do (
set SQLL=%a
set SQLR=%b
)
C:\Documents and Settings\Administrator\桌面\sqltest-augvii>set SQL=~-1SQLR
C:\Documents and Settings\Administrator\桌面\sqltest-augvii>echo ~-1SQLR
~-1SQLR
C:\Documents and Settings\Administrator\桌面\sqltest-augvii>pause
请按任意键继续. . .
我是放在桌面运行的,刚刚复制到d:\也是不行。。。
==================================================
还有个问题:copy xx.txt %SQL% 有错吗? (xx.txt为同一目录下的文件,SQL为赋了一个路径的变量)
[
Last edited by augvii on 2008-9-24 at 12:11 PM ]
作者: HAT
时间: 2008-9-24 13:37
标题: Re 14楼
开始
运行
cmd
reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup" /v "SQLPath"
结果是什么?如果没有结果,请检查这台机器是否安装了SQL Server 2000
路径有空格的时候记得加引号:
copy "xx.txt" "%SQL%"
作者: augvii
时间: 2008-9-24 13:43
路径有空格的时候记得加引号:
----------------------------------------------------
正解。好多细节不知道,HAT谢谢了。
作者: HAT
时间: 2008-9-24 13:56
标题: 多看教程
批处理的教学
http://www.cn-dos.net/forum/viewthread.php?tid=2338
批处理最完整人性化教程
http://www.cn-dos.net/forum/viewthread.php?tid=18482
批处理新手FAQ整理
http://www.cn-dos.net/forum/viewthread.php?tid=34049
中国DOS联盟批处理室经典帖子合集
http://www.cn-dos.net/forum/viewthread.php?tid=31551
作者: augvii
时间: 2008-9-24 14:26
嗯,学习中。。。
作者: everest79
时间: 2008-9-25 11:46
还有个方法就是获取SQL服务程序的路径
作者: augvii
时间: 2008-9-25 11:49
也是到注册表里找吗?
作者: chenall
时间: 2008-9-25 12:35
用REG命令行读注册表取得的字符串有时是不完整的,虽然显示的是完整的,便重定向一下可以发现后面会少字符.具体原因未知,很早以后想用REG取注册表指定路径时才发现的这个问题.
解决方法可以使用VBS,或其它工具.
作者: HAT
时间: 2008-9-25 14:19
标题: Re 21楼
测试环境:xp sp2 en
测试结果:no problem
Quote: |
Microsoft Windows XP [Version 5.1.2600]
(C) Copyright 1985-2001 Microsoft Corp.
C:\Test>reg query HKEY_CURRENT_USER\Software\BitComet /ve
! REG.EXE VERSION 3.0
HKEY_CURRENT_USER\Software\BitComet
<NO NAME> REG_SZ C:\Personal\BitComet 0.85
C:\Test>reg query HKEY_CURRENT_USER\Software\BitComet /ve>a.txt
C:\Test>type a.txt
! REG.EXE VERSION 3.0
HKEY_CURRENT_USER\Software\BitComet
<NO NAME> REG_SZ C:\Personal\BitComet 0.85 |
|
你说的问题是xp sp2 cs的reg.exe在搜索结果中包含中文时的问题吧:
http://www.cn-dos.net/forum/viewthread.php?tid=22202