Реляциялық алгебра - Relational algebra

Жылы мәліметтер қорының теориясы, реляциялық алгебра қолданатын теория болып табылады алгебралық құрылымдар а негізделген семантика деректерді модельдеуге және олар бойынша сұраныстарды анықтауға арналған. Теория енгізген Эдгар Ф. Кодд.

Реляциялық алгебраның негізгі қолданылуы теориялық негіз қалау болып табылады реляциялық мәліметтер базасы, атап айтқанда сұрау тілдері осындай мәліметтер базасы үшін, олардың ішінде бастысы SQL. Реляциялық мәліметтер қоры кесте түрінде көрсетілген деректерді сақтайды қарым-қатынастар. Реляциялық мәліметтер қорына қатысты сұраулар көбінесе кесте түрінде көрсетілген деректерді қайтарады қарым-қатынастар. Реляциялық алгебраның негізгі алғышарты - бір немесе бірнеше кіріс қатынастарын шығыс қатынасқа түрлендіретін операторларды анықтау. Бұл операторлар қатынастарды кіріс ретінде қабылдап, қатынастарды нәтиже ретінде шығаратындығын ескере отырып, оларды біріктіруге болады және көптеген кіріс қатынастарын (олардың дерекқорында сақталатын) бір қатынасқа айналдыратын әлеуетті күрделі сұраныстарды қолдануға болады (сұрау нәтижелері) . Бірыңғай операторлар кіріс ретінде бір қатынасты қабылдайды; мысалдарға белгілі бір атрибуттарды (бағандарды) немесе кортеждерді (жолдарды) енгізу қатынасынан сүзуге арналған операторлар жатады. Екілік операторлар кіріс ретінде екі қатынасты қабылдайды; мұндай операторлар екі кірістегі қатынастарды бір шығыс қатынасқа біріктіреді, мысалы, екі қатынаста кездесетін барлық кортеждерді алып, екінші қатынастан табылған бірінші қатынастан кортеждерді алып тастап, бірінші қатынастың кортеждерін екінші қатынасқа шығарады. белгілі бір шарттарға сәйкес келу және т.б. Сондай-ақ басқа операторларды қосуға болады, мұнда белгілі бір операторларды қосу немесе алып тастау алгебралар отбасын тудырады.

Кіріспе

Реляциялық алгебра таза математикадан тыс жарық көргенге дейін аз көңіл бөлді Э.Ф.Кодд Келіңіздер мәліметтердің реляциялық моделі 1970 ж. Кодд осындай алгебраны мәліметтер базасының сұраныстар тілдеріне негіз ретінде ұсынды. (Бөлімді қараңыз) Іске асыру.)

Кодд алгебрасының бес қарабайыр операторы болып табылады таңдау, болжам, Декарттық өнім (деп те аталады кросс өнім немесе айқасу), одақ құрды, және айырмашылықты орнатыңыз.

Операторларды орнатыңыз

Реляциялық алгебра қолданады одақ құрды, айырмашылықты орнатыңыз, және Декарттық өнім бастап жиынтық теориясы, бірақ осы операторларға қосымша шектеулер қосады.

Орнатылған одақ пен жиынтық айырмашылығы үшін екеуі қарым-қатынастар қатысуы керек кәсіптік үйлесімді- яғни екі қатынастың атрибуттарының жиынтығы болуы керек. Себебі қиылысты орнатыңыз белгіленген одақ және жиынтық айырмашылық тұрғысынан анықталады, жиынтық қиылысқа қатысатын екі қатынас сонымен қатар одаққа үйлесімді болуы керек.

Декарттық өнімнің анықталуы үшін екі қатынастың біріккен тақырыптары болуы керек, яғни олардың жалпы атрибут атауы болмауы керек.

Сонымен қатар, декарттық өнім in-мен салыстырғанда басқаша анықталады орнатылды кортеждер операция мақсаттары үшін «таяз» болып саналады деген мағынадағы теория. Яғни, жиынтықтың декарттық көбейтіндісі n- жиынтығы бар буындар м-жұптар «тегістелген» жиынтығын береді (n + м)-tuples (алайда негізгі жиынтық теориясы әрқайсысында an бар 2 кортеж жиынтығын тағайындаған болар еді n-tuple және an м-тупле). Ресми түрде, R × S келесідей анықталады:

Декарттық өнімнің кардиналдылығы деп оның факторларының кардиналының көбейтіндісін айтады, яғни |R × S| = |R| × |S|.

Болжам (Π)

A болжам Бұл бірыңғай операция ретінде жазылған қайда атрибут атауларының жиынтығы болып табылады. Мұндай проекцияның нәтижесі ретінде анықталады орнатылды бұл барлық кезде алынған кортеждер жылы R жиынтығымен шектелген .

Ескерту: іске асырылған кезде SQL стандартты «әдепкі проекция» а қайтарады мультисет жиынтықтың орнына және Π қайталанатын деректерді жоюға арналған проекцияны. қосу арқылы алады БІЛУ кілт сөз.

Таңдау (σ)

A жалпыланған таңдау Бұл бірыңғай операция ретінде жазылған қайда φ Бұл ұсыныстық формула тұрады атомдар рұқсат етілгендей қалыпты таңдау және логикалық операторлар (және ), (немесе ) және (жоққа шығару ). Бұл таңдау олардың барлығын таңдайды кортеждер жылы R ол үшін φ ұстайды.

Мекен-жай кітабындағы барлық достардың немесе серіктестердің тізімін алу үшін таңдау келесі түрде жазылуы мүмкін . Нәтижесінде барлық бірегей жазбалардың барлық атрибуттарын қамтитын қатынас болады isF Friend шын немесе қайда isBusinessContact шындық

Атауын өзгерту (ρ)

A атауын өзгерту Бұл бірыңғай операция ретінде жазылған мұндағы нәтиже бірдей R қоспағанда б барлық кортеждердегі атрибут an деп өзгертілді а атрибут. Бұл жай атрибутының атауын өзгерту үшін қолданылады қатынас немесе қатынастың өзі.

«IsFriend» атрибутының атын «isBusinessContact» қатынасқа өзгерту үшін, қолданылуы мүмкін.

Қосылу және біріктіру сияқты операторлар

Табиғи қосылу ()

Табиғи қосылыс (⋈) - бұл екілік оператор деп жазылған (RS) қайда R және S болып табылады қарым-қатынастар.[1] Табиғи қосылудың нәтижесі - бұл кортеждердің барлық тіркесімдерінің жиынтығы R және S жалпы атрибуттық атауларына тең. Мысал үшін кестелерді қарастырайық Қызметкер және Бөлім және олардың табиғи қосылыстары:

Нәтижесінде Мэри есімді қызметкер де, өндірістік бөлім де көрінбейтінін ескеріңіз.

Мұны анықтау үшін де қолдануға болады қатынастардың құрамы. Мысалы, Қызметкер және Бөлім бұл жоғарыда көрсетілгендей, жалпы атрибуттан басқаларының бәрінде болжанған олардың қосылысы DeptName. Жылы категория теориясы, қосылу дәл болып табылады талшық өнімі.

Табиғи қосылыс маңызды операторлардың бірі болып табылады, өйткені ол логикалық AND операторының реляциялық аналогы болып табылады. ЖӘНЕ-мен байланысқан екі предикаттың әрқайсысында бірдей айнымалы пайда болса, онда бұл айнымалы бірдей затты білдіреді және екі көрініс әрқашан бірдей мәнмен алмастырылуы керек (бұл икемсіздік логикалық ЖӘНЕ). Атап айтқанда, табиғи қосылу а байланыстыратын қатынастардың үйлесуіне мүмкіндік береді шетелдік кілт. Мысалы, жоғарыдағы мысалда шетелдік кілт болуы мүмкін Қызметкер.DeptName дейін Бөлім.DeptName содан кейін табиғи қосылу Қызметкер және Бөлім барлық қызметкерлерді өздерінің бөлімшелерімен біріктіреді. Бұл жұмыс істейді, өйткені шетелдік кілт аттас атрибуттар арасында болады. Егер бұл шетелдік кілт сияқты болмаса Бөлім.Менеджер дейін Қызметкер.Аты-жөні онда біз табиғи қосылысты бастамас бұрын осы бағандардың атын өзгертуіміз керек. Мұндай қосылысты кейде ан деп те атайды equijoin (қараңыз θ-қосылыңыз).

Табиғи қосылыстың семантикасы ресми түрде келесідей анықталады:

 

 

 

 

(1)

қайда Көңілді (t) Бұл предикат бұл а қатынас т (математикалық мағынада) iff т функция болып табылады. Әдетте бұл талап етіледі R және S кем дегенде бір жалпы төлсипатқа ие болуы керек, бірақ егер бұл шектеу алынып тасталса және R және S жалпы атрибуттары жоқ болса, онда табиғи қосылыс декарттық өнімге айналады.

Табиғи қосылысты Кодд примитивтерімен келесідей модельдеуге болады. Мұны ойлаңыз c1,...,cм жалпы атрибут атаулары болып табылады R және S, р1,...,рn ерекше атрибуттар R және с1,...,ск ерекше атрибуттар S. Сонымен, атрибут атаулары деп ойлаңыз х1,...,хм жоқ R не S. Бірінші қадамда біз енді жалпы атрибут атауларын қайта атауымызға болады S:

 

 

 

 

(2)

Содан кейін декарттық өнімді аламыз және біріктірілетін кортеждерді таңдаймыз:

 

 

 

 

(3)

Соңында біз қайта атрибуттардан құтылу үшін проекция аламыз:

 

 

 

 

(4)

θ-қосылу және қосылу

Кестелерді қарастырыңыз Автокөлік және Қайық онда автомобильдер мен қайықтардың модельдері және олардың бағалары келтірілген. Клиент автокөлік пен қайық алғысы келеді делік, бірақ ол қайыққа машинадан гөрі көп ақша жұмсағысы келмейді. The θ-қосылу (⋈θ) предикат бойынша CarPriceBoatPrice предикатты қанағаттандыратын тегістелген жұп қатарлар шығарады. Атрибуттар тең болатын шартты қолданған кезде, мысалы, баға, онда шарт ретінде көрсетілуі мүмкін Бағасы=Бағасынемесе балама (Бағасы) өзі.

Егер біз үйлесімділік шарты тек ортақ атрибуттардың теңдігі емес екі қатынастың кортеждерін біріктіргіміз келсе, онда біріктіру операторының неғұрлым жалпы формасы болған ыңғайлы, бұл θ-қосылу (немесе тета-қосылу). The θ-қосу ретінде жазылатын екілік оператор немесе қайда а және б атрибут атаулары, θ екілік болып табылады реляциялық оператор жиынтықта {<, ≤, =, ≠, >, ≥}, υ мәні тұрақты болып табылады және R және S қатынастар болып табылады. Бұл операцияның нәтижесі in-дегі барлық тіркесімдерден тұрады R және S бұл қанағаттандырады θ. Нәтижесі θ-қосу тек егер тақырыптары болса ғана анықталады S және R бөлінеді, яғни жалпы атрибутты қамтымайды.

Бұл операцияның негізгі операциялардағы модельдеуі келесідей:

Rθ S = σθ(R × S)

Егер оператор болса θ теңдік операторы (=) болса, онда бұл қосылыс ан деп аталады equijoin.

Алайда, табиғи қосылу және таңдау операторларын қолдайтын компьютер тілі қажет еместігін ескеріңіз θ- сонымен қатар қосылыңыз, өйткені бұны табиғи қосылыстың нәтижесінен таңдау арқылы алуға болады (ол ортақ атрибуттар болмаған кезде декарттық өнімге азаяды).

SQL ендірулерінде предикатқа қосылуды әдетте an деп атайды ішкі қосылыс, және қосулы кілт сөз жолдарды сүзуге қолданылатын предикатты көрсетуге мүмкіндік береді. Айта кету керек: тегістелген декарттық өнімді қалыптастыру, содан кейін жолдарды сүзу тұжырымдамалық тұрғыдан дұрыс, бірақ іске қосылу сұранысын жеделдету үшін неғұрлым жетілдірілген деректер құрылымдарын қолданады.

Semijoin (⋉)(⋊)

Сол жақ семижоин - бұл табиғи қосылысқа ұқсас және осылай жазылған қосылыс RS қайда R және S болып табылады қарым-қатынастар.[2] Нәтижесінде барлық кортеждердің жиынтығы болады R ол үшін кортеж бар S бұл олардың жалпы төлсипат атауларына тең. Табиғи қосылыстың айырмашылығы мынада: S пайда болмайды. Мысалы, кестелерді қарастырайық Қызметкер және Бөлім және олардың қосылуы:

Жартылай қосылудың семантикасын ресми түрде келесідей анықтауға болады:

RS = { т : тR ∧ ∃сS(Көңілді (тс)) }

қайда Көңілді(р) табиғи қосылыстың анықтамасындағы сияқты.

Жартылай қосылысты табиғи қосылыстың көмегімен орындауға болады. Егер а1, ..., аn деген атрибуттар болып табылады R, содан кейін

RS = πа1,..,аn(RS).

Табиғи қосылуды негізгі операторлармен имитациялау мүмкін болғандықтан, бұл semijoin үшін де қажет.

Коддтың 1970 жылғы еңбегінде семижоин шектеу деп аталады.[3]

Антигоин (▷)

Ретінде жазылған антижоин RS қайда R және S болып табылады қарым-қатынастар, semijoin-ге ұқсас, бірақ антижоиннің нәтижесі тек сол кортеждер R ол үшін бар жоқ кортеж S бұл олардың жалпы төлсипат атауларына тең.[4]

Мысал үшін кестелерді қарастырайық Қызметкер және Бөлім және оларға қосылу:

Антигоин ресми түрде келесі түрде анықталады:

RS = { т : тR ∧ ¬∃сS(Көңілді (тс)) }

немесе

RS = { т : тR, кортеж жоқ с туралы S бұл қанағаттандырады Көңілді (тс) }

қайда Көңілді (тс) табиғи қосылыстың анықтамасындағы сияқты.

Антигоинді ретінде анықтауға болады толықтыру жартылай қосылыстың тізімі:

RS = R − RS

 

 

 

 

(5)

Осыны ескере отырып, антижоин кейде антисемиджоин деп аталады, ал антиджоин операторы кейде of орнына, үстінде жолағы бар семижоин символы түрінде жазылады.

Бөлім (÷)

Бөлу деп жазылатын екілік амал болып табылады R ÷ S. Бөлу тікелей SQL-де жүзеге асырылмайды. Нәтиже ішіндегі кортеждердің шектеулерінен тұрады R тек төлсипат атауларына R, яғни, тақырыбында R бірақ тақырыпта жоқ S, бұл үшін олардың барлық тіркесімдері кортеждермен біріктірілген S қатысады R. Мысал үшін кестелерді қараңыз Аяқталды, DBProject және оларды бөлу:

Егер DBProject Деректер қоры жобасының барлық тапсырмаларын қамтиды, содан кейін жоғарыдағы бөлудің нәтижелері Деректер қоры жобасындағы екі тапсырманы да орындаған студенттерден тұрады, формальды түрде бөлудің семантикасы келесідей анықталады:

R ÷ S = { т[а1,...,аn] : тR ∧ ∀сS ( (т[а1,...,аn] ∪ с) ∈ R) }

 

 

 

 

(6)

қайда {а1,...,аn} - тек өзіне ғана тән атрибут атауларының жиынтығы R және т[а1,...,аn] дегеніміз - шектеу т осы жиынтыққа. Әдетте атрибут аттарының тақырыбында болуы қажет S солардың жиынтығы R өйткені әйтпесе операцияның нәтижесі әрқашан бос болады.

Негізгі операциялармен бөлуді модельдеу келесідей. Біз мұны болжаймыз а1,...,аn тек төлсипат атаулары болып табылады R және б1,...,бм атрибуттары болып табылады S. Бірінші қадамда біз жобалаймыз R оның бірегей төлсипат атауларында және барлық тіркесімдерді курорттармен салыңыз S:

Т : = πа1,...,аn(R) × S

Алдыңғы мысалда, T кестені ұсынады, өйткені әр студент (ол Толтырылған кестенің ерекше кілт / атрибуты болғандықтан) әрбір берілген тапсырмамен біріктіріледі. Мысалы, Евгенийде екі қатар болады: Евгений → Деректер базасы1 және Евгений → Деректер базасы2.

Э.Г .: Алдымен, «Аяқталды» дегеннің «баға» деп аталатын үшінші атрибутына ие болып көрінейік. Бұл жерде қажет емес жүк, сондықтан біз оны әрдайым алып тастауымыз керек. Іс жүзінде бұл қадамда біз R-ден 'Task' тастай аламыз; көбейту оны қайтадан қояды.
Т : = πСтудент(R) × S // Бұл бізге кез-келген ықтимал комбинацияны, соның ішінде R-де жоқтығын және басқаларын қоспағанда береді (мысалы, Fred | компилятор1, бұл қажет тіркесім емес)

Келесі қадамда біз шегереміз R бастап Т

қатынас:

U := ТR

Жылы U бізде болуы мүмкін «мүмкін» комбинациялар бар R, бірақ болған жоқ.

ЭГ: Тағы да проекциялармен - Т және R бірдей атрибуттардың аттары / тақырыптары болуы керек.
U := Т - πСтудент, тапсырма(R) // Бұл бізге «не жетіспейтін» тізімді береді.

Сонымен, егер атрибут атауларына проекцияны тек ерекше деп алсақ R

онда бізде кортеждердің шектеулері бар R ол үшін кортеждермен біріктірілген комбинациялар жоқ S қатысқан R:

V : = πа1,...,аn(U)
EG: жоба U тек атрибутқа (қасиеттерге) дейін (Студент)
V : = πСтудент(U)

Сонымен, проекциясын қабылдау керек R оның ерекше атрибуттары бойынша және оларды алып тастаңыз V:

W : = πа1,...,аn(R) − V
ЭГ: W : = πСтудент(R) − V.

Жалпы кеңейтулер

Іс жүзінде жоғарыда сипатталған классикалық реляциялық алгебра сыртқы қосылыстар, агрегаттық функциялар және транзиттік жабылу сияқты әр түрлі операциялармен кеңейтіледі.[5]

Сыртқы қосылады

Қосылудың (немесе ішкі қосылыстың) нәтижесі екі операндтағы сәйкес кортеждерді біріктіру нәтижесінде пайда болған кортеждерден құралған болса, сыртқы біріктіруге сол кортеждер және қосымша операндалардың біріне теңестірілмеген кортежді «толтыру» мәндерімен кеңейту арқылы құрылған кейбір кортеждер кіреді. басқа операнд атрибуттарының әрқайсысы үшін. Сыртқы қосылыстар осы уақытқа дейін талқыланған классикалық реляциялық алгебраның бөлігі болып саналмайды.[6]

Осы бөлімде анықталған операторлар а-ның болуын болжайды нөл мәні, ω, біз анықтамаймыз, толтыру мәндері үшін қолдану керек; іс жүзінде бұл сәйкес келеді ЖОҚ SQL-де. Алынған кестедегі келесі таңдау операцияларын мағыналы ету үшін нөлдерге мағыналық мағына беру керек; Кодд тәсілінде таңдау қолданатын пропорционалды логика болып табылады үш мәнді логикаға дейін кеңейтілген дегенмен, біз осы мақалада осы егжей-тегжейлерді қарастырамыз.

Үш сыртқы біріктіру операторы анықталды: сол жақ сыртқы қосылыс, оң жақ сыртқы қосылыс және толық сыртқы біріктіру. («Сыртқы» сөзі кейде алынып тасталады).

Сол жақтағы қосылыс (⟕)

Сол жақтағы қосылыс келесі түрінде жазылады RS қайда R және S болып табылады қарым-қатынастар.[7] Сол жақтағы қосылудың нәтижесі - бұл кортеждердің барлық тіркесімдерінің жиынтығы R және S жалпы атрибуттық атауларына тең, сонымен қатар (еркін түрде) R сәйкес келетін кортеждері жоқ S.

Мысал үшін кестелерді қарастырайық Қызметкер және Бөлім және олардың сол жақ сыртқы қосылыстары:

Алынған қатынаста кортеждер S кортеждері бар жалпы төлсипат атауларында ортақ мәндері жоқ R а нөл мәні, ω.

Кірістер жоқ болғандықтан Бөлім а DeptName туралы Қаржы немесе Атқарушы, ωs кортеждер пайда болатын қатынастарда пайда болады Қызметкер бар DeptName туралы Қаржы немесе Атқарушы.

Келіңіздер р1, р2, ..., рn қатынастың атрибуттары болу R және {(ω, ..., ω) атрибуттар бойынша жалғыз байланыс болуы керек бірегей қатынасқа S (атрибуттары болып табылмайтындар) R). Содан кейін сол жақтағы қосылысты табиғи қосылысқа қатысты сипаттауға болады (демек, негізгі операторларды қолдана отырып):

Оң жақ сыртқы қосылыс (⟖)

Оң жақ сыртқы қосылыс сол жақ сыртқы қосылумен бірдей дерлік әрекет етеді, бірақ кестелердің рөлдері ауысады.

Оң жақ сыртқы қосылысы қарым-қатынастар R және S ретінде жазылады RS.[8] Оң жақ сыртқы қосылыстың нәтижесі - бұл кортеждердің барлық тіркесімдерінің жиынтығы R және S ішіндегі кортеждерден басқа, олардың жалпы төлсипат атауларына тең S сәйкес келетін кортеждері жоқ R.

Мысалы, кестелерді қарастырайық Қызметкер және Бөлім және олардың сыртқы қосылыстары:

Алынған қатынаста кортеждер R кортеждері бар жалпы төлсипат атауларында ортақ мәндері жоқ S а нөл мәні, ω.

Кірістер жоқ болғандықтан Қызметкер а DeptName туралы Өндіріс, ωлар пайда болған қатынастың Name және EmpId атрибуттарында кездеседі, мұндағы кортеждер Бөлім болған DeptName туралы Өндіріс.

Келіңіздер с1, с2, ..., сn қатынастың атрибуттары болу S және {(ω, ..., ω) атрибуттар бойынша жалғыз байланыс болуы керек бірегей қатынасқа R (атрибуттары болып табылмайтындар) S). Содан кейін, сол жақ қосылыстағы сияқты, оң жақ сыртқы қосылысты табиғи қосылысты келесідей етіп модельдеуге болады:

Толық сыртқы қосылыс (⟗)

The сыртқы біріктіру немесе толық сыртқы қосылыс іс жүзінде сол және оң жақ сыртқы қосылыстардың нәтижелерін біріктіреді.

Толық сыртқы қосылыс ретінде жазылады RS қайда R және S болып табылады қарым-қатынастар.[9] Толық сыртқы қосылудың нәтижесі - бұл кортеждердің барлық тіркесімдерінің жиынтығы R және S ішіндегі кортеждерден басқа, олардың жалпы төлсипат атауларына тең S сәйкес келетін кортеждері жоқ R және кортеждер R сәйкес келетін кортеждері жоқ S олардың жалпы атрибуттық атауларында.

Мысал үшін кестелерді қарастырайық Қызметкер және Бөлім және олардың сыртқы қосылыстары:

Алынған қатынаста кортеждер R кортеждері бар жалпы төлсипат атауларында ортақ мәндері жоқ S а нөл мәні, ω. Кіреберістер S кортеждері бар жалпы төлсипат атауларында ортақ мәндері жоқ R сонымен қатар а нөл мәні, ω.

Толық сыртқы біріктіруді сол және оң жақ сыртқы қосылыстардың көмегімен модельдеуге болады (демек, табиғи қосылу және жиынтық біріктіру):

RS = (RS) ∪ (RS)

Домендік есептеулерге арналған операциялар

Реляциялық алгебрада деректер домендерінде есептеулер жүргізуге мүмкіндік беретін ештеңе жоқ (теңдікке қатысты пропозициялық өрнектерді бағалаудан басқа). Мысалы, екі бағандағы сандарды көбейтетін өрнек жазу үшін осы уақытқа дейін енгізілген алгебраны ғана қолдану мүмкін емес, мысалы. жалпы бағаны алу үшін саны бар бірлік бағасы. Сұраныстың практикалық тілдері осындай мүмкіндіктерге ие, мысалы. SQL SELECT арифметикалық операцияларға нәтижеде жаңа бағандарды анықтауға мүмкіндік береді ТАҢДАУ тауар өлшемінің бағасы * саны AS жалпы_баға КІМДЕН т, және ұқсас нысанды неғұрлым айқын қамтамасыз етілген Оқу құралы D Келіңіздер ҰЗАРТУ кілт сөз.[10] Деректер қоры теориясында бұл деп аталады кеңейтілген проекция.[11]:213

Жиынтық

Сонымен қатар, бағанға әртүрлі функцияларды есептеу, оның элементтерін қорытындылау сияқты, осы уақытқа дейін енгізілген реляциялық алгебраның көмегімен де мүмкін емес. Бесеуі бар жиынтық функциялар көптеген реляциялық мәліметтер қоры жүйелеріне енгізілген. Бұл операциялар - қосынды, санақ, орташа, максимум және минимум. Реляциялық алгебрада схема бойынша біріктіру әрекеті (A1, A2, ... An) келесідей жазылады:

қайда Aj', 1 ≤ jк, бастапқы атрибуттардың бірі болып табылады Aмен, 1 ≤ менn.

Алдыңғы атрибуттар ж SQL ішіндегі «топтастыру» сөйлемі сияқты жұмыс жасайтын атрибуттар. Содан кейін жеке атрибуттарға қолданылатын біріктіру функцияларының ерікті саны бар. Операция ерікті қатынасқа қолданылады р. Топтастырудың атрибуттары міндетті емес, егер олар жеткізілмеген болса, біріктіру функциялары операция қолданылатын барлық қатынасқа қолданылады.

Бізде кесте бар деп есептейік Тіркелгі үш бағанмен, атап айтқанда Есептік жазбаның нөмірі, филиалдың аты және Баланс. Әр филиалдың максималды балансын табуды қалаймыз. Мұны жүзеге асырады Тармақ_атыGМаксимум (Баланс)(Тіркелгі). Барлық шоттардың ең жоғары сальдосын филиалына қарамай табу үшін жай ғана жаза алдық GМаксимум (Баланс)(Тіркелгі).

Өтпелі жабу

Реляциялық алгебра практикалық мақсаттар үшін жеткілікті қуатты болып көрінгенімен, қарапайым және табиғи операторлар бар қарым-қатынастар оны реляциялық алгебра арқылы өрнектеуге болмайды. Солардың бірі өтпелі жабылу екілік қатынастың Домен берілген Д., екілік қатынасқа жол берейік R ішкі бөлігі болуы керек Д.×Д.. Өтпелі жабылу R+ туралы R ең кіші ішкі жиыны болып табылады Д.×Д. бар R және келесі шартты қанағаттандырады:

Реляциялық алгебра өрнегі жоқ E(R) қабылдау R шығаратын айнымалы аргумент ретінде R+. Мұны реляциялық өрнек келтіре отырып дәлелдеуге болады E ол үшін бұл талап етіледі E(R) = R+, қайда R айнымалы болып табылады, біз әрқашан дананы таба аламыз р туралы R (және тиісті домен г.) солай E(р) ≠ р+.[12]

SQL дегенмен бұларды ресми түрде қолдайды fixpoint сұраулары 1999 жылдан бастап және оның осы бағытта сатушыларға арналған кеңейтімдері болған.

Сұраныстарды оңтайландыру үшін алгебралық қасиеттерді қолдану

Сұрақтар ретінде ұсынылуы мүмкін ағаш, қайда

  • ішкі түйіндер - операторлар,
  • жапырақтары қарым-қатынастар,
  • кіші ағаштар қосалқы өрнектер болып табылады.

Біздің басты мақсатымыз - экспрессиялық ағаштарды эквивалентке айналдыру ағаштар, мұнда ағаштағы субэкспрессиялар арқылы туындайтын қатынастардың орташа мөлшері бұрынғыдан кішірек оңтайландыру. Біздің екінші мақсатымыз - бір сұрау шеңберінде жалпы субэкспрессия құруға тырысу, немесе егер бір уақытта бірнеше сұраныс бағаланса, сол сұраулардың барлығында. Екінші мақсаттың негізі мынада: жалпы субэкспрессияларды бір рет есептеу жеткілікті, ал нәтижелер осы субэкпрессияны қамтитын барлық сұрауларда қолданыла алады.

Мұнда біз осындай түрлендірулерде қолдануға болатын ережелер жиынтығын ұсынамыз.

Таңдау

Іріктеу операторлары туралы ережелер сұранысты оңтайландыруда маңызды рөл атқарады. Таңдау - бұл өз операндындағы жолдар санын өте тиімді түрде азайтатын оператор, сондықтан егер өрнек ағашындағы таңдауды жапыраққа қарай жылжытсақ, ішкі қарым-қатынастар (субэкспрессия арқылы алынған) ықшамдалуы мүмкін.

Негізгі таңдау қасиеттері

Таңдау идемпотентті (бірдей таңдаудың бірнеше қосымшасы біріншісінен тыс қосымша әсер етпейді), және ауыстырмалы (тапсырыс таңдауының қолданылуы түпкілікті нәтижеге әсер етпейді).

Күрделі шарттары бар таңдауды бұзу

Шарты a болатын таңдау конъюнкция қарапайым шарттар бірдей жеке шарттары бар таңдау тізбегіне және шарты а болатын таңдауға сәйкес келеді дизъюнкция таңдаулар одағына тең. Бұл сәйкестікті таңдауларды азырақ бағалау қажет болатындай етіп таңдауды біріктіру үшін немесе компоненттерді бөлек жылжыту немесе оңтайландыру үшін оларды бөлу үшін пайдалануға болады.

Таңдау және кросс-өнім

Кросс өнім бағалаудың ең қымбат операторы болып табылады. Егер кіріс қарым-қатынастар бар N және М жолдар, нәтиже болады жолдар. Сондықтан кросс-өнім операторын қолданар алдында екі операндтың көлемін азайту үшін бар күшімізді салу өте маңызды.

Мұны тиімді түрде жасауға болады, егер кросс өнімнен кейін таңдау операторы жүрсе, мысалы. . Қосылудың анықтамасын ескере отырып, бұл ең ықтимал жағдай. Егер кросс-өнімнің артынан таңдау операторы жүрмесе, біз басқа таңдау ережелерін қолдана отырып, өрнек ағашының жоғары деңгейлерінен таңдауды төмендетуге тырысамыз.

Жоғарыдағы жағдайда біз шартты бұзамыз A жағдайға B, C және Д. күрделі таңдау шарттары туралы сплит ережелерін қолдану, осылайша және B тек атрибуттарды қамтиды R, C тек атрибуттарды қамтиды P, және Д. бөлігін қамтиды A екеуінің де атрибуттарын қамтиды R және P. Ескертіп қой B, C немесе Д. бос болуы мүмкін. Содан кейін келесідей:

Операторларды таңдау және орнату

Таңдау тарату орнатылған айырмашылық, қиылысу және біріктіру операторлары. Келесі үш ереже өрнек ағашындағы орнатылған амалдардан төмен таңдауды итеру үшін қолданылады. Орнатылған айырмашылық пен қиылысу операторлары үшін таңдау операторын түрлендіруден кейінгі операндалардың біріне ғана қолдануға болады. Бұл операндтардың біреуі кіші болған жағдайда тиімді болуы мүмкін, ал таңдау операторын бағалаудың артықшылығы кішірек нұсқаны пайдаланудан артық болады қатынас операнд ретінде.

Таңдау және проекциялау

Егер таңдау шартында көрсетілген өрістер проекциядағы өрістердің ішкі жиыны болса ғана, таңдау проекциямен жүреді. Проекцияға дейін таңдауды орындау операнд кросс өнім немесе біріктіру болған жағдайда пайдалы болуы мүмкін. Басқа жағдайларда, егер таңдау шартын есептеу салыстырмалы түрде қымбатқа түсетін болса, проекциядан тыс жылжу таңдаудың тексерілуі керек кортеждердің санын азайтуы мүмкін (өйткені проекцияда өткізіп алған өрістердің нәтижесінде қайталанатын көшірмелердің жойылуына байланысты аз кортеждер пайда болуы мүмкін).

Болжам

Негізгі проекциялық қасиеттері

Проекция идемпотентті, сондықтан проекциялар қатары (жарамды) сыртқы проекцияға эквивалентті болады.

Проекциялау және орнату операторлары

Проекциялау тарату белгіленген одақ.

Проекция қиылысу бойынша бөлінбейді және айырмашылықты орнатады. Қарсы мысалдар келтірілген:

және

қайда б ерекшеленеді деп болжануда b '.

Атын өзгерту

Атаулардың негізгі қасиеттері

Айнымалының кезекті атауын бір атау етіп жинауға болады. Жалпыға ортақ айнымалысы жоқ атауды өзгерту бір-біріне қатысты ерікті түрде қайта реттелуі мүмкін, оны пайдаланып, оларды ығыстыруға болатын етіп, қатарлас атау жасауға болады.

Операторлардың атауын өзгерту және орнату

Атын өзгерту жиынтық айырмашылыққа, біріктіруге және қиылысқа бөлінеді.

Өнім және кәсіподақ

Декарттық өнім одаққа қарай таралады.

Іске асыру

Кодд алгебрасына негізделген алғашқы сұрау тілі - доктор Коддтың өзі жасаған Альфа. Кейіннен, ISBL құрылды, және бұл ізашарлық жұмысты көптеген органдар мақтады [1] Коддтың идеясын пайдалы тілге айналдыру жолын көрсеткендей. Бизнес жүйесі 12 ISBL үлгісін ұстанған қысқа мерзімді салалық қатынасты ДҚБЖ болды.

1998 жылы Крис Дата және Хью Дарвен деп аталатын тілді ұсынды Оқу құралы D реляциялық мәліметтер қорының теориясын оқытуда қолдануға арналған және оның сұрау тілі ISBL идеяларына сүйенеді. Рел жүзеге асыру болып табылады Оқу құралы D.

Тіпті SQL реляциялық алгебраға негізделген, бірақ SQL-дегі операндтар (кестелер ) дәл емес қарым-қатынастар және реляциялық алгебра туралы бірнеше пайдалы теоремалар SQL аналогында болмайды (оптимизаторларға және / немесе пайдаланушыларға зиян келтіруі мүмкін). SQL кестесінің моделі - бұл сөмке (мультисет ) емес, жиынтық. Мысалы, өрнек жиынтықтардағы реляциялық алгебра үшін теорема, бірақ сөмкелердегі реляциялық алгебра үшін емес; реляциялық алгебраны сөмкелермен емдеу үшін «Толық» оқулығының 5-тарауын қараңыз Гарсия-Молина, Ульман және Widom.[11]

Сондай-ақ қараңыз

Әдебиеттер тізімі

  1. ^ Жылы Юникод, галстук белгісі ⋈ (U + 22C8).
  2. ^ Жылы Юникод, ltimes символы ⋉ (U + 22C9). Rtimes символы ⋊ (U + 22CA)
  3. ^ Кодд, Э.Ф. (Маусым 1970). «Ірі ортақ пайдаланылатын деректер банктері үшін реляциялық модель». ACM байланысы. 13 (6): 377–387. дои:10.1145/362384.362685.
  4. ^ Жылы Юникод, Antijoin символы ▷ (U + 25B7).
  5. ^ М.Тамер Өзсу; Патрик Валдуриез (2011). Таратылған мәліметтер қоры жүйелерінің принциптері (3-ші басылым). Спрингер. б. 46. ISBN  978-1-4419-8833-1.
  6. ^ Патрик О'Нил; Элизабет О'Нил (2001). Деректер базасы: принциптер, бағдарламалау және өнімділік, екінші басылым. Морган Кауфман. б. 120. ISBN  978-1-55860-438-4.
  7. ^ Жылы Юникод, сол жақ сыртқы біріктіру символы ⟕ (U + 27D5).
  8. ^ Жылы Юникод, оң жақ сыртқы біріктіру символы ⟖ (U + 27D6).
  9. ^ Жылы Юникод, Толық сыртқы қосылу символы ⟗ (U + 27D7).
  10. ^ C. J. Күні (2011). SQL және қатынас теориясы: SQL кодын қалай дұрыс жазу керек. O'Reilly Media, Inc. 133–135 беттер. ISBN  978-1-4493-1974-8.
  11. ^ а б Гектор Гарсия-Молина; Джеффри Д. Ульман; Дженнифер Видом (2009). Мәліметтер базасы жүйелері: толық кітап (2-ші басылым). Pearson Prentice Hall. ISBN  978-0-13-187325-4.
  12. ^ Ахо, Альфред V .; Джеффри Д. Ульман (1979). «Мәліметтерді іздеу тілдерінің әмбебаптығы». Бағдарламалау тілдерінің принциптері бойынша 6-шы ACM SIGACT-SIGPLAN симпозиумының материалдары: 110–119. дои:10.1145/567752.567763.

Әрі қарай оқу

Деректер базасындағы кез-келген академиялық оқулықта классикалық реляциялық алгебра егжей-тегжейлі қарастырылған.

Сыртқы сілтемелер