資料庫的運算
① 資料庫關系運算
傳統的數學集合的關系運算和資料庫專有的關系運算
資料庫本身是一個二維的表,就相當於是一個數學的集合。
有的時候需要兩個表進行運算,比如,找到兩個表中相同的部分,這個的運算機制就是傳統的集合運算中的「交」。
有的時候需要表本身進行計算,比如,只需要顯示表中某一列的數值,這個就是關系的專門運算「投影」。
其餘的運算你可以自己找找,基本原理都很簡單的,一看就能明白。
② 資料庫是怎樣運算數據的
先把輸入的字元串轉換成資料庫內部的數據結構,然後根據解析出來的數據結構執行相應的操作。不同的數據類型有系統內部寫好的處理函數,根據識別的數據類型和命令類型查找對應的處理函數。對於一個查詢,會生產執行計劃,根據輸入的信息從外存中取數據,然後進行用戶要求的操作。輸入的數據會被解析成一個參數結構體,里邊存放了數據的類型,長度等信息。表達式會放在表達式的結構體中
③ 資料庫常用的關系運算是什麼
在關系資料庫中,基本的關系運算有三種,它們是選擇、投影和連接。關系的基本運算有兩類:一類是傳統的集合運算(並、差、交等),另一類是專門的關系運算(選擇、投影、連接、除法、外連接等),有些查詢需要幾個基本運算的組合,要經過若干步驟才能完成。
一、傳統的集合運算
1、並(UNION)設有兩個關系R和S,它們具有相同的結構。R和S的並是由屬於R或屬於S的元組組成的集合,運算符為∪。記為T=R∪S。
2、差(DIFFERENCE)R和S的差是由屬於R但不屬於S的元組組成的集合,運算符為-。記為T=R-S。
3、交(INTERSECTION)R和S的交是由既屬於R又屬於S的元組組成的集合,運算符為∩。記為T=R∩S。R∩S=R-(R-S)。
二、選擇運算
從關系中找出滿足給定條件的那些元組稱為選擇。其中的條件是以邏輯表達式給出的,值為真的元組將被選取。這種運算是從水平方向抽取元組。在FOXPRO中的短語FOR和WHILE均相當於選擇運算。
如:LISTFOR出版單位='高等教育出版社'AND單價<=20
三、投影運算
從關系模式中挑選若干屬性組成新的關系稱為投影。這是從列的角度進行的運算,相當於對關系進行垂直分解。在FOXPRO中短語FIELDS相當於投影運算。如:LISTFIELDS單位,姓名
四、連接運算
連接運算是從兩個關系的笛卡爾積中選擇屬性間滿足一定條件的元組。
五、除法運算
在關系代數中,除法運算可理解為笛卡爾積的逆運算。
設被除關系R為m元關系,除關系S為n元關系,那麼它們的商為m-n元關系,記為R÷S。商的構成原則是:將被除關系R中的m-n列,按其值分成若干組,檢查每一組的n列值的集合是否包含除關系S,若包含則取m-n列的值作為商的一個元組,否則不取。
(3)資料庫的運算擴展閱讀:
資料庫除運算:
除運算的含義–給定關系R (X,Y) 和S (Y,Z),其中X,Y,Z為屬性組。R中的Y與S中的Y可以有不同的屬性名,但必須出自相同的域集。R與S的除運算得到一個新的關系P(X),P是R中滿足下列條件的元組在X屬性列上的投影:元組在X上分量值x的象集Yx包含S在Y上投影的集合。
R÷S的結果為a1,x相當於A y 相當於B,C z相當於D,按照除運算規則,我們不必關注D。只需比較B,C當S關系中的B,C所有的組合(b1,c2)(b2,c3)(b2,c1)都出現在R關系中時,結果才為A
R÷S = {tr[X] | trÎR∧πY (S) íYx },Yx:x在R中的象集,x = tr[X]。除操作是同時從行和列角度進行運算。
④ 資料庫的關系運算
傳統的數學集合的關系運算和資料庫專有的關系運算
資料庫本身是一個二維的表,就相當於是一個數學的集合。
有的時候需要兩個表進行運算,比如,找到兩個表中相同的部分,這個的運算機制就是傳統的集合運算中的「交」。
有的時候需要表本身進行計算,比如,只需要顯示表中某一列的數值,這個就是關系的專門運算「投影」。
其餘的運算你可以自己找找,基本原理都很簡單的,一看就能明白。
⑤ 關系資料庫中關系代數的基本運算有哪些
五種基本操作:並,差,積,選擇,投影;構成關系代數完備的操作集。其他非基本操作:可以用以上五種基本操作合成的所有操作。並(U)、交(⌒)、投影(π)選擇(σ)和笛卡兒積(×)。
傳統的集合運算:
1、並(UNION)設有兩個關系R和S,它們具有相同的結構。R和S的並是由屬於R或屬於S的元組組成的集合,運算符為∪。記為T=R∪S。
2、差(DIFFERENCE)R和S的差是由屬於R但不屬於S的元組組成的集合,運算符為-。記為T=R-S。
3、交(INTERSCTION)R和S的交是由既屬於R又屬於S的元組組成的集合,運算符為∩。記為T=R∩S。R∩S=R-(R-S)。
(5)資料庫的運算擴展閱讀:
在資料庫世界裡,後關系資料庫仍舊泰然自若,保持其本色。
在現代IT界,sql和XML已經成為資料庫的非常重要組成部分,這二者成為資料庫系統結構組成部分的歷史也很長久了,至於開始的時間我也很難記得了。
在60年代末和70年代初,出現了具備靈活欄位長度、嵌套表格、鬆散數據類型選擇的資料庫構架,這樣的資料庫系統不僅受市場歡迎,也得到大家的青睞。這些早期的資料庫系統雖然缺乏像XML一樣的標記功能,但是它們在實際工作中卻表現出和XML極為類似的功能。
描述這些資料庫系統的術語是「後關系」或者「多值」,它們沒有SQL關系資料庫知名,是因為這些資料庫系統缺乏許多新聞的宣傳度,我們很容易把它認為是一個實驗而已,然後這些實驗在人們的印象中就會半途而廢了,最終慢慢的消失。
⑥ SQL資料庫中有哪幾類運算啊
主要四種
1實體完整性約束(每一行反應不同的實體)
通過索引,唯一約束。主鍵約束或標識屬性來體現
2域完整性約束(指給定列的輸入有效性)
通過限制數據類型,檢查約束,輸入格式,外鍵約束,默認值,非空等體現
3引用完整性約束(表之間的聯系)
通過主外建
4自定義完整性約束(根據用戶的需求)
⑦ 關系資料庫主要支持的3種基本運算是什麼
關系的基本運算有兩類:一類是傳統的集合運算(並、差、交等),另一類是專門的關系運算(選擇、投影、聯接等),有些查詢需要幾個基本運算的組合,要經過若干步驟才能完成。
一、傳統的集合運算
1、並(UNION) 設有兩個關系R和S,它們具有相同的結構。R和S的並是由屬於R或屬於S的元組組成的集合,運算符為∪。記為T=R∪S。
2、差(DIFFERENCE) R和S的差是由屬於R但不屬於S的元組組成的集合,運算符為-。記為T=R-S。
3、交(INTERSCTION) R和S的交是由既屬於R又屬於S的元組組成的集合,運算符為∩。記為T=R∩S。 R∩S=R-(R-S)。
二、選擇運算
從關系中找出滿足給定條件的那些元組稱為選擇。其中的條件是以邏輯表達式給出的,值為真的元組將被選取。這種運算是從水平方向抽取元組。 在FOXPRO中的短語FOR<條件>和WHILE<條件>均相當於選擇運算。
如:LIST FOR 出版單位='高等教育出版社' AND 單價<=20
三、投影運算
從關系模式中挑選若干屬性組成新的關系稱為投影。這是從列的角度進行的運算,相當於對關系進行垂直分解。在FOXPRO中短語FIELDS<欄位1,欄位2,…>相當於投影運算。 如: LIST FIELDS 單位,姓名
四、聯接運算
選擇和投影運算都是屬於一目運算,它們的操作對象只是一個關系。聯接運算是二目運算,需要兩個關系作為操作對象。
1、聯接 聯接是將兩個關系模式通過公共的屬性名拼接成一個更寬的關系模式,生成的新關系中包含滿足聯接條件的元組。運算過程是通過聯接條件來控制的,聯接條件中將出現兩個關系中的公共屬性名,或者具有相同語義、可比的屬性。聯接是對關系的結合。在FOXPRO中有單獨一條命令JOIN實現兩個關系的聯接運算。如:
SELE 1
USE 定單
SELE 2
USE 商品
JOIN WITH A TO XGX FOR A->貨號=貨號 AND 庫存量>=A->定購量
設關系R和S分別有m和n個元組,則R與S的聯接過程要訪問m×n個元組。由此可見,涉及到聯接的查詢應當考慮優化,以便提高查詢效率。
2、自然聯接 自然聯接是去掉重復屬性的等值聯接。它屬於聯接運算的一個特例,是最常用的聯接運算,在關系運算中起著重要作用。
如果需要兩個以上的關系進行聯接,應當兩兩進行。利用關系的這三種專門運算可以方便地構造新的關系。
五、外關鍵字
如果一個關系中的屬性或屬性組並非該關系的關鍵字,但它們是另外一個關系的關鍵字,則稱為該關系的外關鍵字。
綜上所述,關系資料庫系統有如下特點:
(1)資料庫中的全部數據及其相互聯系都被組織成關系,即二維表的形式。
(2)關系資料庫系統提供一種完備的高級關系運算,支持對資料庫的各種操作。
(3)關系模型有嚴格的數學理論,使資料庫的研究建立在比較堅實的數學基礎上。
⑧ 資料庫中邏輯運算符有哪些
資料庫中邏輯運算符有:「非」(¬)、「與」(∧)、「或」(∨)、「條件」(→)以及「雙條件」(↔)。「非」是一個一元操作符,它只操作一項(¬ P)等。
注意,符號「與」(∧)和交集(∩),「或」(∨)和並集(∪)的相似性。這不是巧合:交集的定義使用「與」,並集的定義是用「或」。
在形式邏輯中,邏輯運算符或邏輯聯結詞把語句連接成更復雜的復雜語句。例如,假設有兩個邏輯命題,分別是「正在下雨」和「我在屋裡」,我們可以將它們組成復雜命題「正在下雨,並且我在屋裡」或「沒有正在下雨」或「如果正在下雨,那麼我在屋裡」。
一個將兩個語句組成的新的語句或命題叫做復合語句或復合命題。
(8)資料庫的運算擴展閱讀
sql語句結構
1、數據查詢語言(DQL:Data Query Language):其語句,也稱為「數據檢索語句」,用以從表中獲得數據,確定數據怎樣在應用程序給出。
保留字SELECT是DQL(也是所有SQL)用得最多的動詞,其他DQL常用的保留字有WHERE,ORDER BY,GROUP BY和HAVING。這些DQL保留字常與其它類型的SQL語句一起使用。
2、數據操作語言(DML:Data Manipulation Language):其語句包括動詞INSERT、UPDATE和DELETE。它們分別用於添加、修改和刪除。
3、事務控制語言(TCL):它的語句能確保被DML語句影響的表的所有行及時得以更新。包括COMMIT(提交)命令、SAVEPOINT(保存點)命令、ROLLBACK(回滾)命令。
⑨ 資料庫中專門的關系運算包括那三種
關系基本運算包括:選擇、投影和連接。選擇是篩選出符合條件的記錄;投影是選擇若干屬性;連接是兩個關系通過關聯欄位合並為一個新的關系。
1、選擇(selection)
選擇運算是單目運算,它從一個關系R中選擇出滿足給定條件的所有元組,並同R具有相同的結構。
關系R的選擇運算是從關系R中選擇滿足指定條件(用F表示)的元組構成的新關系.換言之,選擇運算的結果是一個表的水平方向的子集。關系R的選擇運算記為:σF(R)。
2、投影(projection)
投影運算也是單目運算,它從一個關系R所有屬性中選擇某些指定屬性,組成一個新的關系。選擇運算選取關系的某些行,而投影運算選取關系的某些列,是從一個關系出發構造其垂直子集的運算。
3、連接(join)
連接運算是關系的二目運算.關系R與關系S的連接運算是從兩個關系的廣義笛卡爾積中選取屬性間滿足一定條件(稱為連接條件,記為AθB)的元組形成一個新關系。
(9)資料庫的運算擴展閱讀:
關系運算符有6種關系,分別為小於、小於等於、大於、等於、大於等於、不等於。
1、小於a<b,a小於b時返回真;否則返回假。
2、小於等於a<=b;a小於等於b時返回真;否則返回假。
3、大於a>b;a大於b時返回真;否則返回假。
4、大於等於a>=b;a大於等於b時返回真;否則返回假。
5、等於a=b;a等於b時返回真;否則返回假。
6、不等於a!=b;a不等於b時返回真;否則返回假。
關系運算符的值只能是0或1。關系運算符的值為真時,結果值都為1。關系運算符的值為假時,結果值都為0。
前4種關系運算符的優先順序別相同,後兩種也相同。前四種高於後兩種。關系運算符的優先順序低於算術運算符。關系運算符的優先順序高於賦值運算符。
⑩ 資料庫中關系運算有哪些
應該分為兩大類:
1.傳統的數學集合的關系運算
2.資料庫專有的關系運算
現在關系資料庫本身是一個二維表,相當於一個有序的鏈表,也可以看成是數學中的集合。
(1)表與表之間的運算可以看成是集合和集合之間的運算,支持"與"、"或"、「非」和
「異或」等大部分算術運算。
(2)「投影運算」:即對資料庫的一列(欄位)或多列的運算。