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

[文本处理] 操作DB2数据库的批处理echo输出结果不正确?

[复制链接]
发表于 2015-6-23 15:46:06 | 显示全部楼层 |阅读模式
  1. @echo off
  2. setlocal EnableDelayedExpansion
  3.       for /f %%d in ('db2 list db directory ^| awk "{a[NR]=$0}END{for (j=1;j<=NR;j++) if (a[j]~/间接/) print a[j-4]}" ^| awk "{print $3}"') do (
  4.         db2 connect to %%d >D:\monitor\frult.txt
  5.         for /f %%a in ('type D:\monitor\frult.txt ^| grep "本地数据库别名" ^| grep %%d ^| wc -l') do (set among=%%a)
  6.         if !among! equ 1 (
  7.           @echo @@d
  8.           @echo ===  Inf:DB  ===
  9.           @echo ===  成功连接到 %%d 数据库  [[[
  10.           @echo =================================&@echo.

  11.           @echo do my work

  12.           @echo ===  Inf:DB  ==="
  13.           @echo ===  断开 %%d 数据库连接  ]]]
  14.           @db2 connect reset > null
  15.           @echo =================================&@echo.

  16.           @db2 reset MONITOR for db %%d > null
  17.         ) else (
  18.           @echo ===  Inf:DB  ===
  19.           @echo ***  %%d 数据库连接失败!  ***
  20.           @echo =================================&@echo.
  21.         )
  22.       )
  23. )
复制代码
第9行期待结果:===  成功连接到 SAMPLE 数据库  [[[
实际结果为: 数据库  [[[ 到 SAMPLE

第15行期待结果:===  断开 SAMPLE 数据库连接  ]]]
实际结果为: 数据库连接  ]]]

1、为什么?
2、如何解决?
发表于 2015-6-23 21:12:58 | 显示全部楼层
第6行代码下面加一行:
chcp 936
试试效果如何
 楼主| 发表于 2015-6-24 08:38:27 | 显示全部楼层
回复 2# gawk


    效果是对应的多出一行输出:活动代码页: 936
发表于 2015-6-24 09:34:40 | 显示全部楼层
回复 3# taosicai


    把 @echo off 删掉,完整的执行结果发出来。
 楼主| 发表于 2015-6-24 15:54:12 | 显示全部楼层
回复  taosicai


    把 @echo off 删掉,完整的执行结果发出来。
gawk 发表于 2015-6-24 09:34



    谢谢您,先不管它了。
输出到屏幕不正确,但输出到文本就正常了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-18 22:44 , Processed in 0.018815 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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