एसक्यूएल केस अभिव्यक्ति सिंटेक्स?

SQL केस अभिव्यक्ति के लिए पूर्ण और सही वाक्यविन्यास क्या है?

0
ro fr bn
केस अभिव्यक्ति सही शब्द है क्योंकि वे स्केलर मान का मूल्यांकन करते हैं (SQL में कथन को "स्टेटमेंट टर्मिनेटर" द्वारा समाप्त किया जाता है जो सेमी-कोलन है)।
जोड़ा लेखक Used_By_Already, स्रोत

8 उत्तर

पूर्ण वाक्यविन्यास उस डेटाबेस इंजन पर निर्भर करता है जिसके साथ आप काम कर रहे हैं:

एसक्यूएल सर्वर के लिए:

CASE case-expression
    WHEN when-expression-1 THEN value-1
  [ WHEN when-expression-n THEN value-n ... ]
  [ ELSE else-value ]
END

या:

CASE
    WHEN boolean-when-expression-1 THEN value-1
  [ WHEN boolean-when-expression-n THEN value-n ... ]
  [ ELSE else-value ]
END

अभिव्यक्ति, आदि:

case-expression    - something that produces a value
when-expression-x  - something that is compared against the case-expression
value-1            - the result of the CASE statement if:
                         the when-expression == case-expression
                      OR the boolean-when-expression == TRUE
boolean-when-exp.. - something that produces a TRUE/FALSE answer

Link: CASE (Transact-SQL)

यह भी ध्यान रखें कि WHEN कथन का क्रम महत्वपूर्ण है। आप आसानी से एकाधिक WHEN क्लॉज लिख सकते हैं जो ओवरलैप करते हैं, और मिलान करने वाले पहले व्यक्ति का उपयोग किया जाता है

Note: If no ELSE clause is specified, and no matching WHEN-condition is found, the value of the CASE expression will be NULL.

0
जोड़ा
क्या यह हमेशा एक एसक्यूएल चीज रहा है? मैंने हाल ही में हाल ही में यह खोज लिया है
जोड़ा लेखक mike james, स्रोत

मैंने ओरेकल पेज को उसी के लिए खोला और ऐसा लगता है कि यह वही वाक्यविन्यास है, बस थोड़ा अलग वर्णन किया गया है।

Link: Oracle/PLSQL: Case Statement

0
जोड़ा

ओरेकल 11 जी दस्तावेज़ीकरण से वाक्यविन्यास :

CASE { simple_case_expression | searched_case_expression }
     [ else_clause ]
     END

simple_case_expression

expr { WHEN comparison_expr THEN return_expr }...

searched_case_expression

{ WHEN condition THEN return_expr }...

else_clause

ELSE else_expr
0
जोड़ा
धन्यवाद रॉब वैन विज्क, आप सही हैं। मैंने अपना जवाब संपादित कर लिया है।
जोड़ा लेखक Leigh Riffel, स्रोत
यह पीएल / एसक्यूएल केस स्टेटमेंट है
जोड़ा लेखक Rob van Wijk, स्रोत

एसक्यूएल सर्वर में केस कथन वाक्यविन्यास:

CASE column
   WHEN value1 THEN 1
   WHEN value3 THEN 2
   WHEN value3 THEN 3
   WHEN value1 THEN 4
   ELSE ''
END

और हम नीचे भी उपयोग कर सकते हैं:

CASE 
   WHEN column=value1 THEN 1
   WHEN column=value3 THEN 2
   WHEN column=value3 THEN 3
   WHEN column=value1 THEN 4
   ELSE ''
END
0
जोड़ा

यहां CASE हैं PostgreSQL दस्तावेज़ों से कथन उदाहरण (पोस्टग्रेस यहां SQL मानक का पालन करता है):

SELECT a,
   CASE WHEN a=1 THEN 'one'
        WHEN a=2 THEN 'two'
        ELSE 'other'
   END
FROM test;

या

SELECT a,
   CASE a WHEN 1 THEN 'one'
          WHEN 2 THEN 'two'
          ELSE 'other'
   END
FROM test;

Obviously the second fयाm is cleaner when you are just checking one field against a list of possible values. The first fयाm allows mयाe complicated expressions.

0
जोड़ा

आपको कई उत्पादों को टैग करने पर विचार करते हुए, मैं कहूंगा कि पूर्ण सही वाक्यविन्यास आईएसओ / एएनएसआई एसक्यूएल-9 2 मानक में पाया जाएगा:

 ::=
       
     | 

 ::=
       NULLIF   
               
     | COALESCE  
                {   }... 

 ::=
       
     | 

 ::=
     CASE 
          ...
        [  ]
     END

 ::=
     CASE
       ...
     [  ]
     END

 ::= WHEN  THEN 

 ::= WHEN  THEN 

 ::= ELSE 

 ::= 

 ::= 

 ::=  | NULL

 ::= 

सिंटेक्स नियम

1) NULLIF (V1, V2) is equivalent to the following :

     CASE WHEN V1=V2 THEN NULL ELSE V1 END

2) COALESCE (V1, V2) is equivalent to the following :

     CASE WHEN V1 IS NOT NULL THEN V1 ELSE V2 END

3) COALESCE (V1, V2, . . . ,n ), for n >= 3, is equivalent to the
   following :

     CASE WHEN V1 IS NOT NULL THEN V1 ELSE COALESCE (V2, . . . ,n )
     END

4) If a  specifies a , then let CO
   be the :

   a) The data type of each  WO shall be comparable
      with the data type of the .

   b) The  is equivalent to a 
      in which each  specifies a  of the form "CO=WO".

5) At least one  in a  shall specify a
   .

6) If an  is not specified, then ELSE NULL is im-
   plicit.

7) The data type of a  is determined by ap-
   plying Subclause 9.3, "Set operation result data types", to the
   data types of all s in the .

Access Rules

   None.

General Rules

1) Case:

   a) If a  specifies NULL, then its value is the null
      value.

   b) If a  specifies a , then its value
      is the value of that .

2) Case:

   a) If the  of some  in
      a  is true, then the value of the  is the value of the  of the first
      (leftmost)  whose  is
      true, cast as the data type of the .

   b) If no  in a  is true,
      then the value of the  is the value of the
       of the explicit or implicit , cast as
      the data type of the .
0
जोड़ा
सार्वभौमिक वाक्यविन्यास आवश्यकता को संबोधित करने का प्रयास करने वाला एकमात्र व्यक्ति!
जोड़ा लेखक Peter Majeed, स्रोत

ओरेकल के मामले में ध्यान देने योग्य एक बिंदु, यदि कोई मेल नहीं खाता है और कोई और हिस्सा नहीं है तो अपवाद उठाया जाता है।

0
जोड़ा
मुझे यकीन नहीं है कि यह किस संस्करण पर लागू होगा। निम्नलिखित दोनों 10 जी या 11 जी पर अपवाद नहीं उठाते हैं। केस का चयन करें जब 1 = 2 फिर 'ए' दोहरी से समाप्त होता है; 1 केस का चयन करें जब 2 'दो' दोहरी से समाप्त होता है;
जोड़ा लेखक Leigh Riffel, स्रोत
यह पीएल / एसक्यूएल में केस कथन के लिए सच हो सकता है, लेकिन एसक्यूएल में अभिव्यक्ति के लिए नहीं
जोड़ा लेखक a_horse_with_no_name, स्रोत
पीछे की ओर, मुझे लगता है कि मैं 9i के बारे में बात कर रहा था। :)
जोड़ा लेखक Tanveer Badar, स्रोत

Sybase एक ही केस वाक्यविन्यास :

विवरण

सशर्त एसक्यूएल अभिव्यक्ति का समर्थन करता है; कहीं भी इस्तेमाल किया जा सकता है एक मूल्य अभिव्यक्ति का उपयोग किया जा सकता है।

वाक्य - विन्यास

मामला 
     कब search_condition फिर अभिव्यक्ति 
    [कब search_condition फिर अभिव्यक्ति]...
    [else अभिव्यक्ति]
end

मामला and values वाक्य - विन्यास

मामला अभिव्यक्ति
     कब अभिव्यक्ति फिर अभिव्यक्ति 
    [कब अभिव्यक्ति फिर अभिव्यक्ति]...
    [else अभिव्यक्ति]
end

पैरामीटर

मामला

begins the मामला अभिव्यक्ति.

कब

खोज की स्थिति या तुलना करने की अभिव्यक्ति से पहले।

search_condition

is used to set conditions for the results that are selected. Search conditions for मामला अभिव्यक्तिs are similar to the search conditions in a where clause. Search conditions are detailed in the Transact-SQL User?s Guide.

फिर

precedes the अभिव्यक्ति that specifies a result value of मामला.

अभिव्यक्ति

is a column name, a constant, a function, a subquery, or any combination of column names, constants, and functions connected by arithmetic or bitwise operators. For more information about अभिव्यक्तिs, see ?अभिव्यक्तिs? in.

उदाहरण

select disaster, 
       मामला
            कब disaster = "earthquake" 
                फिर "stand in doorway"
            कब disaster = "nuclear apocalypse" 
                फिर "hide in basement"
            कब monster = "zombie apocalypse" 
                फिर "hide with Chuck Norris"
            else
                फिर "ask mom"
       end 
  from endoftheworld
0
जोड़ा
CASE कथन के सिंटैक्स को आसानी से समझने के लिए यह अविश्वसनीय रूप से सहायक था। धन्यवाद, और + 1।
जोड़ा लेखक Mike Varosky, स्रोत