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

[代码合集] [已解决]批处理for语句实现连接postgres数据库问题求解答

[复制链接]
发表于 2015-8-3 11:43:22 | 显示全部楼层 |阅读模式
代码功能,for语句实现连接局域网内计算机(IP为192.168.210.210-192.168.210.147)实现运行一个sql文件,然后将运行结果输出到目录,输出结果的时候出问题了,求解答
输出的文件名字test_192.168.210   t.txt存放的是IP地址(192.168.210.210,192.168.210.211》》),为什么文件名字不是test_192.168.210.210呢,这样就不能把每个IP运行sql的结果输出来,最后只有一个文件test_192.168.210.txt 
代码:
  1. @echo off
  2. set PGPASSWORD=postgres
  3. for /f "delims=, " %%i in (t.txt) do psql -h %%i -p 5432 -U postgres  -d tzxserver -f d:/2000.sql -o d:/test_%%~ni.txt
  4. pause
复制代码

评分

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

查看全部评分

发表于 2015-8-3 12:53:35 | 显示全部楼层
@echo off
set PGPASSWORD=postgres
for /f "delims=, " %%i in (t.txt) do psql -h %%i -p 5432 -U postgres  -d tzxserver -f d:/2000.sql -o d:/test_%%i.txt
pause

试试这样

评分

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

查看全部评分

 楼主| 发表于 2015-8-3 14:50:30 | 显示全部楼层
好了,非常感谢,不过有个问题还想请教,昨天我用自己的电脑,win7-32位,写的也是%%i.txt,提示忽略多余参数.txt。如果直接写d:/%%i就输出以IP地址命名的文件,没有扩展名,后来在试验,就是代码还是写d:%%i,也是输出127.0.0命名的文件,老是少最后一位  127.0.0.1。这win732位和xp运行该语句有什么区别啊?都是把;D:\Program Files\PostgreSQL\9.0\bin;添加到path环境变量里了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-18 14:15 , Processed in 0.018878 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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