我想将值从 SQL Server 导出到 txt 文件。我知道 BCP,我需要提供查询或表名才能从表中导出数据。我不想导出数据,但我想导出分配给变量的值。我该怎么做,有什么帮助吗?
问问题
10643 次
1 回答
5
使用查询来收集要导出的变量。像这样的东西:
DECLARE @var1 INTEGER
DECLARE @var2 INTEGER
SELECT @var1 = 10
SELECT @var2 = 22
SELECT 'variable 1' AS VarName, @var1 AS VarValue
UNION
SELECT 'variable 2' AS VarName, @var2 AS VarValue
在以下命令中使用此查询语句。使用 queryout 并将 [querystatement] 替换为上述语句,或使用变量作为查询字符串。
EXEC master..XP_CMDSHELL 'bcp "[querystatement]" queryout "c:\spt_values.dat"'
如果变量需要在语句之外声明:
DECLARE @cmd varchar(1000)
DECLARE @sql varchar(8000)
DECLARE @var1 int
SELECT @var1 = 10
SET @cmd='"select '+CAST(@var1 AS VARCHAR(10))+'"'
SELECT @sql = 'bcp '+@cmd+' queryout I:\File\mytest.txt -c -t -T -S YAMUNA\SQLEXPRESS';
exec xp_cmdshell @sql;
于 2013-09-05T11:14:57.543 回答