Tuple ilişkisel hesap - Tuple relational calculus

Tuple hesabı bir hesap tarafından oluşturulan ve tanıtılan Edgar F. Codd bir parçası olarak ilişkisel model sağlamak için beyan edici burada veri işleme için veritabanı sorgu dili veri örneği. Veritabanı sorgu dilleri için ilham kaynağı oluşturdu QUEL ve SQL orijinal ilişkisel modele ve analize çok daha az sadık olmasına rağmen, şimdi fiilen standart veritabanı sorgulama dilidir; SQL'in bir lehçesi neredeyse herkes tarafından kullanılır ilişkisel veritabanı yönetim sistemi. Michel Lacroix ve Alain Pirotte önerilen alan hesabı, hangisine daha yakın birinci dereceden mantık ve Codd ile birlikte, bu taşların her ikisinin de (hem de ilişkisel cebir ) ifade gücünde eşdeğerdir. Daha sonra, ilişkisel model için sorgu dilleri çağrıldı ilişkisel olarak tamamlanmış en azından tüm bu sorguları ifade edebilselerdi.

Analizin tanımı

İlişkisel veritabanı

Analiz için bir sorgu dili olduğu için ilişkisel veritabanları önce ilişkisel bir veri tabanı tanımlamamız gerekir. Temel ilişkisel yapı taşı, alan adı (biraz benzer, ancak eşit değil, a veri tipi ). Bir demet sonlu bir dizidir Öznitellikler, hangileri sıralı çiftler alanların ve değerlerin. Bir ilişki (uyumlu) demetler kümesidir. Bu ilişkisel kavramlar matematiksel olarak tanımlansa da, bu tanımlar geleneksel veritabanı kavramlarıyla gevşek bir şekilde eşleşir. Bir masa bir ilişkinin kabul edilen görsel bir temsilidir; demet, bir kavramına benzer kürek çekmek.

Önce bir setin varlığını varsayıyoruz C Örnekleri "ad", "yazar", "adres" vb. olan sütun adları. Biz tanımlıyoruz başlıklar sonlu alt kümeleri olarak C. Bir ilişkisel veritabanı şeması olarak tanımlanır demet S = (D, R, h) nerede D atomik değerlerin alanıdır (bkz. ilişkisel model kavramları hakkında daha fazlası için alan adı ve atomik değer), R sonlu bir ilişki isimleri kümesidir ve

h : R → 2C

a işlevi her bir ilişki adıyla bir başlığı ilişkilendiren R. (Bunun, birden fazla alanın olduğu ve bir başlığın yalnızca bir sütun adı kümesi olmadığı, aynı zamanda bu sütun adlarını bir alanla eşlediği tam ilişkisel modelden bir basitleştirme olduğunu unutmayın.) Bir etki alanı verildiğinde D biz bir demet bitmiş D olarak kısmi işlev bazı sütun adlarını atomik bir değerle eşleyen D. Bir örnek şöyle olabilir (isim: "Harry", yaş: 25).

t : CD

Tüm demetlerin kümesi bitti D olarak belirtilir TD. Alt kümesi C bunun için bir demet t tanımlanırsa denir alan adı nın-nin t (şemadaki alan adıyla karıştırılmamalıdır) ve şu şekilde gösterilir: dom(t).

Sonunda bir tanımlıyoruz ilişkisel veritabanı şema verildi S = (D, R, h) işlev olarak

db : R → 2TD

ilişki adlarını eşleyen R sonlu alt kümelerine TD, öyle ki her ilişki adı için r içinde R ve tuple t içinde db(r) bunu tutar

dom(t) = h(r).

İkinci gereksinim basitçe, bir ilişkideki tüm kayıtların aynı sütun adlarını, yani şemada kendisi için tanımlananları içermesi gerektiğini söyler.

Atomlar

Formüllerin oluşturulması için sonsuz bir küme varsayacağız V tuple değişkenleri. Formüller, bir veritabanı şeması ile tanımlanır S = (D, R, h) ve kısmi bir işlev tip : V ⇸ 2C, aradı tip ataması, bazı tuple değişkenlerine başlıklar atar. Daha sonra dizi atomik formüller Bir[S,tip] aşağıdaki kurallarla:

  1. Eğer v ve w içinde V, a içinde tip(v) ve b içinde tip(w) sonra formül v.a = w.b içinde Bir[S,tip],
  2. Eğer v içinde V, a içinde tip(v) ve k içindeki bir değeri gösterir D sonra formül v.a = k içinde Bir[S,tip], ve
  3. Eğer v içinde V, r içinde R ve tip(v) = h(r) sonra formül r(v) içinde Bir[S,tip].

Atom örnekleri:

  • (t.age = s.age) - t yaş özelliğine sahiptir ve s aynı değere sahip bir yaş özelliğine sahiptir
  • (t.name = "Codd") - tuple t bir name özniteliğine sahiptir ve değeri "Codd" dur
  • Kitap(t) - tuple t İlişkili Kitapta mevcuttur.

Bu tür atomların biçimsel semantiği bir veri tabanıyla tanımlanır. db bitmiş S ve bir tuple değişken bağlaması val : VTD tuple değişkenlerini etki alanı üzerindeki tuple'lere eşleyen S:

  1. v.a = w.b doğrudur ancak ve ancak val(v)(a) = val(w)(b)
  2. v.a = k doğrudur ancak ve ancak val(v)(a) = k
  3. r(v), ancak ve ancak val(v) içinde db(r)

Formüller

Atomlar, birinci dereceden mantıkta her zaman olduğu gibi, mantıksal operatörler ∧ (ve), ∨ (veya) ve ¬ (değil) ile formüllere birleştirilebilir ve varoluşsal niceleyici (∃) ve evrensel niceleyici kullanabiliriz. (∀) değişkenleri bağlamak için. Biz tanımlıyoruz formül seti F[S,tip] aşağıdaki kurallarla endüktif olarak:

  1. içindeki her atom Bir[S,tip] aynı zamanda F[S,tip]
  2. Eğer f1 ve f2 içeride F[S,tip] sonra formül f1f2 ayrıca içinde F[S,tip]
  3. Eğer f1 ve f2 içeride F[S,tip] sonra formül f1f2 ayrıca içinde F[S,tip]
  4. Eğer f içinde F[S,tip] sonra formül ¬ f ayrıca içinde F[S,tip]
  5. Eğer v içinde V, H bir başlık ve f bir formül F[S,tip[v->H]] sonra formül ∃ v : H ( f ) ayrıca F[S,tip], nerede tip[v->H] eşit olan işlevi gösterir tip eşlemesi dışında v -e H,
  6. Eğer v içinde V, H bir başlık ve f bir formül F[S,tip[v->H]] sonra formül ∀ v : H ( f ) ayrıca F[S,tip]

Formül örnekleri:

  • t.name = "C. J. Tarih" ∨ t.name = "H. Darwen"
  • Kitap(t) ∨ Dergi (t)
  • t : {yazar, başlık, konu} (¬ (Kitap (t) ∧ t.author = "C. J. Tarih" ∧ ¬ ( t.subject = "ilişkisel model")))

Son formülün, C. J. Date tarafından yazılan tüm kitapların konu olarak ilişkisel model olduğunu belirttiğine dikkat edin. Her zamanki gibi, eğer bu formülün anlambilimiyle ilgili bir belirsizliğe neden olmazsa, parantezleri atlarız.

Niceleyicilerin, şemadaki etki alanı üzerindeki tüm tupleların evreni üzerinden nicelleştirdiğini varsayacağız. Bu, bir veritabanı verilen formüller için aşağıdaki biçimsel semantiğe götürür db bitmiş S ve bir tuple değişken bağlaması val : V -> TD:

  1. f1f2 doğrudur ancak ve ancak f1 doğru ve f2 doğru,
  2. f1f2 doğrudur ancak ve ancak f1 doğru mu f2 doğru mu yoksa ikisi de doğru
  3. ¬ f doğrudur ancak ve ancak f doğru değil,
  4. v : H ( f ) ancak ve ancak bir demet varsa doğrudur t bitmiş D öyle ki dom(t) = H ve formül f için doğru val[v->t], ve
  5. v : H ( f ), ancak ve ancak tüm demetler için doğrudur t bitmiş D öyle ki dom(t) = H formül f için doğru val[v->t].

Sorguları

Son olarak, bir şema verildiğinde bir sorgu ifadesinin nasıl göründüğünü tanımlıyoruz S = (D, R, h):

{ v : H | f(v) }

nerede v bir tuple değişkendir, H bir başlık ve f(v) bir formül F[S,tip] nerede tip = { (v, H) } Ve birlikte v tek serbest değişkeni olarak. Belirli bir veritabanı için böyle bir sorgunun sonucu db bitmiş S tüm demetlerin kümesidir t bitmiş D ile dom(t) = H öyle ki f için doğru db ve val = { (v, t) }.

Sorgu ifadelerine örnekler:

  • { t : {isim} | ∃ s : {isim, maaş} (Çalışan (s) ∧ s. ücret = 50.000 ∧ t.name = s.name)}
  • { t : {tedarikçi, makale} | ∃ s : {s #, sname} (Tedarikçi (s) ∧ s.sname = t.supplier ∧ ∃ p : {p #, pname} (Ürün (p) ∧ p.pname = t.article ∧ ∃ a : {s #, p #} (Malzemeler (a) ∧ s.s # = a.s # ∧ a.p # = p.p #)}

Analizin anlamsal ve sözdizimsel kısıtlaması

Etki alanından bağımsız sorgular

Nicelik belirteçlerinin anlambilgisi, şemadaki etki alanı üzerindeki tüm tuplelar üzerinden nicelleştirecek şekilde olduğundan, başka bir şema varsayılırsa, bir sorgu belirli bir veritabanı için farklı bir sonuç döndürebilir. Örneğin, iki şemayı düşünün S1 = ( D1, R, h ) ve S2 = ( D2, R, h ) alanlarla D1 = { 1 }, D2 = {1, 2}, ilişki adları R = {"r1"} ve başlıklar h = {("r1", {" a "})}. Her iki şemanın da ortak bir örneği vardır:

db = {("r1", {(" a ", 1)})}

Aşağıdaki sorgu ifadesini ele alırsak

{ t : {a} | t.a = t.a}

sonra sonucu db ya {(a: 1)} altında S1 veya {(a: 1), (a: 2)} altında S2. Etki alanını sonsuz bir küme olarak alırsak, sorgunun sonucunun da sonsuz olacağı açıktır. Bu sorunları çözmek için dikkatimizi şu sorgulara sınırlayacağız: etki alanından bağımsızyani, tüm şemaları altında bir veritabanı için aynı sonucu döndüren sorgular.

Bu sorguların ilginç bir özelliği, tuple değişkenlerinin sözde tuple üzerinde değiştiğini varsayarsak. aktif alan Veritabanında veya sorgu ifadesinde en az bir tuple'da oluşan etki alanının alt kümesi olan veritabanının, sorgu ifadelerinin anlamsallığı değişmez. Aslında, demet hesaplamasının birçok tanımında bu, niceleyicilerin anlambiliminin nasıl tanımlandığıdır, bu da tanıma göre tüm sorguları etki alanından bağımsız kılar.

Güvenli sorgular

Sorgu ifadelerini yalnızca etki alanından bağımsız sorguları ifade edecek şekilde sınırlamak için sözdizimsel bir kavram güvenli sorgu genellikle tanıtılır. Bir sorgu ifadesinin güvenli olup olmadığını belirlemek için bir sorgudan iki tür bilgi türeteceğiz. Birincisi, değişken-sütun çifti olup olmadığıdır. t.a dır-dir ciltli bir ilişkinin veya bir sabitin sütununa ve ikincisi, iki değişken-sütun çiftinin doğrudan mı yoksa dolaylı olarak mı eşitlendiğidir ( t.v == s.w).

Sınırlılık elde etmek için aşağıdaki muhakeme kurallarını sunuyoruz:

  1. içinde " v.a = w.b "hiçbir değişken sütun çifti bağlı değil,
  2. içinde " v.a = k "değişken sütun çifti v.a sınırdır,
  3. içinde " r(v) "tüm çiftler v.a bağlı a içinde tip(v),
  4. içinde " f1f2 "ya bağlı olan tüm çiftler bağlıdır f1 veya içinde f2,
  5. içinde " f1f2 "her ikisi de bağlı olan tüm çiftler f1 ve f2,
  6. "¬ içinde f "hiçbir çift bağlı değildir,
  7. "∃ içinde v : H ( f ) " bir çift w.a bağlıysa bağlıdır f ve w <> v, ve
  8. "∀ içinde v : H ( f ) " bir çift w.a bağlıysa bağlıdır f ve w <> v.

Eşitliği türetmek için aşağıdaki akıl yürütme kurallarını sunuyoruz (eşdeğerlik ilişkileri için olağan muhakeme kurallarının yanında: dönüşlülük, simetri ve geçişlilik):

  1. içinde " v.a = w.b "bunu tutar v.a == w.b,
  2. içinde " v.a = k "hiçbir çift eşit değildir,
  3. içinde " r(v) "hiçbir çift eşitlenmez,
  4. içinde " f1f2 "bunu tutar v.a == w.b ikisinden biri tutarsa f1 veya içinde f2,
  5. içinde " f1f2 "bunu tutar v.a == w.b ikisini de tutarsa f1 ve f2,
  6. "¬ içinde f "hiçbir çift eşit değildir,
  7. "∃ içinde v : H ( f ) "bunu tutar w.a == x.b tutarsa f ve w<>v ve x<>v, ve
  8. "∀ içinde v : H ( f ) "bunu tutar w.a == x.b tutarsa f ve w<>v ve x<>v.

Daha sonra bir sorgu ifadesinin {v: H | f (v)} kasa Eğer

  • her sütun adı için a içinde H bunu türetebiliriz v.a bağlı bir çift ile eşitlenir f,
  • her alt ifadesi için f "∀ şeklinde w : G ( g ) "bunu her sütun adı için türetebiliriz a içinde G bunu türetebiliriz w.a bağlı bir çift ile eşitlenir g, ve
  • her alt ifadesi için f formunun " w : G ( g ) "bunu her sütun adı için türetebiliriz a içinde G bunu türetebiliriz w.a bağlı bir çift ile eşitlenir g.

Güvenli sorgu ifadelerine yönelik kısıtlama, ifade edilebilirliği sınırlamaz çünkü ifade edilebilen tüm etki alanından bağımsız sorgular, güvenli bir sorgu ifadesi ile de ifade edilebilir. Bu, bir şema için gösterilerek kanıtlanabilir S = (D, R, h), belirli bir set K Sorgu ifadesindeki sabitlerin sayısı, bir tuple değişkeni v ve bir başlık H her çift için güvenli bir formül oluşturabiliriz v.a ile a içinde H değerinin aktif alanda olduğunu belirtir. Örneğin, varsayalım ki K={1,2}, R= {"r"} ve h = {("r", {"a," b "})} sonra buna karşılık gelen güvenli formül v.b şudur:

v.b = 1 ∨ v.b = 2 ∨ ∃ w (r (w) ∧ ( v.b = w.a ∨ v.b = w.b))

Bu formül, daha sonra, her değişken için böyle bir formül ekleyerek herhangi bir güvenli olmayan sorgu ifadesini eşdeğer güvenli bir sorgu ifadesine yeniden yazmak için kullanılabilir. v ve sütun adı a ifadede kullanıldığı türünde. Etkili olarak bu, tüm değişkenlerin, daha önce açıklandığı gibi, ifade edilen sorgu etki alanından bağımsız olması durumunda semantiği değiştirmeyen etkin etki alanı üzerinde değişmesine izin verdiğimiz anlamına gelir.

Sistemler

Ayrıca bakınız

Referanslar