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

[文本处理] [已解决]批处理进行SQL模糊查询字符串时的变量要怎么定义?

[复制链接]
发表于 2011-11-20 18:29:36 | 显示全部楼层 |阅读模式
  1. OSQL -S sqlserver -U user -P sqlpwd  -d local -Q "Select level,Balance from member where (userid like %'08113817'%)
复制代码
上面代码中的 08113817 是一个变量,是让用户输入的,这里如果用变量名就会查询不到
  1. OSQL -S sqlserver -U user -P sqlpwd  -d local -Q "Select level,Balance from member where (userid like %'%ID%'%)
复制代码
要怎么修改下呢??

有4个%

评分

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

查看全部评分

发表于 2011-11-20 19:05:39 | 显示全部楼层
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. set /p ID=请输入:
  4. OSQL -S sqlserver -U user -P sqlpwd  -d local -Q "Select level,Balance from member where (userid like %'!ID!'%)
复制代码

评分

参与人数 1技术 +1 收起 理由
CrLf + 1 乐于助人

查看全部评分

发表于 2011-11-21 22:40:08 | 显示全部楼层
批处理中一个%符号本身要用两个表示,写成%%
@echo off
set /p ID=请输入:
OSQL -S sqlserver -U user -P sqlpwd  -d local -Q "Select level,Balance from member where (userid like '%%%ID%%%')

评分

参与人数 1PB +5 收起 理由
CrLf + 5 乐于助人

查看全部评分

 楼主| 发表于 2011-11-25 22:47:52 | 显示全部楼层
awk 发表于 2011-11-20 19:05



    谢谢哥们
 楼主| 发表于 2011-11-25 22:48:11 | 显示全部楼层
回复 3# powerbat


        谢谢哥们,解决了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-17 06:06 , Processed in 0.030380 second(s), 14 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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