Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

Esporta i valori da SQL Server in un file txt

Utilizza una query per raccogliere le variabili che desideri esportare. Qualcosa del genere:

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

Utilizzare questa istruzione di query nel comando seguente. Usa queryout e sostituisci [querystatement] con l'istruzione sopra, oppure usa una variabile per la stringa di query.

EXEC master..XP_CMDSHELL 'bcp "[querystatement]" queryout "c:\spt_values.dat"'

Se la variabile deve essere dichiarata al di fuori dell'istruzione:

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 '[email protected]+' queryout I:\File\mytest.txt -c -t -T -S YAMUNA\SQLEXPRESS';
exec xp_cmdshell @sql;