首頁 資料庫 mysql教程 Sql Server2005 利用XML一次更新多条记录

Sql Server2005 利用XML一次更新多条记录

Jun 07, 2016 pm 03:08 PM
sql xml 使用 更新

很久么写博客了,惭愧。今天终于搞定了很久以来一直郁闷的一个问题,写个日志备注下。 我想很多人都知道,在oracle里面,存储过程里面可以传入数组(如int[]),也就是说,可以传多条 记录 到数据,从而一起 更新 。减少数据库的请求次数。 但SqlServer呢?b

很久么写博客了,惭愧。今天终于搞定了很久以来一直郁闷的一个问题,写个日志备注下。
我想很多人都知道,在oracle里面,存储过程里面可以传入数组(如int[]),也就是说,可以传多条记录到数据,从而一起更新。减少数据库的请求次数。
但SqlServer呢?bulk Insert这个很多人都知道,我也知道,但可惜,我从来没用过,只有导数据的时候才会考虑,但导数据DTS不是更方便吗?
手头的一个项目,有几个功能,每次需要更新N(N记录,记录不多,但如果每次只更新一条,循环insert,那每个功能需要N次请求数据库,如果有1000个并发,那数据库除了做你这个事情,其他的活不用干了。所以,需要尽量减少数据库请求,做到一次更新所有的记录
幸好,SqlServer给我们提供了一个新功能,利用XML(2000好像是没有这个功能的)。
先来假定一个这样的需求:用户更新一个book,同时需要更新N个章节。
一般的思路是这样,先更新book,然后循环章节数,N次更新数据的章节表。大家可以看下这个性能。

那我们用XML试试

Sql Server2005 利用XML一次更新多条记录利用XML更新的存储过程

Create PROCEDURE UP_Book_Insert
(
    
@BookId        INT,
    
@ChapterXml    XML

AS
BEGIN
CREATE TABLE #table
(
    ChapterId        
INT,
    ChapterName        
VARCHAR(255),
    Price            
INT
);
INSERT #table
    
SELECT *
    
FROM   (
               
SELECT X.C.value('Id[1]''int'AS ChapterId,
                      X.C.value(
'Name[1]''varchar(255)'AS ChapterName,
                      X.C.value(
'Price[1]','int'AS Price
               
FROM   @ChapterXml.nodes('Chapter'AS X(C)    --注意:这里的X(C)命名空间是需要的
           ) t;    
    
INSERT INTO tbChapter(BookId,ChapterId,ChapterName,Price) 
    
SELECT @BookId,ChapterId,ChapterName,Price from #table;
END

其实,在存储过程里面可以把临时表去掉的。

然后我们执行下看看

Sql Server2005 利用XML一次更新多条记录执行存储过程

exec UP_Book_Insert 10000,'268第268章100273第273章100275第275章100'

怎么样?不错吧。只需要在存储过程里面对XML格式进行解析。

而在c#里面,XML格式可以传入DbType.String类型就可以了。

再写一个函数来生成XML格式的字符串

Sql Server2005 利用XML一次更新多条记录生成XML格式的函数

public static string FormatXmlInfo(ListChapterInfo> list)
        {
            
if (list==null||list.Count0)
            {
                
return String.Empty;
            }
            StringBuilder sb = new StringBuilder();
            
foreach (ChapterInfo info in list)
            {
                sb.AppendFormat("{0}{1}{2}", info.ChapterId, info.ChapterName, info.Price);
            }
            
return sb.ToString();
        }


 好了,完成了。

性能具体怎么样,还没进行测试,但肯定的一点是,比多次请求数据库,或者在存储过程里面循环分割字符串效率要高。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

暴雪戰網更新一直卡在45%怎麼解決? 暴雪戰網更新一直卡在45%怎麼解決? Mar 16, 2024 pm 06:52 PM

  暴雪戰網更新一直卡在45%怎麼解決?近期有很多人在更新軟體的時候,都是卡在45%的進度條,重啟多次還是會卡住,那麼這種情況應該要如何解決,我們可以透過重新安裝客戶端、切換地區、刪除文件的方式來處理,本期軟體教程就來分享操作步驟,希望能帶給更多的人幫助。  暴雪戰網更新一直卡在45%怎麼解決  一、客戶端  1、首先需要確認你的客戶是官網下載的官方版本。  2、如果不是的話,使用者可以進入亞服網址來進行下載。  3、進入以後點選右上角的下載就可以了。  注意:安裝的時候一定不要選擇簡體中文。

Hibernate 框架中 HQL 和 SQL 的差異是什麼? Hibernate 框架中 HQL 和 SQL 的差異是什麼? Apr 17, 2024 pm 02:57 PM

HQL和SQL在Hibernate框架中進行比較:HQL(1.物件導向語法,2.資料庫無關的查詢,3.類型安全),而SQL直接操作資料庫(1.與資料庫無關的標準,2.可執行複雜查詢和資料操作)。

如何在Ubuntu 24.04上安裝Angular 如何在Ubuntu 24.04上安裝Angular Mar 23, 2024 pm 12:20 PM

Angular.js是一種可自由存取的JavaScript平台,用於建立動態應用程式。它允許您透過擴展HTML的語法作為模板語言,以快速、清晰地表示應用程式的各個方面。 Angular.js提供了一系列工具,可協助您編寫、更新和測試程式碼。此外,它還提供了許多功能,如路由和表單管理。本指南將討論在Ubuntu24上安裝Angular的方法。首先,您需要安裝Node.js。 Node.js是一個基於ChromeV8引擎的JavaScript運行環境,可讓您在伺服器端執行JavaScript程式碼。要在Ub

Windows無法存取指定裝置、路徑或文件 Windows無法存取指定裝置、路徑或文件 Jun 18, 2024 pm 04:49 PM

小夥伴電腦出現這樣的故障,開啟「此電腦」和C碟檔案會提示「Explorer.EXEWindows無法存取指定裝置、路徑或檔案。你可能沒有適當的權限存取存取專案。」包括資料夾、檔案、此電腦、回收站等,雙擊都會彈出這樣的窗口,右鍵又是正常的。這是系統更新導致,如果你也遇到這樣的狀況,下面小編教大家如何解決。一,開啟登錄編輯程式Win+R,輸入regedit,或右鍵開始選單執行輸入regedit;二,定位登錄機「電腦\HKEY_CLASSES_ROOT\PackagedCom\ClassInd

微星顯卡驅動怎麼更新?微星顯示卡驅動下載安裝步驟 微星顯卡驅動怎麼更新?微星顯示卡驅動下載安裝步驟 Mar 13, 2024 pm 08:49 PM

  微星顯示卡是市面上主流的顯示卡品牌,我們知道顯示卡都需要安裝驅動才能發揮效能,並保證相容性。那麼微星顯示卡驅動要怎麼更新到最新版本呢?一般微星顯卡驅動可以官網下載驅動安裝,以下就來了解一下。  顯卡驅動更新方法:  1.首先我們進入「微星官網」。  2.進入後點選右上角「搜尋」按鈕並輸入自己的顯示卡型號。  3.然後找到對應的顯示卡點開詳情頁。  4.隨後進入上方「技術支援」選項。  5.最後在“驅動器&下載”

Windows永久暫停更新,Windows關閉自動更新 Windows永久暫停更新,Windows關閉自動更新 Jun 18, 2024 pm 07:04 PM

Windows更新可能導致以下一些問題:1.相容性問題:某些應用程式、驅動程式或硬體裝置可能與新的Windows更新不相容,導致它們無法正常運作或崩潰。 2.效能問題:有時,Windows更新可能會導致系統變得更慢或出現效能下降的情況。這可能是由於新的功能或改進需要更多資源來運作。 3.系統穩定性問題:某些用戶報告稱,在安裝Windows更新後,系統可能會出現意外的崩潰或藍屏錯誤。 4.資料遺失:在罕見的情況下,Windows更新可能會導致資料遺失或檔案損壞。這是為什麼在進行任何重要的更新之前,請備份您

抖音怎麼更新最新版本 抖音怎麼更新最新版本 Mar 27, 2024 am 11:06 AM

1.打開抖音app,點選右下角的【我】,點選右上角的【三條槓】圖示。 2.選擇【設定】,點選進入設定介面,找到並點選【通用設定】。 3.在通用設定介面下拉,找到並點選【檢查更新】。 4.如果使用者目前使用的版本不是最新版本,就會出現新版本的更新提示,點選【升級】。 5.等待安裝包下載完畢,系統會自動安裝,點選【繼續安裝】即可。 6.如果目前已經是最新版本,則會出現【沒有可用的更新版本】的提

Outlook在更新收件匣時卡住了; Outlook在更新收件匣時卡住了; Mar 25, 2024 am 09:46 AM

當Outlook在更新收件匣時發生問題,可能會影響工作效率。本文將介紹一些簡單的故障排除步驟,幫助您解決問題並讓Outlook恢復正常。為什麼Outlook總是卡在收件匣更新上?Outlook更新收件匣時可能會出現卡頓的情況,常見原因包括網路問題、信箱容量過大,以及防毒軟體或防火牆的影響。外部插件或資料檔案損壞也可能導致這種情況發生。接下來,我們將詳細探討這些可能的原因,並提供解決方案。修正Outlook卡住更新收件匣如果Outlook無法更新你的收件匣,請參考下面列出的解決方案:重啟前景禁

See all articles