forked from bulentgucuk/DBA-Scripts
-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathBCP Out Sample.sql
More file actions
60 lines (48 loc) · 1.27 KB
/
BCP Out Sample.sql
File metadata and controls
60 lines (48 loc) · 1.27 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
SET NOCOUNT ON;
GO
SET ANSI_PADDING ON;
GO
SET QUOTED_IDENTIFIER ON;
GO
DECLARE @DatabaseName VARCHAR(32) = 'CU'
, @ServerName VARCHAR(32) = 'SSBCIDW04'
, @BcpFileLocation VARCHAR(128) = 'D:\';
IF OBJECT_ID('tempdb..#BcpOut') IS NOT NULL
DROP TABLE #BcpOut;
CREATE TABLE #BcpOut (
RowId INT IDENTITY (1,1) NOT NULL
, DatabaseName VARCHAR(32) NOT NULL
, TableName VARCHAR(128) NOT NULL
, BcpFileLocation VARCHAR(128) NOT NULL
, ServerName VARCHAR(32) NOT NULL
, OpStartDateTime DATETIME NULL
, OpEndDateTime DATETIME NULL
)
INSERT INTO #BcpOut
(
DatabaseName ,
TableName ,
BcpFileLocation ,
ServerName
)
VALUES
(@DatabaseName, 'dbo.TK_TRANS_ITEM_EVENT', @BcpFileLocation, @ServerName);
DECLARE @cmd VARCHAR(MAX)
, @MaxRowId INT
SELECT @MaxRowId = MAX(RowId)
FROM #BcpOut
WHILE @MaxRowId > 0
BEGIN
SELECT @cmd = 'EXEC XP_CMDSHELL ''BCP ' + DatabaseName + '.' + TableName + ' OUT ' + BcpFileLocation + TableName + '.dat -n -b 5000 -E -T -S ' + ServerName + ''''
FROM #BcpOut
WHERE RowId = @MaxRowId;
UPDATE #BcpOut
SET OpStartDateTime = GETDATE()
WHERE RowId = @MaxRowId;
PRINT @cmd
--EXEC (@cmd)
UPDATE #BcpOut
SET OpEndDateTime = GETDATE()
WHERE RowId = @MaxRowId;
SELECT @MaxRowId = @MaxRowId - 1;
END