日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

比較SQL Server數(shù)據(jù)庫導(dǎo)入導(dǎo)出數(shù)據(jù)方式(2)_Mssql數(shù)據(jù)庫教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:如何在SQL Server數(shù)據(jù)庫中拆分字符串函數(shù)
SQL Server數(shù)據(jù)庫中拆分字符串函數(shù)的具體方法: 以下為引用的內(nèi)容:   CREATE  FUNCTION uf_StrSplit '1.1.2.50','.'   (@origStr varc

2. 使用命令行BCP導(dǎo)入導(dǎo)出數(shù)據(jù)

很多大型的系統(tǒng)不僅僅提供了友好的圖形用戶接口,同時也提供了命令行方式對系統(tǒng)進行控制。在SQL Server中除了可以使用SQL語句對數(shù)據(jù)進行操作外,還可以使用一個命令行工具BCP對數(shù)據(jù)進行同樣的操作。BCP是基于DB-Library 客戶端庫的工具。它的功能十分強大,BCP能夠以并行方式將數(shù)據(jù)從多個客戶端大容量復(fù)制到單個表中,從而大大提高了裝載效率。但在執(zhí)行并行操作時要注意的是只有使用基于 ODBC 或 SQL OLE DB 的 API 的應(yīng)用程序才可以執(zhí)行將數(shù)據(jù)并行裝載到單個表中的操作。

BCP可以將SQL Server中的數(shù)據(jù)導(dǎo)出到任何OLE DB所支持的數(shù)據(jù)庫的,如下面的語句是將authors表導(dǎo)出到excel文件中。

bcp pubs.dbo.authors out c:\temp1.xls

-c -q -S"GNETDATA/GNETDATA" -U"sa" -P"password"

BCP不僅能夠通過命令行執(zhí)行,同時也可以通過SQL執(zhí)行,這需要一個系統(tǒng)存儲過程xp_cmdshell來實現(xiàn),如上面的命令可改寫為如下形式。

EXEC master..xp_cmdshell 'bcp pubs.dbo.authors out

c:\temp1.xls -c -q -S"GNETDATA/GNETDATA" -U"sa" -P"password"'

3. 使用數(shù)據(jù)轉(zhuǎn)換服務(wù)(DTS)導(dǎo)入導(dǎo)出數(shù)據(jù)

DTS是SQL Server中導(dǎo)入導(dǎo)出數(shù)據(jù)的核心,它除有具有SQL和命令行工具BCP相應(yīng)的功能外,還可以靈活地通過VBScript、JScript等腳本語言對數(shù)據(jù)進行檢驗、凈化和轉(zhuǎn)換。

SQL Server為DTS提供了圖形用戶接口,用戶可以使用圖形界面導(dǎo)入導(dǎo)出數(shù)據(jù),并對數(shù)據(jù)進行相應(yīng)的處理。同時,DTS還以com組件的形式提供編程接口,也就是說任何支持com組件的開發(fā)工具都可以利用com組件使用DTS所提供的功能。DTS在SQL Server中可以保存為不同的形式,可以是包的形式,也可以保存成Visual Basic源程序文件,這樣只要在VB中編譯便可以使用DTS com組件了。

DTS和其它數(shù)據(jù)導(dǎo)入導(dǎo)出方式最大的不同就是它可以在處理數(shù)據(jù)的過程中對每一行數(shù)據(jù)進行深度處理。以下是一段VBScript代碼,這段代碼在處DTS理每一條記錄時執(zhí)行,DTSDestination表示目標(biāo)記錄,DTSSource表示源記錄,在處理“婚姻狀況”時,將源記錄中的“婚姻狀況”中的0或1轉(zhuǎn)換成目標(biāo)記錄中“已婚”或“未婚”。

Function Main()

DTSDestination("姓名") = DTSSource("姓名")

DTSDestination("年齡") = DTSSource("年齡")

If DTSDestination("婚姻狀況") = 1 Then

DTSDestination("婚姻狀況") = "已婚"

Else

DTSDestination("婚姻狀況") = "未婚"

End If

Main = DTSTransformStat_OK

End Function

上述的三種數(shù)據(jù)導(dǎo)入導(dǎo)出方法各有其利弊,它們之間的相互比較如圖1如示。

二、性能的比較

使用Transact-SQL方式。如果是SQL Server數(shù)據(jù)庫之間的導(dǎo)入導(dǎo)出,速度將非�?�,但是使用OPENDATASOURCE和OPENROWSET方法利用OLE DB Provider打開并操作數(shù)據(jù)庫時速度會慢一些。

使用BCP命令方式。如果不需要對數(shù)據(jù)進行驗證等操作的話,使用它還是非�?斓�,這是因為它的內(nèi)部使用c接口的DB-library,所以在操作數(shù)據(jù)庫時速度有很大的提升。

使用DTS方式導(dǎo)數(shù)據(jù)應(yīng)該是最好的方式了。由于它整合了Microsoft Universal Data Access技術(shù)與Microsoft ActiveX技術(shù),因此不僅可以靈活地處理數(shù)據(jù),而且在數(shù)據(jù)導(dǎo)入導(dǎo)出的效率是非常高的。

總結(jié)

SQL Server提供了豐富的數(shù)據(jù)導(dǎo)入導(dǎo)出方法,這給我們提供了更多的選擇,但是這又會給我們帶來一個新問題:如何根據(jù)具體情況選擇合適的數(shù)據(jù)導(dǎo)入導(dǎo)出方法呢?我在這里提供一些個人的建議,希望能對讀者起到一定的指導(dǎo)作用。

如果是在SQL Server數(shù)據(jù)庫之間進行數(shù)據(jù)導(dǎo)入導(dǎo)出時,并且不需要對數(shù)據(jù)進行復(fù)雜的檢驗,最好使用Transact-SQL方法進行處理,因為在SQL Server數(shù)據(jù)庫之間進行數(shù)據(jù)操作時,SQL是非�?斓�。當(dāng)然,如果要進行復(fù)雜的操作,如數(shù)據(jù)檢驗、轉(zhuǎn)換等操作時,最好還是使用DTS進行處理,因為DTS不光導(dǎo)數(shù)據(jù)效率高,而且能夠?qū)?shù)據(jù)進行深度控制。但是DTS的編程接口是基于com的,并且這個接口十分復(fù)雜,因此,使用程序調(diào)用DTS將變也會變得很復(fù)雜,因此, 當(dāng)數(shù)據(jù)量不是很大,并且想將數(shù)據(jù)導(dǎo)入導(dǎo)出功能加入到程序中,而且沒有復(fù)雜的數(shù)據(jù)處理功能時,可以使用OPENDATASOURCE或OPENROWSET進行處理。

BCP命令并不太適合通過程序來調(diào)用,如果需要使用批量的方式導(dǎo)數(shù)據(jù),可以通過批處理文件調(diào)用BCP命令,這樣做即不需要編寫大量的程序,也無需在企業(yè)管理器中通過各種操作界面的切換來進行數(shù)據(jù)導(dǎo)入導(dǎo)出。因此,它比較適合在客戶端未安企業(yè)管理器或使用SQL Server Express時對數(shù)據(jù)進行快速導(dǎo)入導(dǎo)出的場合。

分享:淺談在SQL Server2005中進行錯誤捕捉
任何程序都可能出現(xiàn)錯誤,在SQL Server中執(zhí)行Transact-SQL也不例外。如果在Transact-SQL中發(fā)生了錯誤,一般有兩種捕捉錯誤的方法,一種是在客戶端代碼(如C#、Delphi等)中使用類似try

共2頁上一頁12下一頁
來源:模板無憂//所屬分類:Mssql數(shù)據(jù)庫教程/更新時間:2009-08-02
相關(guān)Mssql數(shù)據(jù)庫教程