हाँ, SQL सर्वर कुछ परिस्थितियों में पंक्ति के "पुराने" संस्करण से एक कॉलम का मूल्य पढ़ सकता है, और पंक्ति के "नए" संस्करण से दूसरे कॉलम का मान।
सेट अप:
CREATE TABLE Person
(
Id INT PRIMARY KEY,
Name VARCHAR(100),
Surname VARCHAR(100)
);
CREATE INDEX ix_Name
ON Person(Name);
CREATE INDEX ix_Surname
ON Person(Surname);
INSERT INTO Person
SELECT TOP 1000000 ROW_NUMBER() OVER (ORDER BY @@SPID),
'Jonny1',
'Jonny1'
FROM master..spt_values v1,
master..spt_values v2
पहले कनेक्शन में, इसे चलाएं:
WHILE ( 1 = 1 )
BEGIN
UPDATE Person
SET Name = 'Jonny2',
Surname = 'Jonny2'
UPDATE Person
SET Name = 'Jonny1',
Surname = 'Jonny1'
END
दूसरे कनेक्शन में, इसे चलाएं:
DECLARE @Person TABLE (
Id INT PRIMARY KEY,
Name VARCHAR(100),
Surname VARCHAR(100));
SELECT 'Setting intial Rowcount'
WHERE 1 = 0
WHILE @@ROWCOUNT = 0
INSERT INTO @Person
SELECT Id,
Name,
Surname
FROM Person WITH(NOLOCK, INDEX = ix_Name, INDEX = ix_Surname)
WHERE Id > 30
AND Name <> Surname
SELECT *
FROM @Person
लगभग 30 सेकंड के लिए दौड़ने के बाद मुझे:
SELECT
क्वेरी (संकेत की वजह से हालांकि) संकुल अनुक्रमणिका के बजाय गैर क्लस्टर अनुक्रमित से स्तंभ को पुन: प्राप्त कर रहा है।
अपडेट स्टेटमेंट को एक विस्तृत अपडेट योजना मिलती है ...
... और अनुक्रमों को अनुक्रम में अपडेट करता है इसलिए "एक सूचकांक से मूल्यों" से पहले और दूसरे से "बाद" पढ़ना संभव है।
एक ही स्तंभ मान के दो अलग-अलग संस्करणों को पुनर्प्राप्त करना भी संभव है।
पहले कनेक्शन में, इसे चलाएं:
DECLARE @A VARCHAR(MAX) = 'A';
DECLARE @B VARCHAR(MAX) = 'B';
SELECT @A = REPLICATE(@A, 200000),
@B = REPLICATE(@B, 200000);
CREATE TABLE T
(
V VARCHAR(MAX) NULL
);
INSERT INTO T
VALUES (@B);
WHILE 1 = 1
BEGIN
UPDATE T
SET V = @A;
UPDATE T
SET V = @B;
END
और फिर दूसरे में, इसे चलाएं:
SELECT 'Setting intial Rowcount'
WHERE 1 = 0;
WHILE @@ROWCOUNT = 0
SELECT LEFT(V, 10) AS Left10,
RIGHT(V, 10) AS Right10
FROM T WITH (NOLOCK)
WHERE LEFT(V, 10) <> RIGHT(V, 10);
DROP TABLE T;
सीधे, यह मेरे लिए निम्नलिखित परिणाम लौटा
+------------+------------+
| Left10 | Right10 |
+------------+------------+
| BBBBBBBBBB | AAAAAAAAAA |
+------------+------------+