@@ROWCOUNT अंतिम . से प्रभावित पंक्तियों की संख्या देगा SQL कथन, विचाराधीन कमांड के बाद इसे स्थानीय चर में कैप्चर करना सबसे अच्छा है, क्योंकि अगली बार जब आप इसे देखेंगे तो इसका मान बदल जाएगा:
DECLARE @Rows int
DECLARE @TestTable table (col1 int, col2 int)
INSERT INTO @TestTable (col1, col2) select 1,2 union select 3,4
SELECT @example@sqldat.com@ROWCOUNT
SELECT @Rows AS Rows,@@ROWCOUNT AS [ROWCOUNT]
आउटपुट:
(2 row(s) affected)
Rows ROWCOUNT
----------- -----------
2 1
(1 row(s) affected)
आपको Rows मिलती है 2 का मान, सम्मिलित पंक्तियों की संख्या, लेकिन ROWCOUNT 1 है क्योंकि SELECT @example@sqldat.com@ROWCOUNT कमांड ने 1 पंक्ति को प्रभावित किया
यदि आपके लेन-देन में कई INSERTs या UPDATEs आदि हैं, तो आपको यह निर्धारित करने की आवश्यकता है कि आप कैसे "गिनती" करना चाहते हैं कि क्या हो रहा है। आपके पास प्रत्येक तालिका के लिए एक अलग कुल, एक भव्य कुल मूल्य, या कुछ पूरी तरह से अलग हो सकता है। आपको उस प्रत्येक कुल के लिए एक चर घोषित करना होगा जिसे आप ट्रैक करना चाहते हैं और उस पर लागू होने वाले प्रत्येक ऑपरेशन के बाद उसमें जोड़ना होगा:
--note there is no error handling here, as this is a simple example
DECLARE @AppleTotal int
DECLARE @PeachTotal int
SELECT @AppleTotal=0,@PeachTotal=0
BEGIN TRANSACTION
INSERT INTO Apple (col1, col2) Select col1,col2 from xyz where ...
SET @example@sqldat.comexample@sqldat.com@ROWCOUNT
INSERT INTO Apple (col1, col2) Select col1,col2 from abc where ...
SET @example@sqldat.comexample@sqldat.com@ROWCOUNT
INSERT INTO Peach (col1, col2) Select col1,col2 from xyz where ...
SET @example@sqldat.comexample@sqldat.com@ROWCOUNT
INSERT INTO Peach (col1, col2) Select col1,col2 from abc where ...
SET @example@sqldat.comexample@sqldat.com@ROWCOUNT
COMMIT
SELECT @AppleTotal AS AppleTotal, @PeachTotal AS PeachTotal