1. 程式人生 > >sql server 執行上100mb sql sql sql server 無法執行指令碼 沒有足夠的記憶體繼續執行

sql server 執行上100mb sql sql sql server 無法執行指令碼 沒有足夠的記憶體繼續執行

最近遇到一個問題,在sqlserver的查詢分析器裡面執行一個超過100MB的資料庫指令碼,發現老是報“引發型別為“System.OutOfMemoryException”的異常”,上網查了一下,主要是因為.sql的指令碼檔案過大(一般都超過100M)造成記憶體無法處理這麼多的資料。

  解決辦法有各種各樣,例如:

    1、用記事本開啟指令碼檔案,把檔案依次剪下成10-15M左右的文字檔案,然後再一個個執行;

    2、或者在指令碼匯出時,分表匯出,這樣匯出的文字size也不會很大;

    以上問題雖然簡便,但是步驟繁多,要是表和資料太多,著實是一種勞力折磨!另外如果表之間是有主外來鍵關係的,分資料得小心謹慎,否則報錯讓你抓狂!

    好!說了這麼多,到底有什麼解決方案了呢!

    解決方案就是使用cmd下的osql命令,指令碼大不是問題,關鍵是你得有耐心,執行大指令碼,是需要一定的時間的!實際上也是!

什麼是 Osql?

osql 是一個 Microsoft Windows 32 命令提示符工具,您可以使用它執行 Transact-SQL 語句和指令碼檔案!

如何使用 Osql?

在開始->執行 中鍵入cmd,使用 "OSQL -?"命令,就可以顯示osql命令列的幫助。
注意:osql 工具的選項列表是區分大小的,在使用時注意。

 注意:在上圖中我們可以看到osql 並不支援 SQL Server 2012的所有功能,如果需要使用SQL Server 2012的所有功能可以使用ocmd命令。

 1、使用osql執行單個 Transact-SQL 語句

      在鍵入cmd與下面這一個類似的命令:

    osql -E -q "Transact-SQL statement"  

    例如:sql -E -q "use myDB select * from myTable"

    其中 -E 表示使用 Microsoft Windows NT 身份驗證。

    也可以使用sa賬戶,具體可以看看上面的命令!

    而-q 表示執行 Transact-SQL 語句,但是在查詢結束時不退出 osql。

    如要執行 Transact-SQL 語句並退出 osql,請使用 -Q 引數來代替 -q。

2、使用osql執行一個大指令碼檔案

     將該工具指向一個指令碼檔案,步驟:

    a.建立一個包含一批 Transact-SQL 語句的指令碼檔案(如 myfile.sql)。

    b.開啟命令提示符,鍵入與下面類似的一個命令,然後按 ENTER 鍵:

    osql -E -i input_file

    其中input_file 是指令碼檔案及其完整路徑。例如,如果指令碼檔案 myfile.sql 在 C:\users資料夾中,

    請將引數 myfile 替換為 C:\users\myfile.sql。

    該指令碼檔案的執行結果將出現在控制檯視窗中。

    如果您想將執行結果定向到一個檔案,請向上述命令中新增 -o output_file 引數。例如:

    osql -E -i input_file -o output_file

    其中output_file 是輸出檔案及其完整路徑。

總結

    如果你覺得太麻煩了,可以使用批處理,將常用的一些命令寫在bat檔案中,需要的時候替換一些引數,點選檔案執行即可!是不是比自己去寫一個程式方便多呢???

http://www.cnblogs.com/hai-ping/p/3939150.html