sql 二進位檔案的匯入匯出

來源:互聯網
上載者:User

   /*--bcp-二進位檔案的匯入匯出

  支援image,text,ntext欄位的匯入/匯出

  image適合於二進位檔案;text,ntext適合於文本資料檔案

  注意:匯入時,將覆蓋滿足條件的所有行

  匯出時,將把所有滿足條件的行也出到指定檔案中

  此預存程序僅用bcp實現

  鄒建 2003.08-----------------*/

  /*--調用樣本

  --資料匯出

  exec p_binaryIO 'zj','','','acc_示範資料..tb','img','c:zj1.dat'

  --資料匯出

  exec p_binaryIO 'zj','','','acc_示範資料..tb','img','c:zj1.dat','',0

  --*/

  if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_binaryIO]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)

  drop procedure [dbo].[p_binaryIO]

  GO

  Create proc p_binaryIO

  @servename varchar (30),--伺服器名稱

  @username varchar (30), --使用者名稱

  @password varchar (30), --密碼

  @tbname varchar (500), --資料庫..表名

  @fdname varchar (30), --欄位名

  @fname varchar (1000), --目錄+檔案名稱,處理過程中要使用/覆蓋:@filename+.bak

  @tj varchar (1000)='', --處理條件.對於資料匯入,如果條件中包含@fdname,請指定表名首碼

  @isout bit=1 --1匯出((預設),0匯入

  AS

  declare @fname_in varchar(1000) --bcp處理應答檔案名稱

  ,@fsize varchar(20) --要處理的檔案的大小

  ,@m_tbname varchar(50) --暫存資料表名

  ,@sql varchar(8000)

  --則取得匯入檔案的大小

  if @isout=1

  set @fsize='0'

  else

  begin

  create table #tb(可選名 varchar(20),大小 int

  ,建立日期 varchar(10),建立時間 varchar(20)

  ,上次寫操作日期 varchar(10),上次寫操作時間 varchar(20)

  ,上次訪問日期 varchar(10),上次訪問時間 varchar(20),特性 int)

  insert into #tb

  exec master..xp_getfiledetails @fname

  select @fsize=大小 from #tb

  drop table #tb

  if @fsize is null

  begin

  print '檔案未找到'

  return

  end

  end

  --產生資料處理應答檔案

  set @m_tbname='[##temp'+cast(newid() as varchar(40))+']'

  set @sql='select * into '+@m_tbname+' from(

  select null as 類型

  union all select 0 as 首碼

  union all select '+@fsize+' as 長度

  union all select null as 結束

  union all select null as 格式

  ) a'

  exec(@sql)

  select @fname_in=@fname+'_temp'

  ,@sql='bcp "'+@m_tbname+'" out "'+@fname_in

  +'" /S"'+@servename

  +case when isnull(@username,'')='' then ''

  else '" /U"'+@username end

  +'" /P"'+isnull(@password,'')+'" /c'

  exec master..xp_cmdshell @sql

  --刪除暫存資料表

  set @sql='drop table '+@m_tbname

  exec(@sql)

  if @isout=1

  begin

  set @sql='bcp "select top 1 '+@fdname+' from '

  +@tbname+case isnull(@tj,'') when '' then ''

  else ' where '+@tj end

  +'" queryout "'+@fname

  +'" /S"'+@servename

  +case when isnull(@username,'')='' then ''

  else '" /U"'+@username end

  +'" /P"'+isnull(@password,'')

  +'" /i"'+@fname_in+'"'

  exec master..xp_cmdshell @sql

  end

  else

  begin

  --為資料匯入準備暫存資料表

  set @sql='select top 0 '+@fdname+' into '

  +@m_tbname+' from ' +@tbname

  exec(@sql)

  --將資料匯入到暫存資料表

  set @sql='bcp "'+@m_tbname+'" in "'+@fname

  +'" /S"'+@servename

  +case when isnull(@username,'')='' then ''

  else '" /U"'+@username end

  +'" /P"'+isnull(@password,'')

  +'" /i"'+@fname_in+'"'

  exec master..xp_cmdshell @sql

  --將資料匯入到正式表中

  set @sql='update '+@tbname

  +' set '+@fdname+'=b.'+@fdname

  +' from '+@tbname+' a,'

  +@m_tbname+' b'

  +case isnull(@tj,'') when '' then ''

  else ' where '+@tj end

  exec(@sql)

  --刪除資料處理暫存資料表

  set @sql='drop table '+@m_tbname

  end

  --刪除資料處理應答檔案

  set @sql='del '+@fname_in

  exec master..xp_cmdshell @sql

  go

相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。