sql-server - 我如何将命令传递给 sqsh 并一次性将输出输出到文件?

标签 sql-server database bcp sqsh

我正在尝试设置一个简单的循环来定期查询 bash 中的数据库表。通常我似乎必须这样做:

sqsh -s SERV -U user -P passwd -D db -L bcp_colsep=','

然后在 sqsh 中我必须输入:

select * from some_table where foo=bar
\go -m bcp > /path/to/output.out

我正在尝试使用 sqsh 的 -C 选项来传递这样的命令:

sqsh -s SERV -U user -P passwd -D db -L bcp_colsep=',' -C 'select * from some_table where foo=bar \go -m bcp > /path/to/output.out'

但我不断得到:

Incorrect syntax near '\'.

怎样才能达到预期的效果?

最佳答案

当您使用-C 选项将SQL 语句传递给sqsh 时,\go 命令将被隐式执行。要获得 'bcp' 结果样式的输出,您需要使用 -L 参数设置变量 'style=bcp' 或使用 -mbcp 作为命令行参数并将输出重定向到文件,或使用 sqsh -o 参数指定输出文件名。所以基本上你的命令看起来像:

sqsh -S SERV -U user -P passwd -D db -L bcp_colsep=',' -m bcp \
-C 'select * from some_table where foo=bar' > /path/to/output.out

HTH,马丁

关于sql-server - 我如何将命令传递给 sqsh 并一次性将输出输出到文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21439380/

相关文章:

sql - 在 MSSQL 中使用附加的 max() 条件从数据库中检索每个组中的最后一条记录

sql-server - 如何使用ASP Classic加密和解密SQL Server数据库中的高度敏感信息?

php - MySQL JOIN 2个表并分别获取两个表的总和

sql-server-2012 - SQLState = S1000,NativeError = 0

sql-server - 如何在插入前将触发器写入散列值?

c# - SQL 数据库中的单选按钮值

java - 我应该在每个方法中调用数据库连接设置,还是在构造函数中调用一次?

mysql - MySQL 中嵌套 select 语句

sql-server-2005 - 使用格式文件和批量插入导入 SQL Server

sql-server - 检查 BCP .dat 文件的简单方法?