जब मैं एक पंक्ति को अनप्लस कर रहा हूं तो मैं एक अनचाही समानांतर शाखा से कैसे छुटकारा पा सकता हूं?


9

निम्नलिखित प्रश्न पर विचार करें कि स्केलर समुच्चय के कुछ मुट्ठी भर unpivots:

SELECT A, B
FROM (
    SELECT 
      MAX(CASE WHEN ID = 1 THEN 1 ELSE 0 END) VAL1
    , MAX(CASE WHEN ID = 2 THEN 1 ELSE 0 END) VAL2
    , MAX(CASE WHEN ID = 3 THEN 1 ELSE 0 END) VAL3
    , MAX(CASE WHEN ID = 4 THEN 1 ELSE 0 END) VAL4
    , MAX(CASE WHEN ID = 5 THEN 1 ELSE 0 END) VAL5
    , MAX(CASE WHEN ID = 6 THEN 1 ELSE 0 END) VAL6
    , MAX(CASE WHEN ID = 7 THEN 1 ELSE 0 END) VAL7
    , MAX(CASE WHEN ID = 16 THEN 1 ELSE 0 END) VAL16
    FROM dbo.PARALLEL_ZONE_REPRO
) q
UNPIVOT(B FOR A IN (
    VAL1
    ,VAL2
    ,VAL3
    ,VAL4
    ,VAL5
    ,VAL6
    ,VAL7
    ,VAL16
)) U
OPTION (MAXDOP 4);

SQL सर्वर 2017 पर, मुझे दो समानांतर शाखाओं के साथ एक योजना मिलती है। बाईं समानांतर शाखा मेरे लिए जगह से बाहर महसूस करती है। ऑप्टिमाइज़र की गारंटी है कि ग्लोबल स्केलर एग्रीगेट से केवल एक ही पंक्ति आउटपुट होगा, फिर भी इसका मूल ऑपरेटर राउंड रॉबिन विभाजन के साथ एक वितरित धाराएँ हैं:

राउंड रोबिन

जब मैं क्वेरी को निष्पादित करता हूं तो सभी पंक्तियां एक ही धागे पर जाती हैं, जैसा कि अपेक्षित था। इस क्वेरी के साथ कोई प्रदर्शन समस्या नहीं है, लेकिन क्वेरी 8 समानांतर सेट MAXDOP के साथ 4 को संग्रहीत करती है। फिर से, मुझे लगता है कि यह जगह से बाहर है। एक ही समय में दोनों समानांतर शाखाओं को निष्पादित करना असंभव है। मैं अनावश्यक कार्यकर्ता थ्रेड आरक्षण से बचना चाहता हूं क्योंकि मेरे पास TF 2467 सक्षम है जो शेड्यूलिंग एल्गोरिदम को शेड्यूलर के वर्कर थ्रेड की संख्या को देखने के लिए बदलता है।

क्या क्वेरी को फिर से लिखना संभव है, जिसमें एक समानान्तर शाखा है जिसमें टेबल स्कैन और स्थानीय कुल समाहित है? उदाहरण के लिए, मैं नीचे दिए गए सामान्य आकार के साथ ठीक रहूंगा, सिवाय इसके कि मैं नेस्टेड लूप को एक सीरियल ज़ोन में निष्पादित करना चाहता हूं:

यहां छवि विवरण दर्ज करें

एप्लिकेशन कारण ™ के लिए, मैं दृढ़ता से इस क्वेरी को भागों में विभाजित करने से बचना चाहता हूं। यदि वांछित है, तो आप यहां वास्तविक क्वेरी प्लान देख सकते हैं । यदि आप घर पर खेलना चाहते हैं, तो क्वेरी में प्रयुक्त तालिका बनाने के लिए यहां टी-एसक्यूएल है:

DROP TABLE IF EXISTS dbo.PARALLEL_ZONE_REPRO;

CREATE TABLE dbo.PARALLEL_ZONE_REPRO (
    ID BIGINT,
    FILLER VARCHAR(100)
);

INSERT INTO dbo.PARALLEL_ZONE_REPRO WITH (TABLOCK)
SELECT
  ROW_NUMBER() OVER (ORDER BY (SELECT NULL)) % 15
, REPLICATE('Z', 100)
FROM master..spt_values t1
CROSS JOIN master..spt_values t2;

जवाबों:


8

मैं एक सीरियल लूप के साथ वांछित योजना आकार प्राप्त करने में सक्षम हूं जब निम्नलिखित सभी सत्य हैं:

  • के बजाय एक APPLYया CROSS JOINप्रयोग किया जाता हैUNPIVOT
  • APPLYकोई बाहरी संदर्भ शामिल हैं
  • पंक्तियों का स्रोत APPLYतालिका के विपरीत तालिका मान निर्माता है

उदाहरण के लिए, यह करने का एक तरीका है:

SELECT A, B
FROM 
(
    SELECT A
    , MAX(
        CASE
            WHEN A = 'VAL1' THEN VAL1 
            WHEN A = 'VAL2' THEN VAL2
            WHEN A = 'VAL3' THEN VAL3
            WHEN A = 'VAL4' THEN VAL4
            WHEN A = 'VAL5' THEN VAL5
            WHEN A = 'VAL6' THEN VAL6
            WHEN A = 'VAL7' THEN VAL7
            WHEN A = 'VAL16' THEN VAL16
            ELSE NULL
        END
    ) B
    FROM (
         SELECT 
           MAX(CASE WHEN ID = 1 THEN 1 ELSE 0 END) VAL1
         , MAX(CASE WHEN ID = 2 THEN 1 ELSE 0 END) VAL2
         , MAX(CASE WHEN ID = 3 THEN 1 ELSE 0 END) VAL3
         , MAX(CASE WHEN ID = 4 THEN 1 ELSE 0 END) VAL4
         , MAX(CASE WHEN ID = 5 THEN 1 ELSE 0 END) VAL5
         , MAX(CASE WHEN ID = 6 THEN 1 ELSE 0 END) VAL6
         , MAX(CASE WHEN ID = 7 THEN 1 ELSE 0 END) VAL7
         , MAX(CASE WHEN ID = 16 THEN 1 ELSE 0 END) VAL16
         FROM dbo.PARALLEL_ZONE_REPRO
    ) q
    CROSS APPLY (
        VALUES ('VAL1'), ('VAL2'), ('VAL3'), ('VAL4'),
        ('VAL5'), ('VAL6'), ('VAL7'), ('VAL16') 
    ) ca (A)
    GROUP BY A
) q
WHERE q.B IS NOT NULL
OPTION (MAXDOP 4);

मुझे वांछित योजना योजना का आकार मिलता है जैसा कि केवल एक समानांतर शाखा के साथ दावा किया गया है:

यहां छवि विवरण दर्ज करें

मैंने कई और चीजें आजमाईं जो काम नहीं आईं। यह जवाब असंतोषजनक है कि मुझे नहीं पता कि यह क्यों काम करता है और यह SQL सर्वर के भविष्य के संस्करण में काम नहीं कर सकता है, लेकिन इसने मेरी समस्या को हल कर दिया है।


8

एक ही समय में दोनों समानांतर शाखाओं को निष्पादित करना असंभव है।

योजना के बाएं किनारे पर निष्पादन शुरू होता है । नेस्टेड लूप्स शाखा चल रही है (जब टेबल स्कैन शाखा चल रही है, तो डेटा की प्रतीक्षा कर रहा है)। यह अपरिहार्य है । दोनों शाखाएं एक ही समय में सक्रिय हैं, इसलिए SQL सर्वर इस योजना के लिए 2 * DOP कार्यकर्ताओं को आरक्षित करेगा ।

एक मजबूत समाधान के लिए, आप पिवट को टेबल-वैल्यू फ़ंक्शन में रख सकते हैं:

CREATE OR ALTER FUNCTION dbo.PivotPZR()
RETURNS @R table 
(
    VAL1 bigint NOT NULL, VAL2 bigint NOT NULL,
    VAL3 bigint NOT NULL, VAL4 bigint NOT NULL,
    VAL5 bigint NOT NULL, VAL6 bigint NOT NULL,
    VAL7 bigint NOT NULL, VAL16 bigint NOT NULL
)
WITH SCHEMABINDING AS
BEGIN
    DECLARE 
        @Val1 bigint, @Val2 bigint, @Val3 bigint, @Val4 bigint,
        @Val5 bigint, @Val6 bigint, @Val7 bigint, @Val16 bigint;

    -- Can use parallelism
    SELECT
        @Val1 = MAX(CASE WHEN PZR.ID = 1 THEN 1 ELSE 0 END),
        @Val2 = MAX(CASE WHEN PZR.ID = 2 THEN 1 ELSE 0 END),
        @Val3 = MAX(CASE WHEN PZR.ID = 3 THEN 1 ELSE 0 END),
        @Val4 = MAX(CASE WHEN PZR.ID = 4 THEN 1 ELSE 0 END),
        @Val5 = MAX(CASE WHEN PZR.ID = 5 THEN 1 ELSE 0 END),
        @Val6 = MAX(CASE WHEN PZR.ID = 6 THEN 1 ELSE 0 END),
        @Val7 = MAX(CASE WHEN PZR.ID = 7 THEN 1 ELSE 0 END),
        @Val16 = MAX(CASE WHEN PZR.ID = 16 THEN 1 ELSE 0 END)
    FROM dbo.PARALLEL_ZONE_REPRO AS PZR;

    -- Single result row
    INSERT @R
        (VAL1, VAL2, VAL3, VAL4, VAL5, VAL6, VAL7, VAL16)
    VALUES
        (@Val1, @Val2, @Val3, @Val4, @Val5, @Val6, @Val7, @Val16);

    RETURN;
END;

फिर क्वेरी को इस प्रकार लिखें:

SELECT
    U.A,
    U.B
FROM dbo.PivotPZR() AS PP
UNPIVOT
(
    B FOR A IN (VAL1, VAL2 ,VAL3 ,VAL4, VAL5 ,VAL6 ,VAL7 ,VAL16)
) AS U;

फ़ंक्शन वांछित के रूप में एकल शाखा के साथ समानता का उपयोग करता है:

कार्य योजना

शीर्ष-स्तरीय निष्पादन योजना है:

शीर्ष स्तर की क्वेरी

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.