找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 25366|回复: 4

[文本处理] [已解决]用SELECT读取到SQL字段的值如何赋值给变量?

[复制链接]
发表于 2011-11-20 09:45:19 | 显示全部楼层 |阅读模式
本帖最后由 lovealei 于 2011-11-20 13:58 编辑

在批处理中我用下面的代码运行得到了字段password的值为 123456 ,要如何赋值给变量pwd呢?
OSQL -S localhost -U user -P sqlpwd  -d local -Q "Select password from t1 where userid='%card%'

变量要在批处理中有效,而不是SQL里面...

评分

参与人数 1PB +2 收起 理由
CrLf + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

 楼主| 发表于 2011-11-20 12:11:30 | 显示全部楼层
本帖最后由 lovealei 于 2011-11-20 13:37 编辑

经过一个早上的搜索,终于自己弄好了,把代码贴出来
让有需要的人来拿吧!

  1. OSQL -S %sqlserver% -U %user% -P %sqlpwd% -d local -Q "declare @base64pwd varchar(32);select @base64pwd=(Select password from cur_useraccount where userid='card');print @base64pwd; ">1.TXT
  2. SET /p base64pwd=<1.txt
复制代码
  1. if Defined base64pwd (
  2.      goto ST3
  3.    ) else goto ST4
复制代码
现在我在后面加了个判断,为什么不管%base64pwd% 的值为不为空返回都一样,那里错了??

评分

参与人数 1PB +3 收起 理由
CrLf + 3 感谢分享

查看全部评分

 楼主| 发表于 2011-11-20 13:58:25 | 显示全部楼层
原来是文件不为空,有个换行,唉,又犯老错误了,我改用 findstr 来判断了,因为 base64 最后都有个 = 号,
发表于 2015-11-21 11:32:23 | 显示全部楼层
请教下,如果查询返回的值不止一个,怎么办
发表于 2015-11-21 11:35:24 | 显示全部楼层
回复 4# wumingahui


   去看for 的用法。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-18 10:24 , Processed in 0.019668 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表