क्यू भाषा - कार्यात्मक प्रश्न

कार्यात्मक (डायनामिक) क्वेरीज़ कॉलम के नामों को विशिष्ट q-sql चयन / निष्पादित / हटाने के लिए प्रतीक के रूप में निर्दिष्ट करने की अनुमति देती हैं। जब हम स्तंभ नामों को गतिशील रूप से निर्दिष्ट करना चाहते हैं तो यह बहुत आसान है।

कार्यात्मक रूप हैं -

?[t;c;b;a]    / for select
![t;c;b;a]    / for update

कहाँ पे

  • t एक मेज है;

  • a समुच्चय का एक शब्दकोश है;

  • bउपवाक्य; तथा

  • c बाधाओं की एक सूची है।

नोट -

  • सब q संस्थाओं में a, b, तथा c नाम से संदर्भित होना चाहिए, जिसका अर्थ है इकाई नाम वाले प्रतीक।

  • चयन और अद्यतन के वाक्य-विन्यास रूपों को उनके समकक्ष कार्यात्मक रूपों में पार्स किया जाता है q दुभाषिया, इसलिए दोनों रूपों के बीच कोई प्रदर्शन अंतर नहीं है।

कार्यात्मक चयन

निम्न कोड ब्लॉक दिखाता है कि कैसे उपयोग करना है functional select -

q)t:([]n:`ibm`msft`samsung`apple;p:40 38 45 54)

q)t

    n       p
-------------------
   ibm     40
   msft    38
 samsung   45
  apple    54

q)select m:max p,s:sum p by name:n from t where p>36, n in `ibm`msft`apple

  name |   m   s
------ | ---------
 apple |  54  54
 ibm   |  40  40
 msft  |  38  38

उदाहरण 1

चलो सबसे आसान मामले से शुरू करते हैं, के कार्यात्मक संस्करण “select from t” जैसा दिखेगा -

q)?[t;();0b;()]     / select from t

    n      p
-----------------
   ibm    40
   msft   38
 samsung  45
  apple   54

उदाहरण 2

निम्नलिखित उदाहरण में, हम यह सुनिश्चित करने के लिए एकल सूची का उपयोग करते हैं कि उपयुक्त संस्थाएं सूचीबद्ध हैं।

q)wherecon: enlist (>;`p;40)

q)?[`t;wherecon;0b;()] / select from t where p > 40

    n      p
----------------
 samsung  45
  apple   54

उदाहरण 3

q)groupby: enlist[`p] ! enlist `p

q)selcols: enlist [`n]!enlist `n

q)?[ `t;(); groupby;selcols]        / select n by p from t

   p  |    n
----- | -------
  38  |  msft
  40  |  ibm
  45  | samsung
  54  | apple

कार्यात्मक परीक्षा

निष्पादन का कार्यात्मक रूप एक सरलीकृत रूप है select

q)?[t;();();`n]                / exec n from t (functional form of exec)
`ibm`msft`samsung`apple

q)?[t;();`n;`p]                / exec p by n from t (functional exec)

apple   | 54
ibm     | 40
msft    | 38
samsung | 45

क्रियात्मक अद्यतन

अद्यतन का कार्यात्मक रूप पूरी तरह से इसके अनुरूप है select। निम्नलिखित उदाहरण में, एनलिस्ट का उपयोग एकल बनाना है, यह सुनिश्चित करने के लिए कि इनपुट इकाइयाँ सूचीबद्ध हैं।

q)c:enlist (>;`p;0)

q)b: (enlist `n)!enlist `n

q)a: (enlist `p) ! enlist (max;`p)

q)![t;c;b;a]

   n      p
-------------
  ibm    40
  msft   38
 samsung 45
 apple   54

क्रियात्मक विलोपन

फ़ंक्शनल डिलीट फ़ंक्शनल अपडेट का सरलीकृत रूप है। इसका सिंटैक्स इस प्रकार है -

![t;c;0b;a]        / t is a table, c is a list of where constraints, a is a
                   / list of column names

आइए अब एक उदाहरण लेते हैं कि कैसे कार्य हटाएं -

q)![t; enlist (=;`p; 40); 0b;`symbol$()]
                                          / delete from t where p = 40
   n       p
---------------
  msft    38
 samsung  45
  apple   54