楼 主
如何查询出软件SQLServer2000的安装路径?
发表于 2008-09-23 19:52 · 中国 江西 南昌 电信
初级用户
★
积分 38 发帖 17 注册 2008-04-10 15:23 UID 115485 性别 男
状态 离线
比如如何查出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 ]
第 2 楼
发表于 2008-09-23 20:44 · 中国 江西 南昌 电信
初级用户
★
积分 38 发帖 17 注册 2008-04-10 15:23 UID 115485 性别 男
状态 离线
难道是我没描述清楚?我想查出安装sqlserver2000的安装路径,再传给一个变量。但是按照上面的方法,得到的是“ SQLPath REG_SZ C:\Program Files\Microsoft SQL Server\MSSQL.2\MSSQL “。我想得到C:\Program Files\Microsoft SQL Server\MSSQL.2\MSSQL,批处理该如何写?(注意:后面是没带空格的)
第 3 楼
发表于 2008-09-23 20:49 · 美国 惠普HP
版主
★★★★★
积分 9,023 发帖 5,017 注册 2007-05-31 19:39 UID 89899 性别 男
状态 离线
@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%
第 4 楼
发表于 2008-09-23 20:58 · 中国 江西 南昌 电信
初级用户
★
积分 38 发帖 17 注册 2008-04-10 15:23 UID 115485 性别 男
状态 离线
谢谢,HAT.
CN-DOS上的人果然很热心。查了一下午都没结果,没想到在这10分钟就搞定了。
第 5 楼
发表于 2008-09-24 03:43 · 中国 广东 广州 天河区 电信
金牌会员
★★★★
一叶枝头,万树皆春
积分 2,564 发帖 1,127 注册 2006-12-25 22:57 UID 74552 性别 男
状态 离线
你查下本地变量path中应有安装路径
49206C6F766520796F752067757973 54656C3A3133383238343036373837
第 6 楼
发表于 2008-09-24 09:35 · 中国 江西 南昌 电信
初级用户
★
积分 38 发帖 17 注册 2008-04-10 15:23 UID 115485 性别 男
状态 离线
To everest79:path里取的值好像不是安装路径。我是想取sqlserver数据库文件的存放目录
第 7 楼
发表于 2008-09-24 09:38 · 中国 江西 南昌 电信
初级用户
★
积分 38 发帖 17 注册 2008-04-10 15:23 UID 115485 性别 男
状态 离线
to HAT:那段代码有点奇怪,一台机器上都取得了,但在另一台机器上,就取不全了。难道reg真的会漏字符?可是不是中文路径啊?
还想问一下,%%b,是在什么时候取值的?
[ Last edited by augvii on 2008-9-24 at 09:39 AM ]
第 8 楼
Re 7楼
发表于 2008-09-24 09:44 · 美国 惠普HP
版主
★★★★★
积分 9,023 发帖 5,017 注册 2007-05-31 19:39 UID 89899 性别 男
状态 离线
对于漏字符的机器,系统版本是什么?
你可以到注册表编辑器里面看看是否真的有中文:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup\SQLPath
另,昨晚在群里提到的那个调用VBS来读注册表的代码会不会出现同样的问题?
第 9 楼
发表于 2008-09-24 09:56 · 中国 江西 南昌 电信
初级用户
★
积分 38 发帖 17 注册 2008-04-10 15:23 UID 115485 性别 男
状态 离线
没有中文
用三楼的代码这台机器出现:
~-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
--------------------------------------------------------------------------------------------
这个代码看不到效果啊,一闪而过。
第 10 楼
Re 9楼
发表于 2008-09-24 10:13 · 美国 惠普HP
版主
★★★★★
积分 9,023 发帖 5,017 注册 2007-05-31 19:39 UID 89899 性别 男
状态 离线
出问题的机器,版本是什么?
在那台机器上运行这个代码,把结果贴出来看看:
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
第 11 楼
发表于 2008-09-24 10:30 · 中国 江西 南昌 电信
初级用户
★
积分 38 发帖 17 注册 2008-04-10 15:23 UID 115485 性别 男
状态 离线
第一个代码运行结果:
~-1SQLR\Data
--------------------------------------------------------------------------
第二个代码成功取出:
C:\Program Files\Microsoft SQL Server\MSSQL.2\MSSQL
---------------------------------------------------------------------------
我本想取得sqlserver目录下的Date文件的路径,即存放数据库文件的目录。
现在数据库sqlserver2000安装时数据目录和安装目录分开的。
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup\SQLPath查出的是安装目录。不知道存放数据库文件的目录应该查看注册表的哪一项?
第 12 楼
发表于 2008-09-24 10:41 · 中国 江西 南昌 电信
初级用户
★
积分 38 发帖 17 注册 2008-04-10 15:23 UID 115485 性别 男
状态 离线
sqlserver2000数据库文件存放目录对应注册表查到了
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup\SQLDataRoot
现在用VBS可以实现了。谢谢
但我想问下cscript /nologo 是什么意思啊?
第 13 楼
发表于 2008-09-24 11:16 · 美国 惠普HP
版主
★★★★★
积分 9,023 发帖 5,017 注册 2007-05-31 19:39 UID 89899 性别 男
状态 离线
Re 11楼:
把10楼的第一段代码保存为test.bat,双击运行,把完整结果贴出来看看。
Re 12楼:
看看帮助
cscript /?
第 14 楼
发表于 2008-09-24 12:07 · 中国 江西 南昌 电信
初级用户
★
积分 38 发帖 17 注册 2008-04-10 15:23 UID 115485 性别 男
状态 离线
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 ]
第 15 楼
Re 14楼
发表于 2008-09-24 13:37 · 美国 惠普HP
版主
★★★★★
积分 9,023 发帖 5,017 注册 2007-05-31 19:39 UID 89899 性别 男
状态 离线
开始
运行
cmd
reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Setup" /v "SQLPath"
结果是什么?如果没有结果,请检查这台机器是否安装了SQL Server 2000
路径有空格的时候记得加引号:
copy "xx.txt" "%SQL%"
论坛跳转:
— 请选择 —
站务公告 & 版主讨论
意见反馈 & 网友交流
DOS学习入门 & 精彩文章 (教学室)
DOS疑难解答 & 问题讨论 (解答室)
DOS启动盘 & LOGO技术 (启动盘室)
DOS批处理 & 脚本技术(批处理室)
DOS媒体世界 & 网络技术 (多媒体室)
DOS汉化世界 & 中文系统 (中文化室)
DOS开发编程 & 发展交流 (开发室)
DOS软件下载 & 游戏分享 (下载室)
GRUB4DOS、SYSLINUX及其它启动管理软件讨论专区
其它操作系统综合讨论区
WinPE、PowerShell及其它命令行系统专区
贴图灌水、文学娱乐专区
网络日志(Blog)
论坛回收站
├ 链接失效,待修正