केडीबी + - त्वरित गाइड

यह पूरी तरह से एक है kdb+kx सिस्टम से, मुख्य रूप से स्वतंत्र रूप से सीखने वालों के उद्देश्य से। kdb +, 2003 में शुरू किया गया, kdb डेटाबेस की नई पीढ़ी है जो डेटा को कैप्चर, विश्लेषण, तुलना और स्टोर करने के लिए डिज़ाइन किया गया है।

एक kdb + प्रणाली में निम्नलिखित दो घटक होते हैं -

  • KDB+ - डेटाबेस (k डेटाबेस प्लस)

  • Q - kdb + के साथ काम करने के लिए प्रोग्रामिंग भाषा

दोनों kdb+ तथा q में लिखे गए हैं k programming language (के समान q लेकिन कम पठनीय)।

पृष्ठभूमि

Kdb + / q एक अस्पष्ट अकादमिक भाषा के रूप में उत्पन्न हुआ, लेकिन पिछले कुछ वर्षों में, इसने धीरे-धीरे अपनी उपयोगकर्ता मित्रता में सुधार किया है।

  • APL (1964, एक प्रोग्रामिंग भाषा)

  • A+ (1988, संशोधित एपीएल आर्थर व्हिटनी द्वारा)

  • K (1993, ए + का कुरकुरा संस्करण, ए। व्हिटनी द्वारा विकसित)

  • Kdb (1998, इन-मेमोरी कॉलम-आधारित डीबी)

  • Kdb+/q (2003, क्ष भाषा - k का अधिक पठनीय संस्करण)

KDB + का उपयोग क्यों और कहाँ से करें

क्यों? - यदि आपको एनालिटिक्स के साथ वास्तविक समय के डेटा के लिए एकल समाधान की आवश्यकता है, तो आपको kdb + पर विचार करना चाहिए। केडीबी + डेटाबेस को सामान्य देशी फाइलों के रूप में संग्रहीत करता है, इसलिए इसमें हार्डवेयर और भंडारण वास्तुकला के संबंध में कोई विशेष आवश्यकता नहीं है। यह इंगित करने योग्य है कि डेटाबेस केवल फ़ाइलों का एक सेट है, इसलिए आपका प्रशासनिक कार्य मुश्किल नहीं होगा।

केडीबी + का उपयोग कहां करें?- यह गणना करना आसान है कि कौन से निवेश बैंक kdb + का उपयोग नहीं कर रहे हैं, क्योंकि उनमें से अधिकांश वर्तमान में उपयोग कर रहे हैं या पारंपरिक डेटाबेस से kdb + पर स्विच करने की योजना बना रहे हैं। जैसे-जैसे डेटा की मात्रा दिन-प्रतिदिन बढ़ रही है, हमें एक ऐसी प्रणाली की आवश्यकता है जो डेटा के विशाल मात्रा को संभाल सके। केडीबी + इस आवश्यकता को पूरा करता है। केडीबी + न केवल भारी मात्रा में डेटा संग्रहीत करता है, बल्कि वास्तविक समय में इसका विश्लेषण भी करता है।

शुरू करना

इस पृष्ठभूमि के साथ, आइए अब हम आगे बढ़ते हैं और सीखते हैं कि केडीबी + के लिए एक वातावरण कैसे बनाया जाए। हम केडीबी + को डाउनलोड और इंस्टॉल करने के तरीके से शुरू करेंगे।

केडीबी + डाउनलोड और इंस्टॉल करना

आप केडीबी + का मुफ्त 32-बिट संस्करण प्राप्त कर सकते हैं, जिसमें से 64-बिट संस्करण की सभी कार्यक्षमता है http://kx.com/software-download.php

लाइसेंस समझौते से सहमत, ऑपरेटिंग सिस्टम (सभी प्रमुख ऑपरेटिंग सिस्टम के लिए उपलब्ध) का चयन करें। विंडोज ऑपरेटिंग सिस्टम के लिए, नवीनतम संस्करण 3.2 है। नवीनतम संस्करण डाउनलोड करें। एक बार जब आप इसे अनज़िप कर लेते हैं, तो आपको फ़ोल्डर नाम मिल जाएगा“windows” और विंडोज़ फ़ोल्डर के अंदर, आपको एक और फ़ोल्डर मिलेगा “q”। पूरी कॉपी करेंq आपके c: / ड्राइव पर फ़ोल्डर।

रन टर्मिनल खोलें, वह स्थान लिखें जहां आप स्टोर करते हैं qफ़ोल्डर; यह "c: /q/w32/q.exe" जैसा होगा। Enter पर हिट करते ही, आपको एक नया कंसोल मिलेगा, जो इस प्रकार है -

पहली पंक्ति पर, आप संस्करण संख्या देख सकते हैं जो 3.2 है और 2015.03.05 के रूप में रिलीज़ की तारीख है

निर्देशिका लेआउट

परीक्षण / नि: शुल्क संस्करण आमतौर पर निर्देशिकाओं में स्थापित किया जाता है,

For linux/Mac −

~/q       / main q directory (under the user’s home)
~/q/l32   / location of linux 32-bit executable
~/q/m32   / Location of mac 32-bit executable

For Windows −

c:/q          / Main q directory
c:/q/w32/     / Location of windows 32-bit executable

Example Files −

एक बार जब आप kdb + डाउनलोड करते हैं, तो विंडोज प्लेटफॉर्म में निर्देशिका संरचना निम्नानुसार दिखाई देगी -

उपरोक्त निर्देशिका संरचना में, trade.q तथा sp.q उदाहरण फाइलें हैं जिन्हें हम संदर्भ बिंदु के रूप में उपयोग कर सकते हैं।

Kdb + एक उच्च-प्रदर्शन, उच्च-मात्रा डेटाबेस है जिसे डेटा के जबरदस्त संस्करणों को संभालने के लिए शुरू से डिज़ाइन किया गया है। यह पूरी तरह से 64-बिट है, और इसमें अंतर्निहित मल्टी-कोर प्रसंस्करण और मल्टी-थ्रेडिंग है। उसी वास्तुकला का उपयोग वास्तविक समय और ऐतिहासिक डेटा के लिए किया जाता है। डेटाबेस में अपनी शक्तिशाली क्वेरी भाषा शामिल है,q, इसलिए एनालिटिक्स को सीधे डेटा पर चलाया जा सकता है।

kdb+tick एक आर्किटेक्चर है जो वास्तविक समय और ऐतिहासिक डेटा को पकड़ने, प्रसंस्करण और क्वेरी करने की अनुमति देता है।

केडीबी + / टिक आर्किटेक्चर

निम्नलिखित चित्रण एक विशिष्ट केडीबी + / टिक वास्तुकला की एक सामान्यीकृत रूपरेखा प्रदान करता है, जिसके बाद विभिन्न घटकों की संक्षिप्त व्याख्या और डेटा के माध्यम से प्रवाह होता है।

  • Data Feeds एक टाइम सीरीज़ डेटा है जो ज्यादातर डेटा फीड प्रोवाइडर जैसे रॉयटर्स, ब्लूमबर्ग या सीधे एक्सचेंजों द्वारा प्रदान किया जाता है।

  • प्रासंगिक डेटा प्राप्त करने के लिए, डेटा फीड से डेटा पार्स किया जाता है feed handler

  • फीड हैंडलर द्वारा डेटा पार्स किए जाने के बाद, यह चला जाता है ticker-plant

  • किसी भी विफलता से डेटा को पुनर्प्राप्त करने के लिए, टिकर-प्लांट पहले नए डेटा को लॉग फाइल में अपडेट / संग्रहीत करता है और फिर अपनी खुद की तालिकाओं को अपडेट करता है।

  • आंतरिक तालिकाओं और लॉग फ़ाइलों को अपडेट करने के बाद, ऑन-टाइम लूप डेटा को रियल-टाइम डेटाबेस और डेटा के लिए अनुरोध करने वाले सभी जंजीरों को लगातार भेजा / प्रकाशित किया जाता है।

  • एक व्यावसायिक दिन के अंत में, लॉग फ़ाइल हटा दी जाती है, एक नया बनाया गया और वास्तविक समय डेटाबेस ऐतिहासिक डेटाबेस पर सहेजा जाता है। एक बार सभी डेटा ऐतिहासिक डेटाबेस पर सहेजे जाने के बाद, वास्तविक समय डेटाबेस अपनी तालिकाओं को शुद्ध करता है।

केडीबी + टिक आर्किटेक्चर के घटक

डाटा फीड

डेटा फीड किसी भी बाजार या अन्य समय श्रृंखला डेटा हो सकता है। फीड-हैंडलर को कच्चे इनपुट के रूप में डेटा फीड पर विचार करें। फ़ीड सीधे एक्सचेंज (लाइव-स्ट्रीमिंग डेटा), थॉमसन-रॉयटर्स, ब्लूमबर्ग या किसी अन्य बाहरी एजेंसियों जैसे समाचार / डेटा प्रदाताओं से हो सकते हैं।

हैंडलर खिलाएं

एक फीड हैंडलर डेटा स्ट्रीम को kdb + पर लिखने के लिए उपयुक्त प्रारूप में परिवर्तित करता है। यह डेटा फीड से जुड़ा होता है और यह फीड-स्पेसिफिक फॉर्मेट के डेटा को केडीबी + संदेश में बदल देता है और इसे टिकर-प्लांट प्रक्रिया में प्रकाशित कर देता है। आम तौर पर एक फीड हैंडलर का उपयोग निम्नलिखित ऑपरेशन करने के लिए किया जाता है -

  • नियमों के एक सेट के अनुसार डेटा कैप्चर करें।
  • उस डेटा का एक प्रारूप से दूसरे में अनुवाद (समृद्ध) करें।
  • सबसे हाल के मूल्यों को पकड़ो।

टिकर का पौधा

टिकर प्लांट केडीबी + आर्किटेक्चर का सबसे महत्वपूर्ण घटक है। यह टिकर प्लांट है जिसके साथ वित्तीय डेटा तक पहुंचने के लिए वास्तविक समय डेटाबेस या सीधे ग्राहक (क्लाइंट) जुड़े हुए हैं। में संचालित होता हैpublish and subscribeतंत्र। एक बार जब आप एक सदस्यता (लाइसेंस) प्राप्त करते हैं, तो प्रकाशक (टिकर प्लांट) से एक टिक (नियमित रूप से) प्रकाशन परिभाषित किया जाता है। यह निम्नलिखित कार्य करता है -

  • फीड हैंडलर से डेटा प्राप्त करता है।

  • टिकर प्लांट को डेटा प्राप्त होने के तुरंत बाद, यह एक लॉग फ़ाइल के रूप में एक कॉपी संग्रहीत करता है और एक बार टिकर प्लांट को कोई भी अपडेट मिलने के बाद इसे अपडेट कर देता है ताकि किसी भी विफलता के मामले में, हमें कोई डेटा हानि न हो।

  • ग्राहक (रियल-टाइम सब्सक्राइबर) सीधे टिकर-प्लांट की सदस्यता ले सकते हैं।

  • प्रत्येक व्यावसायिक दिन के अंत में, यानी, एक बार वास्तविक समय डेटाबेस को अंतिम संदेश प्राप्त होने के बाद, यह आज के सभी डेटा को ऐतिहासिक डेटाबेस पर संग्रहीत करता है और उन सभी ग्राहकों को समान धक्का देता है जिन्होंने आज के डेटा के लिए सदस्यता ली है। फिर यह अपनी सभी तालिकाओं को रीसेट करता है। ऐतिहासिक डेटाबेस या डेटा से सीधे जुड़े हुए सब्सक्राइबर को रियल टाइम डेटाबेस (rtdb) में संग्रहीत करने के बाद लॉग फ़ाइल को भी हटा दिया जाता है।

  • नतीजतन, टिकर-प्लांट, रीयल-टाइम डेटाबेस और ऐतिहासिक डेटाबेस 24/7 आधार पर चालू होते हैं।

चूंकि टिकर-प्लांट एक Kdb + अनुप्रयोग है, इसलिए इसकी तालिकाओं का उपयोग करके इसे देखा जा सकता है qकिसी भी अन्य Kdb + डेटाबेस की तरह। सभी टिकर-प्लांट ग्राहकों को केवल ग्राहकों के रूप में डेटाबेस तक पहुंच होनी चाहिए।

वास्तविक समय डेटाबेस

एक वास्तविक समय डेटाबेस (rdb) आज के डेटा को संग्रहीत करता है। यह सीधे टिकर प्लांट से जुड़ा हुआ है। आमतौर पर इसे बाजार के घंटों (एक दिन) के दौरान मेमोरी में स्टोर किया जाता है और दिन के अंत में ऐतिहासिक डेटाबेस (एचडीबी) को लिखा जाता है। जैसा कि डेटा (rdb डेटा) मेमोरी में संग्रहीत किया जाता है, प्रसंस्करण बहुत तेज है।

जैसा कि kdb + प्रति दिन डेटा के अपेक्षित आकार से चार गुना या अधिक रैम आकार की अनुशंसा करता है, rdb पर चलने वाली क्वेरी बहुत तेज़ होती है और बेहतर प्रदर्शन प्रदान करती है। चूंकि एक वास्तविक समय डेटाबेस में केवल आज का डेटा होता है, इसलिए दिनांक स्तंभ (पैरामीटर) की आवश्यकता नहीं होती है।

उदाहरण के लिए, हम rdb प्रश्नों की तरह हो सकते हैं,

select from trade where sym = `ibm

OR

select from trade where sym = `ibm, price > 100

ऐतिहासिक डेटाबेस

यदि हमें किसी कंपनी के अनुमानों की गणना करनी है, तो हमें उसका ऐतिहासिक डेटा उपलब्ध होना चाहिए। एक ऐतिहासिक डेटाबेस (एचडीबी) अतीत में किए गए लेनदेन का डेटा रखता है। प्रत्येक नए दिन का रिकॉर्ड दिन के अंत में एचडीबी में जोड़ा जाएगा। एचडीबी में बड़े तालिकाओं को या तो संग्रहीत किया जाता है (प्रत्येक स्तंभ अपनी फ़ाइल में संग्रहीत किया जाता है) या उन्हें अस्थायी डेटा द्वारा विभाजित किया जाता है। इसके अलावा कुछ बहुत बड़े डेटाबेस का उपयोग करके आगे विभाजन किया जा सकता हैpar.txt (फाइल)।

बड़ी तालिका से डेटा को खोजते या एक्सेस करते समय ये स्टोरेज स्ट्रेटेजी (स्पलैड, पार्टीशन इत्यादि) कुशल होते हैं।

एक ऐतिहासिक डेटाबेस का उपयोग आंतरिक और बाहरी रिपोर्टिंग उद्देश्यों के लिए भी किया जा सकता है, अर्थात, एनालिटिक्स के लिए। उदाहरण के लिए, मान लें कि हम व्यापार (या किसी भी) तालिका नाम से किसी विशेष दिन के लिए आईबीएम की कंपनी ट्रेडों को प्राप्त करना चाहते हैं, हमें निम्नानुसार एक प्रश्न लिखना होगा -

thisday: 2014.10.12

select from trade where date = thisday, sym =`ibm

Note - जैसे ही हम कुछ अवलोकन करेंगे हम इस तरह के सभी प्रश्नों को लिखेंगे q भाषा: हिन्दी।

Kdb + अपनी अंतर्निहित प्रोग्रामिंग भाषा के साथ आता है जिसे के रूप में जाना जाता है q। यह मानक एसक्यूएल के एक सुपरसेट को शामिल करता है जो समय-श्रृंखला विश्लेषण के लिए बढ़ाया जाता है और मानक संस्करण पर कई फायदे प्रदान करता है। SQL से परिचित कोई भी व्यक्ति सीख सकता हैq कुछ ही दिनों में और जल्दी से अपने स्वयं के तदर्थ प्रश्नों को लिखने में सक्षम हो।

"क्ष" पर्यावरण शुरू करना

Kdb + का उपयोग शुरू करने के लिए, आपको शुरू करने की आवश्यकता है qसत्र। शुरू करने के तीन तरीके हैंq सत्र -

  • बस अपने रन टर्मिनल पर "c: /q/w32/q.exe" टाइप करें।

  • MS-DOS कमांड टर्मिनल शुरू करें और टाइप करें q

  • की प्रतिलिपि बनाएँ q.exe फ़ाइल "C: \ Windows \ System32" और रन टर्मिनल पर, बस "q" टाइप करें।

यहां हम मान रहे हैं कि आप विंडोज प्लेटफॉर्म पर काम कर रहे हैं।

जानकारी का प्रकार

निम्न तालिका समर्थित डेटा प्रकारों की एक सूची प्रदान करती है -

नाम उदाहरण चार प्रकार आकार
बूलियन 1b 1 1
बाइट 0xff एक्स 4 1
कम 23h एच 5 2
पूर्णांक 23i मैं 6 4
लंबा 23j जे 7 8
असली 2.3e 8 4
नाव 2.3f 9 8
चार "ए" सी 10 1
varchar `अब रों 1 1 *
महीना 2003.03m 13 4
दिनांक 2015.03.17T18: 01: 40.134 जेड 15 8
मिनट 8:31 यू 17 4
दूसरा 08:31:53 v 18 4
समय 18: 03: 18.521 टी 19 4
enum `यू $` बी, जहां यू: `ए ए बी * 20 4

परमाणु और सूची निर्माण

परमाणु एकल संस्थाएं हैं, उदाहरण के लिए, एक एकल संख्या, एक चरित्र या एक प्रतीक। उपरोक्त तालिका (विभिन्न डेटा प्रकारों में), सभी समर्थित डेटा प्रकार परमाणु हैं। एक सूची परमाणुओं या सूचियों सहित अन्य प्रकारों का एक क्रम है।

किसी भी प्रकार के मोनोमिक (यानी एकल तर्क फ़ंक्शन) प्रकार के फ़ंक्शन को पास करने से नकारात्मक मान वापस आ जाएगा, अर्थात –n, जबकि टाइप फ़ंक्शन के लिए उन परमाणुओं की एक सरल सूची को पारित करने से सकारात्मक मूल्य वापस आ जाएगा n

उदाहरण 1 - परमाणु और सूची निर्माण

/ Note that the comments begin with a slash “ / ” and cause the parser
/ to ignore everything up to the end of the line.

x: `mohan              / `mohan is a symbol, assigned to a variable x
type x                 / let’s check the type of x
-11h                   / -ve sign, because it’s single element.

y: (`abc;`bca;`cab)    / list of three symbols, y is the variable name.

type y
11h                    / +ve sign, as it contain list of atoms (symbol).

y1: (`abc`bca`cab)     / another way of writing y, please note NO semicolon

y2: (`$”symbols may have interior blanks”)   / string to symbol conversion
y[0]                   / return `abc
y 0                    / same as y[0], also returns `abc
y 0 2                  / returns `abc`cab, same as does y[0 2]

z: (`abc; 10 20 30; (`a`b); 9.9 8.8 7.7)      / List of different types,
z 2 0                  / returns (`a`b; `abc),
z[2;0]                 / return `a. first element of z[2]

x: “Hello World!”      / list of character, a string
x 4 0                  / returns “oH” i.e. 4th and 0th(first)
element

अक्सर कुछ डेटा के डेटा प्रकार को एक प्रकार से दूसरे में बदलना आवश्यक होता है। मानक कास्टिंग फ़ंक्शन "$" हैdyadic operator

तीन प्रकारों का उपयोग एक प्रकार से दूसरे में डालने के लिए किया जाता है (स्ट्रिंग को छोड़कर) -

  • वांछित डेटा प्रकार को उसके प्रतीक नाम से निर्दिष्ट करें
  • अपने चरित्र द्वारा वांछित डेटा प्रकार निर्दिष्ट करें
  • वांछित डेटा प्रकार को इसके द्वारा कम मूल्य पर निर्दिष्ट करें।

इंटीग्रेटर्स को फ्लोट्स में कास्टिंग करना

तैरने के लिए कास्टिंग पूर्णांक के निम्नलिखित उदाहरण में, कास्टिंग के तीन अलग-अलग तरीके समान हैं -

q)a:9 18 27

q)$[`float;a]     / Specify desired data type by its symbol name, 1st way
9 18 27f

q)$["f";a]        / Specify desired data type by its character, 2nd way
9 18 27f

q)$[9h;a]         / Specify desired data type by its short value, 3rd way
9 18 27f

जांचें कि क्या तीनों ऑपरेशन बराबर हैं,

q)($[`float;a]~$["f";a]) and ($[`float;a] ~ $[9h;a])
1b

कास्टिंग स्ट्रिंग्स टू सिंबल

प्रतीकों और इसके विपरीत के लिए कास्टिंग स्ट्रिंग थोड़ा अलग तरीके से काम करता है। आइए इसे एक उदाहरण से देखें -

q)b: ("Hello";"World";"HelloWorld")    / define a list of strings

q)b
"Hello"
"World"
"HelloWorld"

q)c: `$b                               / this is how to cast strings to symbols

q)c                                    / Now c is a list of symbols
`Hello`World`HelloWorld

कुंजी शब्द का उपयोग करके प्रतीकों को तार लगाने का प्रयास करना `प्रतीक या 11h प्रकार की त्रुटि के साथ विफल हो जाएगा -

q)b
"Hello"
"World"
"HelloWorld"

q)`symbol$b
'type

q)11h$b
'type

गैर-प्रतीकों के लिए कास्टिंग स्ट्रिंग्स

प्रतीक के अलावा एक डेटा प्रकार के लिए कास्टिंग तार इस प्रकार पूरा किया जाता है -

q)b:900               / b contain single atomic integer

q)c:string b          / convert this integer atom to string “900”

q)c
"900"

q)`int $ c            / converting string to integer will return the
                      / ASCII equivalent of the character “9”, “0” and
                      / “0” to produce the list of integer 57, 48 and
                      / 48.
57 48 48i

q)6h $ c / Same as above 57 48 48i q)"i" $ c             / Same a above
57 48 48i

q)"I" $ c
900i

इसलिए डेटा प्रकार के एक परमाणु के लिए एक पूरी स्ट्रिंग (वर्णों की सूची) डालना x डेटा प्रकार का प्रतिनिधित्व करने वाले ऊपरी मामले पत्र को निर्दिष्ट करने की आवश्यकता है x पहले तर्क के रूप में $ऑपरेटर। यदि आप डेटा प्रकार निर्दिष्ट करते हैंx किसी भी अन्य तरीके से, यह कलाकारों के स्ट्रिंग के प्रत्येक चरित्र पर लागू होने के परिणामस्वरूप होता है।

q भाषा में अस्थायी डेटा का प्रतिनिधित्व करने और हेरफेर करने के कई अलग-अलग तरीके हैं जैसे कि समय और दिनांक।

दिनांक

Kdb + में एक तारीख को आंतरिक रूप से उन दिनों की पूर्णांक संख्या के रूप में संग्रहीत किया जाता है, जब से हमारी संदर्भ तिथि 01J2000 है। इस तिथि के बाद की तारीख को आंतरिक रूप से एक सकारात्मक संख्या के रूप में संग्रहीत किया जाता है और इससे पहले की तारीख को नकारात्मक संख्या के रूप में संदर्भित किया जाता है।

डिफ़ॉल्ट रूप से, दिनांक "YYYY.MM.DD" प्रारूप में लिखी जाती है

q)x:2015.01.22      / This is how we write 22nd Jan 2015

q)`int$x / Number of days since 2000.01.01 5500i q)`year$x           / Extracting year from the date
2015i

q)x.year            / Another way of extracting year
2015i

q)`mm$x / Extracting month from the date 1i q)x.mm / Another way of extracting month 1i q)`dd$x             / Extracting day from the date
22i

q)x.dd              / Another way of extracting day
22i

Arithmetic and logical operations सीधे तारीखों पर प्रदर्शन किया जा सकता है।

q)x+1        / Add one day
2015.01.23

q)x-7        / Subtract 7 days
2015.01.15

1 जनवरी 2000 की शनिवार को गिर गया। इसलिए इतिहास में किसी भी शनिवार या भविष्य में जब 7 से विभाजित किया जाता है, तो शेषफल 0 होगा, रविवार 1, सोमवार 2 उपज देता है।

Day               mod 7
           Saturday              0
           Sunday                1
           Monday                2
           Tuesday               3
           Wednesday             4
           Thursday              5
           Friday                6

बार

आधी रात के बाद से एक समय को मिलीसेकंड के पूर्णांक संख्या के रूप में आंतरिक रूप से संग्रहीत किया जाता है। प्रारूप HH: MM: SS.MSS में एक समय लिखा गया है

q)tt1: 03:30:00.000     / tt1 store the time 03:30 AM

q)tt1
03:30:00.000

q)`int$tt1 / Number of milliseconds in 3.5 hours 12600000i q)`hh$tt1               / Extract the hour component from time
3i

q)tt1.hh
3i

q)`mm$tt1 / Extract the minute component from time 30i q)tt1.mm 30i q)`ss$tt1               / Extract the second component from time
0i

q)tt1.ss
0i

जैसा कि तिथियों के मामले में, अंकगणित सीधे समय पर किया जा सकता है।

datetimes

एक डेटाइम एक तिथि और समय का संयोजन है, जिसे आईएसओ मानक प्रारूप में 'टी' द्वारा अलग किया गया है। एक डाइमटाइम मूल्य 1 जनवरी 2000 की मध्य रात्रि से भिन्नात्मक दिन की गणना करता है।

q)dt:2012.12.20T04:54:59:000      / 04:54.59 AM on 20thDec2012

q)type dt
-15h

q)dt
2012.12.20T04:54:59.000
9
q)`float$dt
4737.205

अंतर्निहित भिन्नात्मक दिन की गणना तैरने के लिए कास्टिंग करके प्राप्त की जा सकती है।

सूची के बुनियादी भवन ब्लॉक हैं q language, इसलिए सूचियों की गहन समझ बहुत महत्वपूर्ण है। एक सूची केवल परमाणुओं (परमाणु तत्वों) और अन्य सूचियों (एक या अधिक परमाणुओं का समूह) का एक संग्रह है।

सूची के प्रकार

general listकोष्ठक के मिलान के भीतर इसकी वस्तुओं को संलग्न करता है और अर्धविरामों के साथ अलग करता है। उदाहरण के लिए -

(9;8;7)   or   ("a"; "b"; "c")   or   (-10.0; 3.1415e; `abcd; "r")

यदि एक सूची में एक ही प्रकार के परमाणु शामिल हैं, तो इसे ए के रूप में जाना जाता है uniform list। एल्स, इसे ए के रूप में जाना जाता हैgeneral list (मिश्रित प्रकार)।

गिनती

हम एक सूची में आइटमों की संख्या इसकी गिनती के माध्यम से प्राप्त कर सकते हैं।

q)l1:(-10.0;3.1415e;`abcd;"r")    / Assigning variable name to general list

q)count l1                        / Calculating number of items in the list l1
4

सरल सूची के उदाहरण

q)h:(1h;2h;255h)                    / Simple Integer List

q)h
1 2 255h

q)f:(123.4567;9876.543;98.7)        / Simple Floating Point List

q)f
123.4567 9876.543 98.7

q)b:(0b;1b;0b;1b;1b)                / Simple Binary Lists

q)b
01011b

q)symbols:(`Life;`Is;`Beautiful)    / Simple Symbols List

q)symbols
`Life`Is`Beautiful

q)chars:("h";"e";"l";"l";"o";" ";"w";"o";"r";"l";"d") 
                                    / Simple char lists and Strings.
q)chars
"hello world"

**Note − A simple list of char is called a string.

एक सूची में परमाणु या सूची होती है। To create a single item list, हम उपयोग करते हैं -

q)singleton:enlist 42

q)singleton
,42

To distinguish between an atom and the equivalent singletonउनके प्रकार के संकेत की जांच करें।

q)signum type 42
-1i

q)signum type enlist 42
1i

एक सूची को उसके आइटम की स्थिति से बाएं से दाएं ओर क्रमबद्ध किया जाता है। सूची की शुरुआत से किसी आइटम की ऑफसेट को कहा जाता हैindex। इस प्रकार, पहले आइटम में एक इंडेक्स 0 है, दूसरा आइटम (यदि कोई है तो) का इंडेक्स 1 है, आदि गिनती की एक सूची हैn से इंडेक्स डोमेन है 0 सेवा n–1

सूचकांक संकेतन

एक सूची दी L, सूचकांक में आइटम i द्वारा पहुँचा है L[i]। किसी वस्तु को उसके सूचकांक द्वारा पुनः प्राप्त करना कहते हैंitem indexing। उदाहरण के लिए,

q)L:(99;98.7e;`b;`abc;"z")

q)L[0]
99

q)L[1]
98.7e

q)L[4]
"z

अनुक्रमित असाइनमेंट

सूची में आइटम को आइटम अनुक्रमण के माध्यम से भी सौंपा जा सकता है। इस प्रकार,

q)L1:9 8 7

q)L1[2]:66      / Indexed assignment into a simple list
                / enforces strict type matching.
                
q)L1
9 8 66

चर से सूचियाँ

q)l1:(9;8;40;200)

q)l2:(1 4 3; `abc`xyz)

q)l:(l1;l2)               / combining the two list l1 and l2

q)l
9 8 40 200
(1 4 3;`abc`xyz)

सूची में शामिल

दो सूचियों पर सबसे आम ऑपरेशन एक बड़ी सूची बनाने के लिए उन्हें एक साथ जोड़ना है। अधिक सटीक रूप से, ज्वाइन ऑपरेटर (), अपने दाहिने ऑपरेंड को बाएं ऑपरेंड के अंत में जोड़ता है और परिणाम देता है। यह किसी भी तर्क में एक परमाणु को स्वीकार करता है।

q)1,2 3 4
1 2 3 4

q)1 2 3, 4.4 5.6     / If the arguments are not of uniform type,
                     / the result is a general list.
1
2
3
4.4
5.6

घोंसला करने की क्रिया

डेटा जटिलता सूचियों के आइटम के रूप में सूचियों का उपयोग करके बनाया गया है।

गहराई

किसी सूची के लिए घोंसले के स्तर की संख्या को इसकी गहराई कहा जाता है। परमाणुओं की गहराई 0 है और सरल सूचियों की गहराई 1 है।

q)l1:(9;8;(99;88))

q)count l1
3

यहाँ गहराई 3 की सूची दो आइटम हैं -

q)l5
9
(90;180;900 1800 2700 3600)

q)count l5
2

q)count l5[1]
3

गहराई पर अनुक्रमण

एक नेस्टेड सूची के आइटम में सीधे अनुक्रमण करना संभव है।

Repeated Item Indexing

किसी एकल अनुक्रमणिका के माध्यम से किसी आइटम को पुनर्प्राप्त करना हमेशा एक नेस्टेड सूची से एक ऊपरवाला आइटम पुनर्प्राप्त करता है।

q)L:(1;(100;200;(300;400;500;600)))

q)L[0]
1

q)L[1]
100
200
300 400 500 600

परिणाम के बाद से L[1] अपने आप में एक सूची है, हम एक एकल सूचकांक का उपयोग करके इसके तत्वों को पुनः प्राप्त कर सकते हैं।

q)L[1][2]
300 400 500 600

हम एक सूची को एक बार फिर से दोहरा सकते हैं ताकि अंतरतम नेस्टेड सूची से किसी वस्तु को पुनः प्राप्त किया जा सके।

q)L[1][2][0]
300

आप इसे पढ़ सकते हैं,

आइटम को L से अनुक्रमणिका 1 पर प्राप्त करें, और इससे अनुक्रमणिका 2 पर आइटम को पुनः प्राप्त करें, और इससे आइटम को अनुक्रमणिका 0 पर पुनः प्राप्त करें।

Notation for Indexing at Depth

एक नेस्टेड सूची के घटकों में बार-बार अनुक्रमण के लिए एक वैकल्पिक संकेतन है। अंतिम पुनर्प्राप्ति के रूप में भी लिखा जा सकता है,

q)L[1;2;0]
300

सूचकांक के माध्यम से असाइनमेंट भी गहराई से काम करता है।

q)L[1;2;1]:900

q)L
1
(100;200;300 900 500 600)

ऐलिड इंडिसेस

Eliding Indices for a General List

q)L:((1 2 3; 4 5 6 7); (`a`b`c;`d`e`f`g;`0`1`2);("good";"morning"))

q)L
(1 2 3;4 5 6 7)
(`a`b`c;`d`e`f`g;`0`1`2)
("good";"morning")

q)L[;1;]
4 5 6 7
`d`e`f`g
"morning"

q)L[;;2]
3 6
`c`f`2
"or"

Interpret L[;1;] as,

शीर्ष स्तर पर प्रत्येक सूची की दूसरी स्थिति में सभी वस्तुओं को पुनः प्राप्त करें।

Interpret L[;;2] as,

दूसरे स्तर पर प्रत्येक सूची के लिए तीसरे स्थान पर आइटम को पुनः प्राप्त करें।

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

"डोमेन → रेंज"

या सामान्य रूप से (छोटा) बनाता है

"कुंजी → मूल्य"

तत्वों के बीच संबंध।

एक शब्दकोश कुंजी-मूल्य वाले जोड़े का एक ऑर्डर किया गया संग्रह है जो मोटे तौर पर एक हैश तालिका के बराबर है। एक डिक्शनरी एक स्पष्ट I / O एसोसिएशन द्वारा एक डोमेन सूची और एक पोजिशन लिस्ट के बीच स्थितीय पत्राचार के माध्यम से परिभाषित मानचित्रण है। शब्दकोश का निर्माण "xkey" आदिम (!) का उपयोग करता है

ListOfDomain ! ListOfRange

सबसे बुनियादी शब्दकोश एक सरल सूची के लिए एक सरल सूची का मानचित्र बनाता है।

इनपुट (I) आउटपुट (O)
`नाम `जॉन
`उम्र 36
`सेक्स "म"
वजन 60.3
q)d:`Name`Age`Sex`Weight!(`John;36;"M";60.3)   / Create a dictionary d

q)d

Name   | `John
Age    | 36
Sex    | "M"
Weight | 60.3

q)count d             / To get the number of rows in a dictionary.
4

q)key d               / The function key returns the domain
`Name`Age`Sex`Weight

q)value d             / The function value returns the range.

`John
36

"M"
60.3

q)cols d             / The function cols also returns the domain.
`Name`Age`Sex`Weight

देखो

इनपुट मूल्य के अनुरूप डिक्शनरी आउटपुट वैल्यू को खोजने को कहा जाता है looking up इनपुट।

q)d[`Name]       / Accessing the value of domain `Name
`John

q)d[`Name`Sex]   / extended item-wise to a simple list of keys
`John
"M"

Verb @ के साथ लुकअप

q)d1:`one`two`three!9 18 27

q)d1[`two]
18

q)d1@`two
18

शब्दकोशों पर संचालन

संशोधन और उपरि

सूचियों के साथ, शब्दकोश की वस्तुओं को अनुक्रमित असाइनमेंट के माध्यम से संशोधित किया जा सकता है।

d:`Name`Age`Sex`Weight! (`John;36;"M";60.3)
                                  / A dictionary d
                                  
q)d[`Age]:35                      / Assigning new value to key Age

q)d 
                              / New value assigned to key Age in d
Name   | `John
Age    | 35
Sex    | "M"
Weight | 60.3

इंडेक्स असाइनमेंट के जरिए डिक्शनरी बढ़ाई जा सकती है।

q)d[`Height]:"182 Ft"

q)d

Name   | `John
Age    | 35
Sex    | "M"
Weight | 60.3
Height | "182 Ft"

लुकअप के साथ लुकअप (?)

खोज (?) ऑपरेटर का उपयोग उसके डोमेन तत्व में तत्वों की एक श्रृंखला को मैप करके रिवर्स लुकअप करने के लिए किया जाता है।

q)d2:`x`y`z!99 88 77

q)d2?77
`z

मामले में एक सूची के तत्व अद्वितीय नहीं हैं, find डोमेन सूची से इसमें पहला आइटम मैपिंग देता है।

प्रविष्टियां निकालना

एक शब्दकोश से एक प्रविष्टि को हटाने के लिए, delete ( _ ) functionप्रयोग किया जाता है। (_) के बाएं ऑपरेंड डिक्शनरी है और राइट ऑपरेंड एक महत्वपूर्ण मूल्य है।

q)d2:`x`y`z!99 88 77

q)d2 _`z

x| 99
y| 88

व्हाट्सएप _ के बाईं ओर आवश्यक है यदि पहला ऑपरेंड एक चर है।

q)`x`y _ d2           / Deleting multiple entries

z| 77

कॉलम शब्दकोश

कॉलम के निर्माण के लिए कॉलम शब्दकोश मूल बातें हैं। निम्नलिखित उदाहरण पर विचार करें -

q)scores: `name`id!(`John`Jenny`Jonathan;9 18 27)
                              / Dictionary scores
                              
q)scores[`name]               / The values for the name column are
`John`Jenny`Jonathan

q)scores.name                 / Retrieving the values for a column in a
                              / column dictionary using dot notation.
`John`Jenny`Jonathan

q)scores[`name][1]            / Values in row 1 of the name column
`Jenny

q)scores[`id][2]              / Values in row 2 of the id column is
27

एक शब्दकोश फ्लिपिंग

कॉलम शब्दकोश को फ़्लिप करने का शुद्ध प्रभाव सूचकांकों के क्रम को उलट रहा है। यह तार्किक रूप से पंक्तियों और स्तंभों को स्थानांतरित करने के बराबर है।

एक कॉलम शब्दकोश पर पलटें

डिक्शनरी का ट्रांज़िशन, यूनियरी फ्लिप ऑपरेटर को लागू करके प्राप्त किया जाता है। निम्नलिखित उदाहरण पर एक नज़र डालें -

q)scores

name  | John Jenny Jonathan
id    | 9   18   27

q)flip scores

  name     id
---------------
  John     9
  Jenny    18
 Jonathan  27

फ़्लिप किए गए कॉलम शब्दकोश का फ़्लिप

यदि आप किसी शब्दकोश को दो बार स्थानांतरित करते हैं, तो आप मूल शब्दकोश प्राप्त करते हैं,

q)scores ~ flip flip scores
1b

तालियाँ kdb + के केंद्र में होती हैं। एक तालिका एक शब्दकोश के रूप में कार्यान्वित नाम स्तंभों का एक संग्रह है।q tables स्तंभ-उन्मुख हैं।

टेबल्स बनाना

तालिकाओं को निम्नलिखित सिंटैक्स का उपयोग करके बनाया जाता है -

q)trade:([]time:();sym:();price:();size:())

q)trade
time sym price size
-------------------

उपरोक्त उदाहरण में, हमने प्रत्येक कॉलम के प्रकार को निर्दिष्ट नहीं किया है। यह तालिका में पहली प्रविष्टि द्वारा सेट किया जाएगा।

एक और तरीका है, हम कॉलम प्रकार को इनिशियलाइज़ेशन पर निर्दिष्ट कर सकते हैं -

q)trade:([]time:`time$();sym:`$();price:`float$();size:`int$())

या हम गैर-रिक्त तालिकाओं को भी परिभाषित कर सकते हैं -

q)trade:([]sym:(`a`b);price:(1 2))

q)trade

 sym   price
-------------
  a      1
  b      2

यदि ऊपर के उदाहरणों में वर्ग कोष्ठक के भीतर कोई स्तंभ नहीं हैं, तो तालिका है unkeyed

बनाने के लिए keyed table, हम वर्ग कोष्ठक में कुंजी के लिए कॉलम (ओं) को सम्मिलित करते हैं।

q)trade:([sym:`$()]time:`time$();price:`float$();size:`int$())

q)trade

 sym   | time price size
-----  | ---------------

विभिन्न प्रकारों की शून्य सूची होने के लिए मानों को सेट करके स्तंभ प्रकारों को भी परिभाषित किया जा सकता है -

q)trade:([]time:0#0Nt;sym:0#`;price:0#0n;size:0#0N)

तालिका जानकारी प्राप्त करना

आइए एक व्यापार तालिका बनाएं -

trade: ([]sym:`ibm`msft`apple`samsung;mcap:2000 4000 9000 6000;ex:`nasdaq`nasdaq`DAX`Dow)

q)cols trade                         / column names of a table
`sym`mcap`ex

q)trade.sym                          / Retrieves the value of column sym
`ibm`msft`apple`samsung

q)show meta trade                    / Get the meta data of a table trade.

  c   | t f a
----- | -----
 Sym  | s
 Mcap | j
 ex   | s

प्राथमिक कुंजी और की-टेबल

की-टेबल

की-टेबल एक डिक्शनरी है, जो यूनीक की-टेबल की प्रत्येक पंक्ति को संबंधित टेबल की वैल्यूज़ की तालिका में मैप करती है। आइए एक उदाहरण लेते हैं -

val:flip `name`id!(`John`Jenny`Jonathan;9 18 27)
                          / a flip dictionary create table val
id:flip (enlist `eid)!enlist 99 198 297
                          / flip dictionary, having single column eid

अब एक साधारण की-टेबल बनाएं जिसमें ईद की चाबी हो,

q)valid: id ! val

q)valid                 / table name valid, having key as eid

  eid |  name      id
---   | ---------------
  99  |  John      9
  198 |  Jenny     18
  297 |  Jonathan  27

ForeignKeys

foreign key तालिका की पंक्तियों से एक मानचित्रण को परिभाषित करता है जिसमें इसे तालिका की पंक्तियों के अनुरूप परिभाषित किया जाता है primary key

विदेशी कुंजी प्रदान करते हैं referential integrity। दूसरे शब्दों में, विदेशी कुंजी मान सम्मिलित करने का प्रयास जो प्राथमिक कुंजी में नहीं है, विफल हो जाएगा।

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

Example 1 − Define foreign key on initialization

q)sector:([sym:`SAMSUNG`HSBC`JPMC`APPLE]ex:`N`CME`DAQ`N;MC:1000 2000 3000 4000)

q)tab:([]sym:`sector$`HSBC`APPLE`APPLE`APPLE`HSBC`JPMC;price:6?9f)

q)show meta tab

  c    | t f a
------ | ----------
 sym   | s sector
 price | f

q)show select from tab where sym.ex=`N

  sym     price
----------------
 APPLE   4.65382
 APPLE   4.643817
 APPLE   3.659978

Example 2 − no pre-defined relationship between tables

sector: ([symb:`IBM`MSFT`HSBC]ex:`N`CME`N;MC:1000 2000 3000)
tab:([]sym:`IBM`MSFT`MSFT`HSBC`HSBC;price:5?9f)

विदेशी कुंजी का उपयोग करने के लिए, हमें क्षेत्र में कुंजी के लिए एक तालिका बनानी होगी।

q)show update mc:(sector([]symb:sym))[`MC] from tab

  sym     price      mc
--------------------------
  IBM   7.065297    1000
  MSFT  4.812387    2000
  MSFT  6.400545    2000
  HSBC  3.704373    3000
  HSBC  4.438651    3000

पूर्वनिर्धारित विदेशी कुंजी के लिए सामान्य अंकन -

c से चयन करें जहाँ a विदेशी कुंजी है (सिम), b a है

प्राथमिक कुंजी तालिका (इंडस्ट्रीज़), सी में फ़ील्ड है

विदेशी कुंजी तालिका (व्यापार)

तालिकाओं में हेरफेर

आइए एक ट्रेड टेबल बनाएं और विभिन्न टेबल एक्सप्रेशन का परिणाम देखें -

q)trade:([]sym:5?`ibm`msft`hsbc`samsung;price:5?(303.00*3+1);size:5?(900*5);time:5?(.z.T-365))

q)trade

  sym        price   size   time
-----------------------------------------
 msft      743.8592  3162  02:32:17.036
 msft      641.7307  2917  01:44:56.936
 hsbc      838.2311  1492  00:25:23.210
 samsung   278.3498  1983  00:29:38.945
 ibm       838.6471  4006  07:24:26.842

आइए अब उन बयानों पर एक नज़र डालते हैं जिनका उपयोग सारणी में हेरफेर करने के लिए किया जाता है q भाषा: हिन्दी।

चुनते हैं

एक का उपयोग करने के लिए वाक्यविन्यास Select कथन इस प्रकार है -

select [columns] [by columns] from table [where clause]

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

q)/ select expression example

q)select sym,price,size by time from trade where size > 2000

    time      |  sym    price     size
------------- | -----------------------
 01:44:56.936 |  msft   641.7307  2917
 02:32:17.036 |  msft   743.8592  3162
 07:24:26.842 |  ibm    838.6471  4006

डालने

एक का उपयोग करने के लिए वाक्यविन्यास Insert कथन इस प्रकार है -

`tablename insert (values)
Insert[`tablename; values]

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

q)/ Insert expression example

q)`trade insert (`hsbc`apple;302.0 730.40;3020 3012;09:30:17.00409:15:00.000)
5 6

q)trade

   sym    price     size    time
------------------------------------------
  msft    743.8592  3162   02:32:17.036
  msft    641.7307  2917   01:44:56.936
  hsbc    838.2311  1492   00:25:23.210
 samsung  278.3498  1983   00:29:38.945
  ibm     838.6471  4006   07:24:26.842
  hsbc    302       3020   09:30:17.004
  apple   730.4     3012   09:15:00.000

q)/Insert another value

q)insert[`trade;(`samsung;302.0; 3333;10:30:00.000]
']

q)insert[`trade;(`samsung;302.0; 3333;10:30:00.000)]
,7

q)trade

   sym     price   size     time
----------------------------------------
  msft   743.8592  3162  02:32:17.036
  msft   641.7307  2917  01:44:56.936
  hsbc   838.2311  1492  00:25:23.210
 samsung 278.3498  1983  00:29:38.945
  ibm    838.6471  4006  07:24:26.842
  hsbc   302       3020  09:30:17.004
  apple  730.4     3012  09:15:00.000
 samsung 302       3333  10:30:00.000

हटाएं

एक का उपयोग करने के लिए वाक्यविन्यास Delete कथन इस प्रकार है -

delete columns from table
delete from table where clause

आइए अब एक उदाहरण लेते हैं कि डिलीट स्टेटमेंट का उपयोग कैसे करें -

q)/Delete expression example

q)delete price from trade

   sym   size       time
-------------------------------
  msft   3162   02:32:17.036
  msft   2917   01:44:56.936
  hsbc   1492   00:25:23.210
 samsung 1983   00:29:38.945
  ibm    4006   07:24:26.842
  hsbc   3020   09:30:17.004
  apple  3012   09:15:00.000
 samsung 3333   10:30:00.000

q)delete from trade where price > 3000

   sym     price     size       time
-------------------------------------------
  msft    743.8592   3162    02:32:17.036
  msft    641.7307   2917    01:44:56.936
  hsbc    838.2311   1492    00:25:23.210
 samsung  278.3498   1983    00:29:38.945
  ibm     838.6471   4006    07:24:26.842
  hsbc    302        3020    09:30:17.004
  apple   730.4      3012    09:15:00.000
 samsung  302        3333    10:30:00.000

q)delete from trade where price > 500

  sym     price     size     time
-----------------------------------------
 samsung  278.3498  1983  00:29:38.945
  hsbc    302       3020  09:30:17.004
 samsung  302       3333  10:30:00.000

अपडेट करें

एक का उपयोग करने के लिए वाक्यविन्यास Update कथन इस प्रकार है -

update column: newValue from table where ….

कास्ट फ़ंक्शन का उपयोग करके स्तंभ के प्रारूप / डेटाटाइप को अपडेट करने के लिए निम्न सिंटैक्स का उपयोग करें -

update column:newValue from `table where …

आइए अब एक उदाहरण लेते हैं कि कैसे उपयोग किया जाए Update कथन -

q)/Update expression example

q)update size:9000 from trade where price > 600

  sym     price      size     time
------------------------------------------
  msft    743.8592   9000   02:32:17.036
  msft    641.7307   9000   01:44:56.936
  hsbc    838.2311   9000   00:25:23.210
 samsung  278.3498   1983   00:29:38.945
  ibm     838.6471   9000   07:24:26.842
  hsbc    302        3020   09:30:17.004
  apple   730.4      9000   09:15:00.000
 samsung  302        3333   10:30:00.000

q)/Update the datatype of a column using the cast function

q)meta trade

   c  |  t f a
----- | --------
  sym |  s
 price|  f
 size |  j
 time |  t

q)update size:`float$size from trade sym price size time ------------------------------------------ msft 743.8592 3162 02:32:17.036 msft 641.7307 2917 01:44:56.936 hsbc 838.2311 1492 00:25:23.210 samsung 278.3498 1983 00:29:38.945 ibm 838.6471 4006 07:24:26.842 hsbc 302 3020 09:30:17.004 apple 730.4 3012 09:15:00.000 samsung 302 3333 10:30:00.000 q)/ Above statement will not update the size column datatype permanently q)meta trade c | t f a ------ | -------- sym | s price | f size | j time | t q)/to make changes in the trade table permanently, we have do q)update size:`float$size from `trade
`trade

q)meta trade

   c   |  t f a
------ | --------
  sym  |   s
 price |   f
 size  |   f
 time  |   t

Kdb + में संज्ञा, क्रिया और क्रिया विशेषण होते हैं। सभी डेटा ऑब्जेक्ट और फ़ंक्शन हैंnounsVerbs अभिव्यक्ति में वर्ग कोष्ठक और कोष्ठक की संख्या को कम करके पठनीयता को बढ़ाएं। Adverbsरंगादिक (2 तर्क) कार्यों और क्रियाओं को संशोधित करके नए, संबंधित क्रियाओं का उत्पादन करें। क्रियाविशेषण द्वारा निर्मित कार्यों को कहा जाता हैderived functions या derived verbs

से प्रत्येक

क्रिया विशेषण each, (,) से चिह्नित, डाइएडिक कार्यों और क्रियाओं को सूचियों के बजाय स्वयं सूचियों के लिए लागू करने के लिए संशोधित करता है। निम्नलिखित उदाहरण पर एक नज़र डालें -

q)1, (2 3 5)       / Join
1 2 3 5

q)1, '( 2 3 4)     / Join each
1 2
1 3
1 4

का एक रूप है Each"प्रत्येक" कीवर्ड का उपयोग करने वाले विवादास्पद कार्यों के लिए। उदाहरण के लिए,

q)reverse ( 1 2 3; "abc")           /Reverse
a b c
1 2 3

q)each [reverse] (1 2 3; "abc")     /Reverse-Each
3 2 1
c b a

q)'[reverse] ( 1 2 3; "abc")
3 2 1
c b a

प्रत्येक-वाम और प्रत्येक-दाएँ

रंगादिक कार्यों के लिए प्रत्येक के दो संस्करण हैं Each-Left (\:) तथा Each-Right(/ :)। निम्नलिखित उदाहरण बताते हैं कि उन्हें कैसे उपयोग करना है।

q)x: 9 18 27 36

q)y:10 20 30 40

q)x,y            / join
9 18 27 36 10 20 30 40

q)x,'y           / each

9   10
18  20
27  30
36  40

q)x: 9 18 27 36

q)y:10 20 30 40

q)x,y            / join
9 18 27 36 10 20 30 40

q)x,'y           / each, will return a list of pairs

9   10
18  20
27  30
36  40

q)x, \:y         / each left, returns a list of each element
                 / from x with all of y
					  
9   10  20  30  40
18  10  20  30  40
27  10  20  30  40
36  10  20  30  40

q)x,/:y          / each right, returns a list of all the x with
                 / each element of y
					  
9  18  27  36  10
9  18  27  36  20
9  18  27  36  30
9  18  27  36  40

q)1 _x           / drop the first element
18 27 36

q)-2_y           / drop the last two element
10 20

q)               / Combine each left and each right to be a
                 / cross-product (cartesian product)
                 
q)x,/:\:y

9   10  9   20  9   30  9   40
18  10  18  20  18  30  18  40
27  10  27  20  27  30  27  40
36  10  36  20  36  30  36  40

में qभाषा, हमारे पास आपूर्ति की गई तालिकाओं के आधार पर विभिन्न प्रकार के जोड़ होते हैं और जिस तरह की सम्मिलित तालिकाओं की हम इच्छा करते हैं। एक जुड़ाव दो तालिकाओं से डेटा को जोड़ता है। विदेशी कुंजी का पीछा करने के अलावा, तालिकाओं में शामिल होने के चार अन्य तरीके हैं -

  • सरल जुड़
  • असोफ जुड़ते हैं
  • बाँया जोड़
  • संघ शामिल हों

यहाँ, इस अध्याय में, हम इनमें से प्रत्येक जोड़ पर विस्तार से चर्चा करेंगे।

सरल सम्मिलित हों

सरल जुड़ाव सबसे बुनियादी प्रकार का जुड़ाव है, जो अल्पविराम के साथ किया जाता है ','। इस मामले में, दो तालिकाओं होना चाहिएtype conformant, अर्थात्, दोनों तालिकाओं में समान क्रम में समान संख्या में स्तंभ हैं, और समान कुंजी है।

table1,:table2 / table1 is assigned the value of table2

हम बग़ल में शामिल होने के लिए समान लंबाई वाली तालिकाओं के लिए अल्पविराम से प्रत्येक में शामिल हो सकते हैं। तालिकाओं में से एक को यहां रखा जा सकता है,

Table1, `Table2

असोफ जॉइन (अंज)

यह सबसे शक्तिशाली जुड़ाव है जिसका उपयोग किसी तालिका में किसी तालिका में किसी क्षेत्र के मान को प्राप्त करने के लिए किया जाता है। आम तौर पर इसका इस्तेमाल प्रचलित बोली प्राप्त करने और प्रत्येक व्यापार के समय पूछने के लिए किया जाता है।

सामान्य प्रारूप

aj[joinColumns;tbl1;tbl2]

उदाहरण के लिए,

aj[`sym`time;trade;quote]

उदाहरण

q)tab1:([]a:(1 2 3 4);b:(2 3 4 5);d:(6 7 8 9))

q)tab2:([]a:(2 3 4);b:(3 4 5); c:( 4 5 6))

q)show aj[`a`b;tab1;tab2]

 a  b  d  c
-------------
 1  2  6
 2  3  7  4
 3  4  8  5
 4  5  9  6

लेफ्ट जॉइन (lj)

यह aj का एक विशेष मामला है जहाँ दूसरा तर्क एक की-टेबल है और पहले तर्क में सही तर्क की कुंजी के कॉलम हैं।

सामान्य प्रारूप

table1 lj Keyed-table

उदाहरण

q)/Left join- syntax table1 lj table2 or lj[table1;table2]

q)tab1:([]a:(1 2 3 4);b:(2 3 4 5);d:(6 7 8 9))

q)tab2:([a:(2 3 4);b:(3 4 5)]; c:( 4 5 6))

q)show lj[tab1;tab2]

 a  b  d  c
-------------
 1  2  6
 2  3  7  4
 3  4  8  5
 4  5  9  6

संघ में शामिल हों (uj)

यह अलग-अलग स्कीमाओं के साथ दो तालिकाओं का एक संघ बनाने की अनुमति देता है। यह मूल रूप से सरल जुड़ाव () के लिए एक विस्तार है

q)tab1:([]a:(1 2 3 4);b:(2 3 4 5);d:(6 7 8 9))

q)tab2:([]a:(2 3 4);b:(3 4 5); c:( 4 5 6))

q)show uj[tab1;tab2]

 a  b  d  c
------------
 1  2  6
 2  3  7
 3  4  8
 4  5  9
 2  3     4
 3  4     5
 4  5     6

यदि आप keyed टेबल पर uj का उपयोग कर रहे हैं, तो प्राथमिक कुंजियों से मेल खाना चाहिए।

प्रकार के कार्य

कार्यों को कई तरीकों से वर्गीकृत किया जा सकता है। यहां हमने उन्हें संख्या और तर्क के प्रकार और परिणाम प्रकार के आधार पर वर्गीकृत किया है। कार्य हो सकते हैं,

  • Atomic - जहां तर्क परमाणु हैं और परमाणु परिणाम उत्पन्न करते हैं

  • Aggregate - सूची से परमाणु

  • Uniform (list from list)- परमाणु की अवधारणा को विस्तारित किया क्योंकि वे सूचियों पर लागू होते हैं। तर्क सूची की गिनती परिणाम सूची की संख्या के बराबर होती है।

  • Other - यदि फ़ंक्शन उपरोक्त श्रेणी से नहीं है।

गणित में द्विआधारी संचालन को कहा जाता है dyadic functionsq में; उदाहरण के लिए, "+"। इसी तरह एकरी संचालन कहा जाता हैmonadic functions; उदाहरण के लिए, "एब्स" या "फ्लोर"।

अक्सर उपयोग किए जाने वाले कार्य

में अक्सर उपयोग किए जाने वाले कुछ कार्य हैं qप्रोग्रामिंग। यहाँ, इस भाग में, हम कुछ लोकप्रिय कार्यों का उपयोग देखेंगे -

पेट

q) abs -9.9 / Absolute value, Negates -ve number & leaves non -ve number
9.9

सब

q) all 4 5 0 -4 / Logical AND (numeric min), returns the minimum value
0b

मैक्स (&), मिन (!), और नहीं (!)

q) /And, Or, and Logical Negation

q) 1b & 1b        / And (Max)
1b

q) 1b|0b              / Or (Min)
1b

q) not 1b             /Logical Negate (Not)
0b

एएससी

q)asc 1 3 5 7 -2 0 4    / Order list ascending, sorted list
                        / in ascending order i
s returned
`s#-2 0 1 3 4 5 7

q)/attr - gives the attributes of data, which describe how it's sorted.
`s denotes fully sorted, `u denotes unique and `p and `g are used to 
refer to lists with repetition, with `p standing for parted and `g for grouped

औसत

q)avg 3 4 5 6 7           / Return average of a list of numeric values
5f

q)/Create on trade table

q)trade:([]time:3?(.z.Z-200);sym:3?(`ibm`msft`apple);price:3?99.0;size:3?100)

द्वारा

q)/ by - Groups rows in a table at given sym

q)select sum price by sym from trade    / find total price for each sym

  sym  |   price
------ | --------
 apple | 140.2165
  ibm  | 16.11385

कॉलम

q)cols trade / Lists columns of a table
`time`sym`price`size

गिनती

q)count (til 9) / Count list, count the elements in a list and
                / return a single int value 9

बंदरगाह

q)\p 9999 / assign port number

q)/csv - This command allows queries in a browser to be exported to
   excel by prefixing the query, such as http://localhost:9999/.csv?select from trade where sym =`ibm

कट गया

q)/ cut - Allows a table or list to be cut at a certain point

q)(1 3 5) cut "abcdefghijkl"
                            / the argument is split at 1st, 3rd and 5th letter.
"bc"
"de"
"fghijkl"

q)5 cut "abcdefghijkl"      / cut the right arg. Into 5 letters part
                            / until its end.
"abcde"
"fghij"
"kl"

हटाएं

q)/delete - Delete rows/columns from a table

q)delete price from trade

          time              sym   size
---------------------------------------
  2009.06.18T06:04:42.919  apple   36
  2009.11.14T12:42:34.653   ibm    12
  2009.12.27T17:02:11.518  apple   97

अलग

q)/distinct - Returns the distinct element of a list

q)distinct 1 2 3 2 3 4 5 2 1 3            / generate unique set of number
1 2 3 4 5

प्राप्त करना

q)/enlist - Creates one-item list.

q)enlist 37
,37

q)type 37           / -ve type value
-7h

q)type enlist 37    / +ve type value
7h

भरें (^)

q)/fill - used with nulls. There are three functions for processing null values.

The dyadic function named fill replaces null values in the right argument with the atomic left argument.

q)100 ^ 3 4 0N 0N -5
3 4 100 100 -5

q)`Hello^`jack`herry``john`
`jack`herry`Hello`john`Hello

भरण

q)/fills - fills in nulls with the previous not null value.

q)fills 1 0N 2 0N 0N 2 3 0N -5 0N
1 1 2 2 2 2 3 3 -5 -5

प्रथम

q)/first - returns the first atom of a list

q)first 1 3 34 5 3
1

फ्लिप

q)/flip - Monadic primitive that applies to lists and associations. It interchange the top two levels of its argument.

q)trade

       time                   sym      price   size
------------------------------------------------------
  2009.06.18T06:04:42.919    apple   72.05742   36
  2009.11.14T12:42:34.653    ibm     16.11385   12
  2009.12.27T17:02:11.518    apple   68.15909   97

q)flip trade

time | 2009.06.18T06:04:42.919 2009.11.14T12:42:34.653
2009.12.27T17:02:11.518

sym   |  apple         ibm         apple
price | 72.05742     16.11385    68.15909
size  | 36 12 97

IASC

q)/iasc - Index ascending, return the indices of the ascended sorted list relative to the input list.

q)iasc 5 4 0 3 4 9

2 3 1 4 0 5

Idesc

q)/idesc - Index desceding, return the descended sorted list relative to the input list

q)idesc 0 1 3 4

3 2 1 0

में

q)/in - In a list, dyadic function used to query list (on the right-handside) about their contents.

q)(2 4) in 1 2 3

10b

डालने

q)/insert - Insert statement, upload new data into a table.

q)insert[`trade;((.z.Z);`samsung;48.35;99)],3

q)trade

      time                  sym       price     size
------------------------------------------------------
 2009.06.18T06:04:42.919   apple    72.05742     36
 2009.11.14T12:42:34.653    ibm     16.11385     12
 2009.12.27T17:02:11.518   apple    68.15909     97
 2015.04.06T10:03:36.738   samsung  48.35        99

चाभी

q)/key - three different functions i.e. generate +ve integer number, gives content of a directory or key of a table/dictionary.

q)key 9

0 1 2 3 4 5 6 7 8

q)key `:c:
`$RECYCLE.BIN`Config.Msi`Documents and Settings`Drivers`Geojit`hiberfil.sys`I..

कम

q)/lower - Convert to lower case and floor

q)lower ("JoHn";`HERRY`SYM)
"john"
`herry`sym

अधिकतम और न्यूनतम (यानी | और)

q)/Max and Min / a|b and a&b

q)9|7
9

q)9&5
5

शून्य

q)/null - return 1b if the atom is a null else 0b from the argument list

q)null 1 3 3 0N
0001b

आड़ू

q)/peach - Parallel each, allows process across slaves

q)foo peach list1       / function foo applied across the slaves named in list1

'list1

q)foo:{x+27}

q)list1:(0 1 2 3 4)

q)foo peach list1       / function foo applied across the slaves named in list1
27 28 29 30 31

पिछला

q)/prev - returns the previous element i.e. pushes list forwards

q)prev 0 1 3 4 5 7

0N 0 1 3 4 5

रैंडम (?)

q)/random - syntax - n?list, gives random sequences of ints and floats

q)9?5
0 0 4 0 3 2 2 0 1

q)3?9.9
0.2426823 1.674133 3.901671

ढाना

q)/raze - Flattn a list of lists, removes a layer of indexing from a list of lists. for instance:

q)raze (( 12 3 4; 30 0);("hello";7 8); 1 3 4)

12 3 4
30 0
"hello"
7 8
1
3
4

read0

q)/read0 - Read in a text file

q)read0 `:c:/q/README.txt    / gives the contents of *.txt file

read1

q)/read1 - Read in a q data file

q)read1 `:c:/q/t1

0xff016200630b000500000073796d0074696d6500707269636…

उलटना

q)/reverse - Reverse a list

q)reverse 2 30 29 1 3 4

4 3 1 29 30 2

q)reverse "HelloWorld"

"dlroWolleH"

सेट

q)/set - set value of a variable

q)`x set 9
`x

q)x
9

q)`:c:/q/test12 set trade

`:c:/q/test12

q)get `:c:/q/test12

       time                   sym      price     size
---------------------------------------------------------
  2009.06.18T06:04:42.919    apple    72.05742    36
  2009.11.14T12:42:34.653     ibm     16.11385    12
  2009.12.27T17:02:11.518    apple    68.15909    97
  2015.04.06T10:03:36.738    samsung  48.35       99
  2015.04.06T10:03:47.540    samsung  48.35       99
  2015.04.06T10:04:44.844    samsung  48.35       99

एसएसआर

q)/ssr - String search and replace, syntax - ssr["string";searchstring;replaced-with]

q)ssr["HelloWorld";"o";"O"]

"HellOWOrld"

तार

q)/string - converts to string, converts all types to a string format.

q)string (1 2 3; `abc;"XYZ";0b)

(,"1";,"2";,"3")
"abc"

(,"X";,"Y";,"Z")
,"0"

एसवी

q)/sv - Scalar from vector, performs different tasks dependent on its arguments.

It evaluates the base representation of numbers, which allows us to calculate the number of seconds in a month or convert a length from feet and inches to centimeters.

q)24 60 60 sv 11 30 49

41449   / number of seconds elapsed in a day at 11:30:49

प्रणाली

q)/system - allows a system command to be sent,

q)system "dir *.py"

" Volume in drive C is New Volume"
" Volume Serial Number is 8CD2-05B2"
""

" Directory of C:\\Users\\myaccount-raj"
""

"09/14/2014    06:32 PM     22 hello1.py"
"                1 File(s)    22 bytes"

टेबल

q)/tables - list all tables

q)tables `

`s#`tab1`tab2`trade

टिल

q)/til - Enumerate

q)til 5

0 1 2 3 4

ट्रिम

q)/trim - Eliminate string spaces

q)trim " John "

"John"

बनाम

q)/vs - Vector from scaler , produces a vector quantity from a scaler quantity

q)"|" vs "20150204|msft|20.45"

"20150204"
"msft"
"20.45"

xasc

q)/xasc - Order table ascending, allows a table (right-hand argument) to be sorted such that (left-hand argument) is in ascending order

q)`price xasc trade

          time                 sym      price      size
----------------------------------------------------------
   2009.11.14T12:42:34.653     ibm     16.11385     12
   2015.04.06T10:03:36.738   samsung   48.35        99
   2015.04.06T10:03:47.540   samsung   48.35        99
   2015.04.06T10:04:44.844   samsung   48.35        99
   2009.12.27T17:02:11.518    apple    68.15909     97
   2009.06.18T06:04:42.919    apple    72.05742     36

xcol

q)/xcol - Renames columns of a table

q)`timeNew`symNew xcol trade

        timeNew                 symNew    price      size
-------------------------------------------------------------
   2009.06.18T06:04:42.919      apple    72.05742     36
   2009.11.14T12:42:34.653       ibm     16.11385     12
   2009.12.27T17:02:11.518      apple    68.15909     97
   2015.04.06T10:03:36.738     samsung   48.35        99
   2015.04.06T10:03:47.540     samsung   48.35        99
   2015.04.06T10:04:44.844     samsung   48.35        99

xcols

q)/xcols - Reorders the columns of a table,

q)`size`price xcols trade

  size    price           time                   sym
-----------------------------------------------------------
   36   72.05742   2009.06.18T06:04:42.919      apple 
   12   16.11385   2009.11.14T12:42:34.653       ibm
   97   68.15909   2009.12.27T17:02:11.518      apple
   99   48.35      2015.04.06T10:03:36.738     samsung 
   99   48.35      2015.04.06T10:03:47.540     samsung
   99   48.35      2015.04.06T10:04:44.844     samsung

xdesc

q)/xdesc - Order table descending, allows tables to be sorted such that the left-hand argument is in descending order.

q)`price xdesc trade

        time                   sym       price      size
-----------------------------------------------------------
   2009.06.18T06:04:42.919    apple    72.05742      36
   2009.12.27T17:02:11.518    apple    68.15909      97
   2015.04.06T10:03:36.738   samsung   48.35         99
   2015.04.06T10:03:47.540   samsung   48.35         99
   2015.04.06T10:04:44.844   samsung   48.35         99
   2009.11.14T12:42:34.653     ibm     16.11385      12

xgroup

q)/xgroup - Creates nested table

q)`x xgroup ([]x:9 18 9 18 27 9 9;y:10 20 10 20 30 40)
'length

q)`x xgroup ([]x:9 18 9 18 27 9 9;y:10 20 10 20 30 40 10)

  x  |    y
---- | -----------
  9  | 10 10 40 10
  18 | 20 20
  27 | ,30

xkey

q)/xkey - Set key on table

q)`sym xkey trade

    sym   |      time                    price     size
--------- | -----------------------------------------------
   apple  | 2009.06.18T06:04:42.919    72.05742     36
    ibm   | 2009.11.14T12:42:34.653    16.11385     12
   apple  | 2009.12.27T17:02:11.518    68.15909     97
  samsung | 2015.04.06T10:03:36.738    48.35        99
  samsung | 2015.04.06T10:03:47.540    48.35        99
  samsung | 2015.04.06T10:04:44.844    48.35        99

सिस्टम कमांड्स

सिस्टम कमांड नियंत्रण करते हैं qवातावरण। वे निम्न रूप हैं -

\cmd [p]       where p may be optional

कुछ लोकप्रिय सिस्टम कमांड के बारे में नीचे चर्चा की गई है -

\ [एक नामस्थान] - दिए गए नामस्थान में सूची तालिकाएँ

q)/Tables in default namespace

q)\a
,`trade

q)\a .o         / table in .o namespace.
,`TI

\ b - निर्भरताएँ देखें

q)/ views/dependencies

q)a:: x+y      / global assingment

q)b:: x+1

q)\b
`s#`a`b

\ B - लंबित विचार / निर्भरता

q)/ Pending views/dependencies

q)a::x+1     / a depends on x

q)\B         / the dependency is pending
' / the dependency is pending

q)\B
`s#`a`b

q)\b
`s#`a`b

q)b
29

q)a
29

q)\B
`symbol$()

\ cd - निर्देशिका बदलें

q)/change directory, \cd [name]

q)\cd
"C:\\Users\\myaccount-raj"

q)\cd ../new-account

q)\cd
"C:\\Users\\new-account"

\ d - वर्तमान नामस्थान सेट करता है

q)/ sets current namespace \d [namespace]

q)\d             /default namespace
'

q)\d .o          /change to .o

q.o)\d
`.o

q.o)\d .         / return to default

q)key `          /lists namespaces other than .z
`q`Q`h`j`o

q)\d .john       /change to non-existent namespace

q.john)\d
`.john

q.john)\d .

q)\d
`.

\ l - db से फ़ाइल या निर्देशिका लोड करें

q)/ Load file or directory, \l

q)\l test2.q / loading test2.q which is stored in current path.

   ric      |     date      ex      openP    closeP    MCap
----------- | -------------------------------------------------
 JPMORGAN   | 2008.05.23  SENSEX  18.30185  17.16319  17876
   HSBC     | 2002.05.21  NIFTY   2.696749  16.58846  26559
 JPMORGAN   | 2006.09.07  NIFTY   14.15219  20.05624  14557
   HSBC     | 2010.10.11  SENSEX  7.394497  25.45859  29366
 JPMORGAN   | 2007.10.02  SENSEX  1.558085  25.61478  20390
 
   ric     |    date       ex      openP     closeP    MCap
---------- | ------------------------------------------------
  INFOSYS  | 2003.10.30    DOW    21.2342   7.565652   2375
 RELIANCE  | 2004.08.12    DOW    12.34132  17.68381   4201
   SBIN    | 2008.02.14    DOW    1.830857  9.006485   15465
  INFOSYS  | 2009.06.11  HENSENG  19.47664  12.05208   11143
   SBIN    | 2010.07.05    DOW    18.55637  10.54082   15873

\ p - पोर्ट नंबर

q)/ assign port number, \p

q)\p
5001i

q)\p 8888

q)\p
8888i

\\ - q कंसोल से बाहर निकलें

\\ - exit
Exit form q.

qप्रोग्रामिंग भाषा में समृद्ध और शक्तिशाली अंतर्निहित कार्यों का एक सेट है। एक अंतर्निहित फ़ंक्शन निम्न प्रकार के हो सकते हैं -

  • String function - इनपुट के रूप में एक स्ट्रिंग लेता है और एक स्ट्रिंग लौटाता है।

  • Aggregate function - एक सूची को इनपुट के रूप में लेता है और एक परमाणु लौटाता है।

  • Uniform function - एक सूची लेता है और एक ही गिनती की एक सूची देता है।

  • Mathematical function - संख्यात्मक तर्क लेता है और एक संख्यात्मक तर्क देता है।

  • Miscellaneous function - उपर्युक्त के अलावा अन्य सभी कार्य।

स्ट्रिंग फ़ंक्शंस

जैसे - पैटर्न का मिलान

q)/like is a dyadic, performs pattern matching, return 1b on success else 0b

q)"John" like "J??n"
1b

q)"John My Name" like "J*"
1b

ltrim - प्रमुख रिक्त स्थान को हटाता है

q)/ ltrim - monadic ltrim takes string argument, removes leading blanks

q)ltrim " Rick "
"Rick "

rtrim - trailing blanks को हटाता है

q)/rtrim - takes string argument, returns the result of removing trailing blanks

q)rtrim " Rick "
" Rick"

ss - स्ट्रिंग खोज

q)/ss - string search, perform pattern matching, same as "like" but return the indices of the matches of the pattern in source.

q)"Life is beautiful" ss "i"
1 5 13

ट्रिम - प्रमुख और पीछे के रिक्त स्थान को हटाता है

q)/trim - takes string argument, returns the result of removing leading & trailing blanks

q)trim " John "
"John"

गणितीय कार्य

acos - कॉस का विलोम

q)/acos - inverse of cos, for input between -1 and 1, return float between 0 and pi

q)acos 1
0f

q)acos -1
3.141593

q)acos 0
1.570796

cor - सहसंबंध देता है

q)/cor - the dyadic takes two numeric lists of same count, returns a correlation between the items of the two arguments

q)27 18 18 9 0 cor 27 36 45 54 63
-0.9707253

क्रॉस - कार्टेशियन उत्पाद

q)/cross - takes atoms or lists as arguments and returns their Cartesian product

q)9 18 cross `x`y`z

9 `x
9 `y
9 `z

18 `x
18 `y
18 `z

var - विचरण

q)/var - monadic, takes a scaler or numeric list and returns a float equal to the mathematical variance of the items

q)var 45
0f

q)var 9 18 27 36
101.25

wavg

q)/wavg - dyadic, takes two numeric lists of the same count and returns the average of the second argument weighted by the first argument.

q)1 2 3 4 wavg 200 300 400 500
400f

अलग कार्य

सभी - और ऑपरेशन

q)/all - monadic, takes a scaler or list of numeric type and returns the result of & applied across the items.

q)all 0b
0b

q)all 9 18 27 36
1b

q)all 10 20 30
1b

कोई - | ऑपरेशन

q)/any - monadic, takes scaler or list of numeric type and the return the result of | applied across the items

q)any 20 30 40 50
1b

q)any 20012.02.12 2013.03.11
'20012.02.12

prd - अंकगणितीय उत्पाद

q)/prd - monadic, takes scaler, list, dictionary or table of numeric type and returns the arithmetic product.

q)prd `x`y`z! 10 20 30
6000

q)prd ((1 2; 3 4);(10 20; 30 40))

10 40
90 160

सम - अंकगणित राशि

q)/sum - monadic, takes a scaler, list,dictionary or table of numeric type and returns the arithmetic sum.

q)sum 2 3 4 5 6
20

q)sum (1 2; 4 5)
5 7

समान कार्य

डेल्टास - इसके पिछले आइटम से अंतर।

q)/deltas -takes a scalar, list, dictionary or table and returns the difference of each item from its predecessor.

q)deltas 2 3 5 7 9
2 1 2 2 2

q)deltas `x`y`z!9 18 27

x | 9
y | 9
z | 9

भरता है - शून्य मान को भरता है

q)/fills - takes scalar, list, dictionary or table of numeric type and returns a c copy of the source in which non-null items are propagated forward to fill nulls

q)fills 1 0N 2 0N 4
1 1 2 2 4

q)fills `a`b`c`d! 10 0N 30 0N

a | 10
b | 10
c | 30
d | 30

maxs - अधिकतम संचयी

q)/maxs - takes scalar, list, dictionary or table and returns the cumulative maximum of the source items.

q)maxs 1 2 4 3 9 13 2
1 2 4 4 9 13 13

q)maxs `a`b`c`d!9 18 0 36

a | 9
b | 18
c | 18
d | 36

विविध कार्य

गणना - तत्व की वापसी संख्या

q)/count - returns the number of entities in its argument.

q)count 10 30 30
3

q)count (til 9)
9

q)count ([]a:9 18 27;b:1.1 2.2 3.3)
3

विशिष्ट - अलग-अलग संस्थाओं को वापस करें

q)/distinct - monadic, returns the distinct entities in its argument

q)distinct 1 2 3 4 2 3 4 5 6 9
1 2 3 4 5 6 9

सिवाय - तत्व दूसरे arg में मौजूद नहीं है।

q)/except - takes a simple list (target) as its first argument and returns a list containing the items of target that are not in its second argument

q)1 2 3 4 3 1 except 1
2 3 4 3

भरना - पहले तर्क से अशक्त भरना

q)/fill (^) - takes an atom as its first argument and a list(target) as its second argument and return a list obtained by substituting the first argument for every occurrence of null in target

q)42^ 9 18 0N 27 0N 36
9 18 42 27 42 36

q)";"^"Life is Beautiful"
"Life;is;Beautiful"

में क्वेरीज़ qछोटे और सरल हैं और sql की क्षमताओं का विस्तार करते हैं। मुख्य क्वेरी अभिव्यक्ति 'चयन अभिव्यक्ति' है, जो अपने सरलतम रूप में उप-तालिकाओं को निकालता है लेकिन यह नए कॉलम भी बना सकता है।

का सामान्य रूप a Select expression इस प्रकार है -

Select columns by columns from table where conditions

**Note − by & where वाक्यांश वैकल्पिक हैं, केवल 'अभिव्यक्ति से' अनिवार्य है।

सामान्य तौर पर, वाक्यविन्यास होगा -

select [a] [by b] from t [where c]
update [a] [by b] from t [where c]

का वाक्य विन्यास q अभिव्यक्तियाँ SQL के समान दिखती हैं, लेकिन qभाव सरल और शक्तिशाली हैं। उपरोक्त के लिए एक समान sql अभिव्यक्तिq अभिव्यक्ति इस प्रकार होगी -

select [b] [a] from t [where c] [group by b order by b]
update t set [a] [where c]

सभी खंड स्तंभों पर निष्पादित होते हैं और इसलिए qआदेश का लाभ ले सकते हैं। चूंकि Sql क्वेरी ऑर्डर पर आधारित नहीं हैं, वे उस लाभ को नहीं ले सकते।

qसंबंधपरक क्वेश्चन आमतौर पर आकार में बहुत छोटे होते हैं, जबकि उनके संबंधित एसक्यूएल की तुलना में। आदेशित और कार्यात्मक प्रश्न उन चीजों को करते हैं जो sql में मुश्किल हैं।

एक ऐतिहासिक डेटाबेस में, का क्रम whereक्लॉज बहुत महत्वपूर्ण है क्योंकि यह क्वेरी के प्रदर्शन को प्रभावित करता है। partition चर (दिनांक / माह / दिन) हमेशा पहले क्रमबद्ध और अनुक्रमित कॉलम (आमतौर पर सिम्बल कॉलम) के बाद आता है।

उदाहरण के लिए,

select from table where date in d, sym in s

की तुलना में बहुत तेज है,

select from table where sym in s, date in d

मूल बातें क्वेरी

नोटपैड में क्वेरी स्क्रिप्ट लिखें (नीचे के रूप में), सहेजें (* .q) के रूप में, और फिर इसे लोड करें।

sym:asc`AIG`CITI`CSCO`IBM`MSFT;
ex:"NASDAQ"
dst:`$":c:/q/test/data/"; /database destination @[dst;`sym;:;sym]; n:1000000; trade:([]sym:n?`sym;time:10:30:00.0+til n;price:n?3.3e;size:n?9;ex:n?ex); quote:([]sym:n?`sym;time:10:30:00.0+til n;bid:n?3.3e;ask:n?3.3e;bsize:n?9;asize:n?9;ex:n?ex); {@[;`sym;`p#]`sym xasc x}each`trade`quote; d:2014.08.07 2014.08.08 2014.08.09 2014.08.10 2014.08.11; /Date vector can also be changed by the user dt:{[d;t].[dst;(`$string d;t;`);:;value t]};
d dt/:\:`trade`quote;

Note: Once you run this query, two folders .i.e. "test" and "data" will be created under "c:/q/", and date partition data can be seen inside data folder.

बाधाओं के साथ प्रश्न

* Denotes HDB query

Select all IBM trades

select from trade where sym in `IBM

*Select all IBM trades on a certain day

thisday: 2014.08.11
select from trade where date=thisday,sym=`IBM

Select all IBM trades with a price > 100

select from trade where sym=`IBM, price > 100.0

Select all IBM trades with a price less than or equal to 100

select from trade where sym=`IBM,not price > 100.0

*Select all IBM trades between 10.30 and 10.40, in the morning, on a certain date

thisday: 2014.08.11
select from trade where
date = thisday, sym = `IBM, time > 10:30:00.000,time < 10:40:00.000

Select all IBM trades in ascending order of price

`price xasc select from trade where sym =`IBM

*Select all IBM trades in descending order of price in a certain time frame

`price xdesc select from trade where date within 2014.08.07 2014.08.11, sym =`IBM

Composite sort − sort ascending order by sym and then sort the result in descending order of price

`sym xasc `price xdesc select from trade where date = 2014.08.07,size = 5

Select all IBM or MSFT trades

select from trade where sym in `IBM`MSFT

*Calculate count of all symbols in ascending order within a certain time frame

`numsym xasc select numsym: count i by sym from trade where date within 2014.08.07 2014.08.11

*Calculate count of all symbols in descending order within a certain time frame

`numsym xdesc select numsym: count i by sym from trade where date within 2014.08.07 2014.08.11

* What is the maximum price of IBM stock within a certain time frame, and when does this first happen?

select time,ask from quote where date within 2014.08.07 2014.08.11,
sym =`IBM, ask = exec first ask from select max ask from quote where
sym =`IBM

Select the last price for each sym in hourly buckets

select last price by hour:time.hh, sym from trade

एकत्रीकरण के साथ प्रश्न

* Calculate vwap (Volume Weighted Average Price) of all symbols

select vwap:size wavg price by sym from trade

* Count the number of records (in millions) for a certain month

(select trade:1e-6*count i by date.dd from trade where date.month=2014.08m) + select quote:1e-6*count i by date.dd from quote where date.month=2014.08m

* HLOC – Daily High, Low, Open and Close for CSCO in a certain month

select high:max price,low:min price,open:first price,close:last price by date.dd from trade where date.month=2014.08m,sym =`CSCO

* Daily Vwap for CSCO in a certain month

select vwap:size wavg price by date.dd from trade where date.month = 2014.08m ,sym = `CSCO

* Calculate the hourly mean, variance and standard deviation of the price for AIG

select mean:avg price, variance:var price, stdDev:dev price by date, hour:time.hh from trade where sym = `AIG

Select the price range in hourly buckets

select range:max[price] – min price by date,sym,hour:time.hh from trade

* Daily Spread (average bid-ask) for CSCO in a certain month

select spread:avg bid-ask by date.dd from quote where date.month = 2014.08m, sym = `CSCO

* Daily Traded Values for all syms in a certain month

select dtv:sum size by date,sym from trade where date.month = 2014.08m

Extract a 5 minute vwap for CSCO

select size wavg price by 5 xbar time.minute from trade where sym = `CSCO

* Extract 10 minute bars for CSCO

select high:max price,low:min price,close:last price by date, 10 xbar time.minute from trade where sym = `CSCO

* Find the times when the price exceeds 100 basis points (100e-4) over the last price for CSCO for a certain day

select time from trade where date = 2014.08.11,sym = `CSCO,price > 1.01*last price

* Full Day Price and Volume for MSFT in 1 Minute Intervals for the last date in the database

select last price,last size by time.minute from trade where date = last date, sym = `MSFT

केडीबी + एक प्रक्रिया को इंटरप्रोसेस संचार के माध्यम से दूसरी प्रक्रिया के साथ संवाद करने की अनुमति देता है। Kdb + प्रक्रियाएं किसी भी अन्य kdb + को एक ही कंप्यूटर, एक ही नेटवर्क या दूर से भी कनेक्ट कर सकती हैं। हमें केवल पोर्ट निर्दिष्ट करने की आवश्यकता है और फिर क्लाइंट उस पोर्ट से बात कर सकते हैं। कोई भीq प्रक्रिया किसी भी अन्य के साथ संवाद कर सकती है q प्रक्रिया जब तक यह नेटवर्क पर सुलभ है और कनेक्शन के लिए सुन रही है।

  • एक सर्वर प्रक्रिया कनेक्शन के लिए सुनती है और किसी भी अनुरोध को संसाधित करती है

  • क्लाइंट प्रक्रिया कनेक्शन आरंभ करती है और निष्पादित होने के लिए कमांड भेजती है

क्लाइंट और सर्वर एक ही मशीन या विभिन्न मशीनों पर हो सकते हैं। एक प्रक्रिया क्लाइंट और सर्वर दोनों हो सकती है।

एक संचार हो सकता है,

  • Synchronous (परिणाम वापस होने की प्रतीक्षा करें)

  • Asynchronous (कोई प्रतीक्षा नहीं और कोई परिणाम नहीं लौटा)

आरंभिक सर्वर

q सर्वर को सुनने के लिए पोर्ट निर्दिष्ट करके आरम्भ किया गया है,

q –p 5001 / command line
\p 5001   / session command

संचार संभाल

एक संचार संभाल एक प्रतीक है जो ":" से शुरू होता है और इसका रूप है -

`:[server]:port-number

उदाहरण

`::5001              / server and client on same machine
`:jack:5001          / server on machine jack
`:192.168.0.156      / server on specific IP address
`:www.myfx.com:5001  / server at www.myfx.com

कनेक्शन शुरू करने के लिए, हम फ़ंक्शन "हॉप" का उपयोग करते हैं जो पूर्णांक कनेक्शन हैंडल देता है। यह हैंडल सभी बाद के क्लाइंट अनुरोधों के लिए उपयोग किया जाता है। उदाहरण के लिए -

q)h:hopen `::5001

q)h"til 5"
0 1 2 3 4

q)hclose h

तुल्यकालिक और अतुल्यकालिक संदेश

एक बार हमारे पास एक हैंडल है, हम एक संदेश भेज सकते हैं या तो सिंक्रोनाइज़ या एसिंक्रोनस रूप से।

Synchronous Message- एक संदेश भेजे जाने के बाद, यह प्रतीक्षा करता है और परिणाम देता है। इसका प्रारूप इस प्रकार है -

handle “message”

Asynchronous Message- एक संदेश भेजने के बाद, इंतजार किए बिना और वापस लौटने के बिना तुरंत अगले कथन को संसाधित करना शुरू करें। इसका प्रारूप इस प्रकार है -

neg[handle] “message”

ऐसे संदेश जिनमें प्रतिक्रिया की आवश्यकता होती है, उदाहरण के लिए फ़ंक्शन कॉल या स्टेटमेंट्स का चयन करें, सामान्य रूप से सिंक्रोनस फॉर्म का उपयोग करेंगे; जबकि संदेश जो आउटपुट को वापस करने की आवश्यकता नहीं है, उदाहरण के लिए तालिका में अपडेट सम्मिलित करना, अतुल्यकालिक होगा।

जब एक q प्रक्रिया दूसरे से जुड़ती है qअंतर-प्रक्रिया संचार के माध्यम से प्रक्रिया, यह संदेश संचालकों द्वारा संसाधित किया जाता है। इन संदेश संचालकों का डिफ़ॉल्ट व्यवहार होता है। उदाहरण के लिए, सिंक्रोनस मैसेज हैंडलिंग के मामले में, हैंडलर क्वेरी का मान लौटाता है। इस मामले में सिंक्रोनस हैंडलर है.z.pg, जो हम आवश्यकता के अनुसार ओवरराइड कर सकते थे।

Kdb + प्रक्रियाओं में कई पूर्व-परिभाषित संदेश हैंडलर होते हैं। डेटाबेस को कॉन्फ़िगर करने के लिए संदेश हैंडलर महत्वपूर्ण हैं। कुछ उपयोगों में शामिल हैं -

  • Logging - आने वाले संदेशों को लॉग करें (किसी भी घातक त्रुटि के मामले में सहायक),

  • Security- उपयोगकर्ता नाम / आईपी पते के आधार पर, डेटाबेस, कुछ फ़ंक्शन कॉल, आदि तक पहुंच की अनुमति न दें। यह केवल अधिकृत ग्राहकों तक पहुंच प्रदान करने में मदद करता है।

  • Handle connections/disconnections अन्य प्रक्रियाओं से।

पूर्वनिर्धारित संदेश संचालकों

पूर्वनिर्धारित संदेश संचालकों में से कुछ नीचे चर्चा कर रहे हैं।

.z.pg

यह एक सिंक्रोनस मैसेज हैंडलर (प्रोसेस गेट) है। जब भी एक kdb + आवृत्ति पर एक सिंक संदेश प्राप्त होता है, तो यह फ़ंक्शन स्वचालित रूप से कहलाता है।

पैरामीटर निष्पादित होने के लिए स्ट्रिंग / फ़ंक्शन कॉल है, अर्थात, संदेश पारित हुआ। डिफ़ॉल्ट रूप से, इसे निम्नानुसार परिभाषित किया जाता है -

.z.pg: {value x}                / simply execute the message 
                                received but we can overwrite it to
give any customized result.
.z.pg : {handle::.z.w;value x}  / this will store the remote handle
.z.pg : {show .z.w;value x}     / this will show the remote handle

.z.ps

यह एक अतुल्यकालिक संदेश हैंडलर (प्रक्रिया सेट) है। यह एसिंक्रोनस संदेशों के लिए बराबर हैंडलर है। पैरामीटर निष्पादित करने के लिए स्ट्रिंग / फ़ंक्शन कॉल है। डिफ़ॉल्ट रूप से, इसे,

.z.pg : {value x}        / Can be overriden for a customized action.

अतुल्यकालिक संदेशों के लिए अनुकूलित संदेश हैंडलर निम्नलिखित है, जहां हमने संरक्षित निष्पादन का उपयोग किया है,

.z.pg: {@[value; x; errhandler x]}

यहाँ errhandler किसी भी अप्रत्याशित त्रुटि के मामले में उपयोग किया जाने वाला एक फ़ंक्शन है।

.z.po []

यह एक कनेक्शन ओपन हैंडलर (प्रोसेस-ओपन) है। यह निष्पादित किया जाता है जब एक दूरस्थ प्रक्रिया एक कनेक्शन खोलती है। जब किसी प्रक्रिया का कनेक्शन खोला जाता है तो हैंडल को देखने के लिए, हम .z.po को इस प्रकार परिभाषित कर सकते हैं,

.z.po : {Show “Connection opened by” , string h: .z.h}

.z.pc []

यह एक करीबी कनेक्शन हैंडलर (प्रक्रिया-करीबी) है। कनेक्शन बंद होने पर इसे कहा जाता है। हम अपने स्वयं के करीबी हैंडलर बना सकते हैं जो वैश्विक कनेक्शन हैंडल को 0 पर रीसेट कर सकते हैं और टाइमर को हर 3 सेकंड (3000 मिलीसेकंड) में आग लगाने (निष्पादित) करने के लिए एक कमांड जारी कर सकते हैं।

.z.pc : { h::0; value “\\t 3000”}

टाइमर हैंडलर (.z.ts) कनेक्शन को फिर से खोलने का प्रयास करता है। सफलता मिलने पर, यह टाइमर को बंद कर देता है।

.z.ts : { h:: hopen `::5001; if [h>0; value “\\t 0”] }

.z.pi []

PI प्रक्रिया इनपुट के लिए है। इसे किसी भी प्रकार के इनपुट के लिए कहा जाता है। इसका उपयोग कंसोल इनपुट या रिमोट क्लाइंट इनपुट को संभालने के लिए किया जा सकता है। .Z.pi [] का उपयोग करके, कोई कंसोल इनपुट को मान्य कर सकता है या डिफ़ॉल्ट डिस्प्ले को बदल सकता है। इसके अलावा, इसका उपयोग किसी भी प्रकार के लॉगिंग ऑपरेशन के लिए किया जा सकता है।

q).z.pi
'.z.pi

q).z.pi:{">", .Q.s value x}

q)5+4
>9

q)30+42
>72

q)30*2
>60

q)\x .z.pi
>q)

q)5+4
9

.z.pw

यह एक सत्यापन कनेक्शन हैंडलर (उपयोगकर्ता प्रमाणीकरण) है। यह एक अतिरिक्त कॉलबैक जोड़ता है जब एक कनेक्शन को kdb + सत्र में खोला जा रहा है। इसे -u / -U चेक और .z.po (पोर्ट ओपन) से पहले कहा जाता है।

.z.pw : {[user_id;passwd] 1b}

इनपुट्स हैं userid (प्रतीक) और password (पाठ)।

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

गुण के प्रकार

क्रमबद्ध (`s #)

`s # का अर्थ है कि सूची को बढ़ते क्रम में क्रमबद्ध किया गया है। यदि कोई सूची स्पष्ट रूप से asc (या xasc) द्वारा छांटी जाती है, तो सूची में स्वचालित रूप से सॉर्ट किया गया विशेषता सेट होगा।

q)L1: asc 40 30 20 50 9 4

q)L1
`s#4 9 20 30 40 50

एक सूची जिसे क्रमबद्ध करने के लिए जाना जाता है, उसमें विशेषता भी स्पष्ट रूप से सेट की जा सकती है। Q जाँच करेगा कि क्या सूची क्रमबद्ध है, और यदि नहीं, तो s-fail त्रुटि डाली जाएगी।

q)L2:30 40 24 30 2

q)`s#L2
's-fail

सॉर्ट की गई विशेषता एक अनसेंडेड ऐपेंड पर खो जाएगी।

जुदा (`पी #)

`पी # का मतलब है कि सूची में विभाजन किया गया है और समान वस्तुओं को संचित रूप से संग्रहीत किया जाता है।

रेंज ए है int या temporal type एक अंतर्निहित int मान होना, जैसे कि साल, महीने, दिन, आदि। आप एक प्रतीक पर विभाजन भी कर सकते हैं, बशर्ते कि वह एनुमरेटेड हो।

विभाजित विशेषता को लागू करने से एक इंडेक्स शब्दकोश बनता है जो प्रत्येक अद्वितीय आउटपुट मान को उसकी पहली घटना की स्थिति में मैप करता है। जब एक सूची का विभाजन किया जाता है, तो लुकअप बहुत तेज होता है, क्योंकि रैखिक खोज को हैशटेबल लुकअप द्वारा बदल दिया जाता है।

q)L:`p# 99 88 77 1 2 3

q)L
`p#99 88 77 1 2 3

q)L,:3

q)L
99 88 77 1 2 3 3

Note −

  • सूची में एक ऑपरेशन के तहत बिदाई विशेषता संरक्षित नहीं है, भले ही ऑपरेशन विभाजन को संरक्षित करता है।

  • विभाजन की विशेषता पर विचार किया जाना चाहिए जब संस्थाओं की संख्या एक अरब तक पहुंचती है और अधिकांश विभाजन पर्याप्त आकार के होते हैं, अर्थात, महत्वपूर्ण पुनरावृत्ति होती है।

समूहीकृत (`जी #)

`जी # का मतलब सूची समूहीकृत है। एक आंतरिक शब्दकोश बनाया और बनाए रखा जाता है, जो अपने प्रत्येक सूचकांक के लिए प्रत्येक अद्वितीय आइटम को मैप करता है, जिसमें काफी भंडारण स्थान की आवश्यकता होती है। लंबाई की सूची के लिएL युक्त u आकार के अद्वितीय आइटम s, यह होगा (L × 4) + (u × s) बाइट्स।

ग्रुपिंग को एक सूची में लागू किया जा सकता है जब इसकी संरचना के बारे में कोई अन्य धारणा नहीं बनाई जा सकती है।

विशेषता को किसी भी टाइप की गई सूचियों पर लागू किया जा सकता है। यह एपेंड पर बना रहता है, लेकिन डिलीट होने पर खो जाता है।

q)L: `g# 1 2 3 4 5 4 2 3 1 4 5 6

q)L
`g#1 2 3 4 5 4 2 3 1 4 5 6

q)L,:9

q)L
`g#1 2 3 4 5 4 2 3 1 4 5 6 9

q)L _:2

q)L
1 2 4 5 4 2 3 1 4 5 6 9

अनोखा (`#u)

एक सूची में अद्वितीय विशेषता (`यू #) को लागू करना इंगित करता है कि सूची के आइटम अलग हैं। यह जानते हुए कि सूची के तत्व अद्वितीय रूप से नाटकीय रूप से गतिमान हैंdistinct और अनुमति देता है q कुछ तुलनाओं को जल्दी निष्पादित करने के लिए।

जब किसी सूची को अद्वितीय के रूप में चिह्नित किया जाता है, तो सूची में प्रत्येक आइटम के लिए एक आंतरिक हैश मानचित्र बनाया जाता है। सूची में संचालन विशिष्टता को संरक्षित करना चाहिए या विशेषता खो जाती है।

q)LU:`u#`MSFT`SAMSUNG`APPLE

q)LU
`u#`MSFT`SAMSUNG`APPLE

q)LU,:`IBM                        /Uniqueness preserved

q)LU
`u#`MSFT`SAMSUNG`APPLE`IBM

q)LU,:`SAMSUNG                    / Attribute lost

q)LU
`MSFT`SAMSUNG`APPLE`IBM`SAMSUNG

Note −

  • `यू # को संघनन पर संरक्षित किया जाता है जो विशिष्टता को संरक्षित करता है। यह विलोपन और गैर-अद्वितीय संगति पर खो जाता है।

  • `यू # सूचियों पर खोज एक हैश फ़ंक्शन के माध्यम से की जाती है।

विशेषताएँ निकालना

`# लागू करके विशेषताओं को हटाया जा सकता है।

गुण लगाना

विशेषताएँ लागू करने के लिए तीन प्रारूप हैं -

  • L: `s# 14 2 3 3 9/ सूची निर्माण के दौरान निर्दिष्ट करें

  • @[ `.; `L ; `s#]/ कार्यात्मक लागू, यानी चर सूची L के लिए

    / डिफ़ॉल्ट नाम स्थान में (यानी `।) लागू होते हैं

    / क्रमबद्ध `s # विशेषता

  • Update `s#time from `tab

    / लागू करने के लिए तालिका (टैब) अपडेट करें

    / विशेषता।

आइए उपरोक्त तीन विभिन्न स्वरूपों को उदाहरणों के साथ लागू करें।

q)/ set the attribute during creation

q)L:`s# 3 4 9 10 23 84 90

q)/apply the attribute to existing list data

q)L1: 9 18 27 36 42 54

q)@[`.;`L1;`s#]
`.

q)L1                 / check
`s#9 18 27 36 42 54

q)@[`.;`L1;`#]       / clear attribute
`.

q)L1
9 18 27 36 42 54

q)/update a table to apply the attribute

q)t: ([] sym:`ibm`msft`samsung; mcap:9000 18000 27000)

q)t:([]time:09:00 09:30 10:00t;sym:`ibm`msft`samsung; mcap:9000 18000 27000)

q)t

    time         sym    mcap
---------------------------------
  09:00:00.000   ibm    9000
  09:30:00.000   msft   18000
  10:00:00.000  samsung 27000

q)update `s#time from `t
`t

q)meta t               / check it was applied

    c  | t f a
------ | -----
  time | t s
  sym  | s
  mcap | j
  
Above we can see that the attribute column in meta table results shows the time column is sorted (`s#).

कार्यात्मक (डायनामिक) क्वेरीज़ कॉलम के नामों को विशिष्ट 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

इस अध्याय में, हम सीखेंगे कि शब्दकोशों और फिर तालिकाओं पर कैसे काम किया जाए। आइए शब्दकोशों के साथ शुरू करते हैं -

q)d:`u`v`x`y`z! 9 18 27 36 45                  / Creating a dictionary d

q)/ key of this dictionary (d) is given by

q)key d
`u`v`x`y`z

q)/and the value by

q)value d
9 18 27 36 45

q)/a specific value

q)d`x
27

q)d[`x]
27

q)/values can be manipulated by using the arithmetic operator +-*% as,

q)45 + d[`x`y]
72 81

यदि किसी को शब्दकोश मूल्यों में संशोधन करने की आवश्यकता है, तो संशोधन का प्रारूप हो सकता है -

q)@[`d;`z;*;9]
`d

q)d

u | 9
v | 18
x | 27
y | 36

q)/Example, table tab

q)tab:([]sym:`;time:0#0nt;price:0n;size:0N)

q)n:10;sym:`IBM`SAMSUNG`APPLE`MSFT

q)insert[`tab;(n?sym;("t"$.z.Z);n?100.0;n?100)]
0 1 2 3 4 5 6 7 8 9

q)`time xasc `tab
`tab

q)/ to get particular column from table tab

q)tab[`size]
12 10 1 90 73 90 43 90 84 63

q)tab[`size]+9
21 19 10 99 82 99 52 99 93 72

z | 405

q)/Example table tab

q)tab:([]sym:`;time:0#0nt;price:0n;size:0N)

q)n:10;sym:`IBM`SAMSUNG`APPLE`MSFT

q)insert[`tab;(n?sym;("t"$.z.Z);n?100.0;n?100)] 0 1 2 3 4 5 6 7 8 9 q)`time xasc `tab `tab q)/ to get particular column from table tab q)tab[`size] 12 10 1 90 73 90 43 90 84 63 q)tab[`size]+9 21 19 10 99 82 99 52 99 93 72 q)/Example table tab q)tab:([]sym:`;time:0#0nt;price:0n;size:0N) q)n:10;sym:`IBM`SAMSUNG`APPLE`MSFT q)insert[`tab;(n?sym;("t"$.z.Z);n?100.0;n?100)]
0 1 2 3 4 5 6 7 8 9

q)`time xasc `tab
`tab

q)/ to get particular column from table tab

q)tab[`size]
12 10 1 90 73 90 43 90 84 63

q)tab[`size]+9
21 19 10 99 82 99 52 99 93 72

q)/We can also use the @ amend too

q)@[tab;`price;-;2]

   sym      time           price     size
--------------------------------------------
  APPLE   11:16:39.779   6.388858     12
  MSFT    11:16:39.779   17.59907     10
  IBM     11:16:39.779   35.5638      1
 SAMSUNG  11:16:39.779   59.37452     90
  APPLE   11:16:39.779   50.94808     73
 SAMSUNG  11:16:39.779   67.16099     90
  APPLE   11:16:39.779   20.96615     43
 SAMSUNG  11:16:39.779   67.19531     90
  IBM     11:16:39.779   45.07883     84
  IBM     11:16:39.779   61.46716     63

q)/if the table is keyed

q)tab1:`sym xkey tab[0 1 2 3 4]

q)tab1

   sym    |   time          price     size
--------- | ----------------------------------
  APPLE   | 11:16:39.779   8.388858    12
  MSFT    | 11:16:39.779   19.59907    10
  IBM     | 11:16:39.779   37.5638     1
 SAMSUNG  | 11:16:39.779   61.37452    90
  APPLE   | 11:16:39.779   52.94808    73

q)/To work on specific column, try this

q){tab1[x]`size} each sym
1 90 12 10

q)(0!tab1)`size
12 10 1 90 73

q)/once we got unkeyed table, manipulation is easy

q)2+ (0!tab1)`size
14 12 3 92 75

आपकी हार्ड डिस्क (जिसे ऐतिहासिक डेटाबेस भी कहा जाता है) पर डेटा को तीन अलग-अलग स्वरूपों में सहेजा जा सकता है - फ्लैट फाइलें, सेप्लेबल टेबल्स और पार्टिशन किए गए टेबल। यहां हम सीखेंगे कि डेटा को बचाने के लिए इन तीन प्रारूपों का उपयोग कैसे करें।

सपाट फ़ाइल

फ्लैट फ़ाइलों को पूरी तरह से मेमोरी में लोड किया जाता है यही कारण है कि उनका आकार (मेमोरी फ़ुटप्रिंट) छोटा होना चाहिए। तालिकाओं को डिस्क पर पूरी तरह से एक फ़ाइल में सहेजा जाता है (इसलिए आकार मायने रखता है)।

इन तालिकाओं में हेरफेर करने के लिए उपयोग किए जाने वाले कार्य हैं set/get -

`:path_to_file/filename set tablename

आइए एक उदाहरण लें कि यह कैसे प्रदर्शित होता है -

q)tables `.
`s#`t`tab`tab1 

q)`:c:/q/w32/tab1_test set tab1
`:c:/q/w32/tab1_test

विंडोज वातावरण में, फ्लैट फ़ाइलों को स्थान पर सहेजा जाता है - C:\q\w32

अपनी डिस्क (ऐतिहासिक डीबी) से फ्लैट फ़ाइल प्राप्त करें और उपयोग करें get आदेश निम्नानुसार है -

q)tab2: get `:c:/q/w32/tab1_test

q)tab2

   sym    |   time           price   size
--------- | -------------------------------
  APPLE   | 11:16:39.779   8.388858   12
  MSFT    | 11:16:39.779   19.59907   10
  IBM     | 11:16:39.779   37.5638    1
 SAMSUNG  | 11:16:39.779   61.37452   90
  APPLE   | 11:16:39.779   52.94808   73

एक नई तालिका बनाई गई है tab2 में संग्रहीत सामग्री के साथ tab1_test फ़ाइल।

Splayed टेबल्स

यदि किसी तालिका में बहुत अधिक कॉलम हैं, तो हम इस तरह के तालिकाओं को splayed प्रारूप में संग्रहीत करते हैं, अर्थात, हम उन्हें एक निर्देशिका में डिस्क पर सहेजते हैं। निर्देशिका के अंदर, प्रत्येक स्तंभ को स्तंभ नाम के समान नाम के तहत एक अलग फ़ाइल में सहेजा जाता है। प्रत्येक कॉलम को kdb + बाइनरी फ़ाइल में संबंधित प्रकार की सूची के रूप में सहेजा जाता है।

जब हमारे कई कॉलमों में से केवल कुछ कॉलमों को ही एक्सेस करना होता है, तो टेबल को स्पलैड फॉर्मेट में सेव करना बहुत उपयोगी होता है। एक splayed तालिका निर्देशिका में है.d बाइनरी फ़ाइल जिसमें कॉलम का क्रम होता है।

एक सपाट फ़ाइल की तरह, एक तालिका का उपयोग करके छप के रूप में बचाया जा सकता है setआदेश। एक तालिका को छंटनी के रूप में सहेजने के लिए, फ़ाइल पथ बैकलैश के साथ समाप्त होना चाहिए -

`:path_to_filename/filename/ set tablename

एक splayed तालिका पढ़ने के लिए, हम उपयोग कर सकते हैं get कार्य -

tablename: get `:path_to_file/filename

Note - एक मेज के रूप में बचाया जा करने के लिए, यह बिना चाबी के और enumerated होना चाहिए।

विंडोज वातावरण में, आपकी फ़ाइल संरचना निम्नानुसार दिखाई देगी -

विभाजन सारणी

विभाजन सारणी डेटा के महत्वपूर्ण संस्करणों वाली विशाल तालिकाओं के प्रबंधन के लिए एक कुशल साधन प्रदान करती है। विभाजन सारणी अधिक विभाजन (निर्देशिका) में फैली हुई टेबल्स हैं।

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

विभाजन तालिका की सामग्री प्राप्त करने के लिए, निम्नलिखित कोड ब्लॉक का उपयोग करें -

q)get `:c:/q/data/2000.01.13              // “get” command used, sample folder

quote| +`sym`time`bid`ask`bsize`asize`ex!(`p#`sym!0 0 0 0 0 0 0 0 0 0 0
0 0 0….

trade| +`sym`time`price`size`ex!(`p#`sym!0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 ….

आइए एक व्यापार तालिका की सामग्री प्राप्त करने का प्रयास करें -

q)get `:c:/q/data/2000.01.13/trade

   sym    time            price     size    ex
--------------------------------------------------
    0   09:30:00.496    0.4092016    7      T
    0   09:30:00.501    1.428629     4      N
    0   09:30:00.707    0.5647834    6      T
    0   09:30:00.781    1.590509     5      T
    0   09:30:00.848    2.242627     3      A
    0   09:30:00.860    2.277041     8      T
    0   09:30:00.931    0.8044885    8      A
    0   09:30:01.197    1.344031     2      A
    0   09:30:01.337    1.875        3      A
    0   09:30:01.399    2.187723     7      A

Note - विभाजित मोड प्रति दिन लाखों रिकॉर्ड के साथ तालिकाओं के लिए उपयुक्त है (अर्थात समय श्रृंखला डेटा)

सिम फ़ाइल

सिम्पट फाइल एक kdb + बाइनरी फाइल होती है जिसमें सभी स्पलैड और पार्टीशन टेबल से प्रतीकों की सूची होती है। इसके साथ पढ़ा जा सकता है,

get `:sym

par.txt फ़ाइल (वैकल्पिक)

यह एक कॉन्फ़िगरेशन फ़ाइल है, जिसका उपयोग कई निर्देशिकाओं / डिस्क ड्राइव पर विभाजन के फैलने पर किया जाता है और डिस्क विभाजन में पथ समाहित करता है।

.Q.en

.Q.enएक डाइएडिक फ़ंक्शन है जो एक प्रतीक स्तंभ की गणना करके तालिका को विभाजित करने में मदद करता है। यह विशेष रूप से तब उपयोगी होता है जब हम ऐतिहासिक db (स्पलैड, पार्टीशन टेबल आदि) के साथ काम कर रहे होते हैं। -

.Q.en[`:directory;table]

कहाँ पे directory ऐतिहासिक डेटाबेस का घर निर्देशिका है sym file स्थित है और table गणना की जाने वाली तालिका है।

टेबल की मैन्युअल गणना के लिए उन्हें स्पलैड टेबल के रूप में सहेजने की आवश्यकता नहीं है, क्योंकि यह इसके द्वारा किया जाएगा -

.Q.en[`:directory_where_symbol_file_stored]table_name

.Q.dpft

.Q.dpftकार्य विभाजन और खंडित तालिकाओं को बनाने में मदद करता है। इसका उन्नत रूप है.Q.en, क्योंकि यह न केवल तालिका को विभाजित करता है, बल्कि एक विभाजन तालिका भी बनाता है।

इसमें इस्तेमाल किए गए चार तर्क दिए गए हैं .Q.dpft -

  • डेटाबेस का प्रतीकात्मक फ़ाइल संभाल जहां हम एक विभाजन बनाना चाहते हैं,

  • q डेटा मान जिसके साथ हम तालिका को विभाजित करने जा रहे हैं,

  • उस फ़ील्ड का नाम, जिसके साथ भागीदारी (`p #) विशेषता लागू होने जा रही है (आमतौर पर` सिम्फ), और

  • तालिका का नाम।

आइए एक उदाहरण लें कि यह कैसे काम करता है -

q)tab:([]sym:5?`msft`hsbc`samsung`ibm;time:5?(09:30:30);price:5?30.25)

q).Q.dpft[`:c:/q/;2014.08.24;`sym;`tab]
`tab

q)delete tab from `
'type

q)delete tab from `/
'type

q)delete tab from .
'type

q)delete tab from `.
`.

q)tab
'tab

हमने मेज हटा दी है tabस्मृति से। अब इसे db से लोड करते हैं

q)\l c:/q/2014.08.24/

q)\a
,`tab

q)tab

   sym      time      price
-------------------------------
  hsbc    07:38:13   15.64201
  hsbc    07:21:05   5.387037
  msft    06:16:58   11.88076
  msft    08:09:26   12.30159
 samsung  04:57:56   15.60838

.Q.chk

.Q.chk एक मोनोडिक फ़ंक्शन है जिसका एकल पैरामीटर रूट डायरेक्टरी का सांकेतिक फ़ाइल हैंडल है। यह विभाजन में खाली टेबल बनाता है, जहां भी आवश्यक हो, रूट में प्रत्येक विभाजन उपनिर्देशिका की जांच करके।

.Q.chk `:directory

कहाँ पे directory ऐतिहासिक डेटाबेस की होम डायरेक्टरी है।