SQL Server 2008 의 정시 작업 데이터 추출

2952 단어
이 데 이 터 는 SQLServer 2008 의 xp 를 통 해 추출 합 니 다.cmdshell 구현, E: \ ABC \ Files * 에서 지정 한 파일 을 먼저 E: \ ABC \ \ Files \ \ out. csv 에 기록 한 다음 E: \ ABC \ Files \ \ UTStockData * 하의 UTStockData 에서 시작 하 는 파일 을 out. csv 에 기록 하고 out. csv 를 읽 어서 표 이름 을 dimp. dbo. t 로 읽 습 니 다.ws_bo_filename 표 에서 표 의 표 이름 을 읽 고 데이터 베 이 스 를 추출 한 다음 추출 이 완료 되면 E: \ ABC \ File 로 파일 을 이동 합 니 다.H \ 폴 더 로 가기;이 추출 은 단일 데이터베이스 시트 에 만 적합 합 니 다.사용 하 는 windows 명령: dir 는 파일 경 로 를 표시 하고 bulk insert 데이터 삽입, move 이동 파일 이나 폴 더 에서 추출 한 정시 작업 은 SQLServer 2008 프 록 시 서 비 스 를 통 해 이 루어 집 니 다.
코드 구현:
--         
EXEC sp_configure 'show advanced options', 1
go
--     
RECONFIGURE
Go
--   xp_cmdshell
EXEC sp_configure 'xp_cmdshell', 1
Go
--    
RECONFIGURE
GO

-- =============================================
-- Author:      
-- Create date: 
-- Description: 
-- =============================================
--         

---- E:\ABC\Files\*       E:\ABC\Files\out.csv 
declare  @dirUrl  varchar(200)
declare  @fileName  varchar(200)
declare @sql varchar(300)
Set   @dirUrl = 'E:\ABC\Files\'
Set   @fileName = 'out.csv'
Set   @sql = 'dir  E:\ABC\Files\UT_StockData* /B >     '+@dirUrl+@fileName
EXEC master..xp_cmdshell @sql
Go


---- out.csv              
declare  @dirUrl  varchar(200)
declare  @fileName  varchar(200)
declare @sql varchar(300)
Set   @dirUrl = 'E:\ABC\Files\'
Set   @fileName = 'out.csv'
--         
delete from dimp.dbo.t_ws_bo_filename

Set @sql = 'bcp [dimp].[dbo].[t_ws_bo_filename]  in  "'+@dirUrl+@fileName+'" -c -t","  -k -S"127.0.0.1" -U"dimp" -P"123456"'
exec  master..xp_cmdshell @sql
Go



declare  @dirUrl  varchar(200)
declare @urlFile varchar(200)
declare yoa cursor for
select fileUrl from dimp.dbo.t_ws_bo_filename order by fileUrl
open yoa
    Fetch Next From yoa into @urlFile
    while(@@Fetch_Status=0)
        begin
            declare @sql varchar(300)
            Set   @dirUrl = 'E:\ABC\Files\'

            Set @sql = @dirUrl+@urlFile
            exec ('BULK INSERT [dimp].[dbo].[tmp_user]  FROM '''+@sql+''' WITH (FIELDTERMINATOR = '','', FIRSTROW = 2)')
            --      
            --exec dbo.sp_add_stock
            Fetch Next From yoa into @urlFile
        end
close yoa
Deallocate yoa
GO

--    ,                  
declare @sql varchar(300)
declare  @sdirUrl  varchar(200)
declare  @ddirUrl  varchar(200)
Set   @sdirUrl = 'E:\ABC\Files\'
Set   @ddirUrl = 'E:\ABC\File_H\'
Set   @sql = 'move /Y '+ @sdirUrl + 'UT_StockData* '+@ddirUrl
exec master..xp_cmdshell @sql
GO


--         
EXEC sp_configure 'show advanced options', 1
Go
--     
RECONFIGURE
Go
--   xp_cmdshell
EXEC sp_configure 'xp_cmdshell', 0
Go
--    
RECONFIGURE
GO

좋은 웹페이지 즐겨찾기