資料庫SQL---關係模型與關係代數

来源:https://www.cnblogs.com/xqy1874/archive/2020/04/30/12808572.html
-Advertisement-
Play Games

1、關係資料庫:表的集合,即關係的集合。 關係資料庫=關係資料庫模式(型)+關係資料庫內容(值) 1)域:一組具有相同數據類型的值的集合。 2)笛卡爾積:對集合進行窮舉外變一次內變一邊,是一張二維表,表中的一行對應於一個元組,表中的一列的值來自於同一個域。 給定一組域D1,D2,...,Dn的笛卡爾 ...


1、關係資料庫:表的集合,即關係的集合。

     關係資料庫=關係資料庫模式(型)+關係資料庫內容(值)

1)域:一組具有相同數據類型的值的集合。

2)笛卡爾積:對集合進行窮舉外變一次內變一邊,是一張二維表,表中的一行對應於一個元組,表中的一列的值來自於同一個域。

     給定一組域D1,D2,...,Dn的笛卡爾積為D1×D2×...×Dn={(d1,d2,...,dn)|di€Di,i=1,2,...,n},其中集合中的每一個元素(d1,d2,...,dn)稱為一個n元組,簡稱元組,元組中的每一個值di稱為一個分量

3)關係:笛卡爾積的子集,是一張二維表。

2、關係模式:簡記為r(U)或r(D1,D2,...,Dn),其中r是關係的名字,U是屬性名(D1,D2,...,Dn)的集合,n是關係的目(或度),當n=1時,稱該關係為單元關係;當n=2時,稱該關係為二元關係。

3、碼

1)超碼:屬性集A可以唯一地標識關係r中的一個元組,則稱屬性A為關係r的超碼。

2)全碼:所有屬性加在一起組成的候選碼。

3)候選碼:屬性集A是關係r的超碼,且屬性集A的任意真子集都不能稱為關係r的超碼,則稱屬性集A為候選碼。候選碼是最小的超碼,即最小屬性組。

候選碼的諸屬性稱為主屬性,不能為空。不包含在任何候選碼中的屬性稱為非碼屬性。

4)主碼:若一個關係有多個候選碼,則可選定其中一個候選碼作為該關係的主碼。

5)外碼:F是關係r的一個屬性,Ks是關係s的主碼,若F與Ks相對應,則稱F是關係r參照關係s的外碼,簡稱F是關係r的外碼,並稱關係r為參照關係,關係s為被參照關係或目標關係。

4、關係完整性約束

      關係模式中3類數據完整性約束:實體完整性、參照完整性、用戶自定義完整性,其中前兩種稱為關係的兩個不變性。

1)實體完整性:若屬性集A是關係r的主碼,則A不能取空值null,即主屬性不能為空。

2)參照完整性:主鍵與外鍵的關係,外碼的取值要麼為空,要麼為與之對應的主碼的值。

3)用戶自定義完整性:限制關係中某些屬性的取值、限制關係中某些屬性的取值之間需要滿足一定的邏輯關係、限制關係中某屬性集上的取值必須唯一。

5、關係模式中的關係操作:查詢操作(最主要部分)、更新操作。

特點:集合操作方式,即操作的對象和結果都是集合。該操作方式也稱為一次一集合方式,非關係數據模型的數據操作方式稱為一次一記錄方式。

6、傳統的集合運算:將關係看作元組的集合,從關係的水平方向來進行的。

1)並υ:rυs,由屬性r或屬性s的所有元組組成,刪去重覆元組。

2)差−:r−s,由屬性r的所有元素組成,從中刪除與屬性s相同的元組。

3)交∩:r∩s,由既屬於r又屬於s的所有元組組成,取相同的元組。

4)笛卡爾積×:r×s,關係r為n目元組的集合,關係s為m目元組的集合,結果為一個n+m目元組的集合,元組的前n列是關係r的一個元組,後m列是關係s的一個元組。 

7、關係運算

1)選擇σ:選出若幹行。是一個邏輯表達式,取值為“真”或“假”。

2)投影Π:選出若幹列,並從刪除重覆列。

3)連接(θ連接):從兩個關係的笛卡爾積中選取連接屬性間滿足謂詞θ的所有元組。

(1)等值連接:θ為等值比較謂詞的連接運算。

(2)自然連接:特殊的等值連接,要求兩個參與連接的關係具有公共的屬性集,併在該屬性集上進行等值連接,並去除重覆列。

(3)外連接:把不能連接的元組也保留到結果關係中,關係r中不能連接的元組在結果中對應於關係s的屬性全部置空。

(4)左外連接:把左關係中不能連接的元組保留到結果關係中。

(5)右外連接:把右關係中不能連接的元組保留到結果關係中。

4)除運算÷:求投影。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文主要介紹 COM 的基礎知識,傾向於理論性的理解,面向初學者,淺嘗輒止。 1. COM 是什麼: COM 的英文全稱是,Component Object Model,中文譯為,組件對象模型。它官方的概念是:The Microsoft Component Object Model (COM) is ...
  • 1、索引 1-1、索引的概述 我們把一個表中的一列或者多列和列中元素所在表中記錄的物理地址組合成一個新的表。這個表的記錄大致為列的內容和該列所在記錄的物理地址。 1-2、索引的優缺點 www.2cto.com 優點:大大加快了對源表的執行速度,我們對索引表的檢索就可以實現對源表的檢索。到底快在哪裡? ...
  • 很多程式員都學過MySQL,而且也會寫SQL語句。但僅僅會寫還遠遠不夠,在面試中以及在工作中,還必須要會事務和併發。 一、事務 事務是滿足 ACID 特性的操作,可以通過 Commit 提交事務,也可以使用 Rollback 進行回滾。 A(Atomicity)原子性:事務被視為不可分割的小單元,事 ...
  • 一、SDS 1、SDS結構體 redis3.2之前 :不管buf的位元組數有多少,都用 4位元組的len來儲存長度 ,對於只存短字元串那麼優點 浪費空間 ,比如只存 ,則 則只需要一個位元組8位即可表示 redis3.2之後: \__attribute__ ((\__packed__)) 關鍵字是為了取消 ...
  • MongoDB Limit() 方法 如果你需要在MongoDB中讀取指定數量的數據記錄,可以使用MongoDB的Limit方法,limit()方法接受一個數字參數,該參數指定從MongoDB中讀取的記錄條數。 語法 >db.COLLECTION_NAME.find().limit(NUMBER) ...
  • 1、SQL(結構化查詢語言)的組成:數據定義語言DDL、數據操縱語言DML、數據控制語言DCL、其他。 2、SQL語言的功能: 1)數據查詢:SELECT 2)數據定義:CREATE DROP ALTER 3)數據操縱:INSERT UPDATE DELETE 4)數據控制:GRANT REVOKE ...
  • 1.redis事務命令: 命令作用返回值 watch 監視一個或多個key 總是OK multi 聲明事務開始,後續命令將排隊按順序等待exec執行 總是OK exec 順序執行multi之後的命令,如果multi之前使用watch命令監視的鍵的值發生變化,執行將失敗 執行成功時返回數組包含每個命令 ...
  • <?php/** * $productTotal 商品總數 * $productSellNum 已售商品數量 * $currentBuyNum 當前購買數量 *///商品總數$productTotal = 100; //當前購買數量$currentBuyNum = 5; try { $redis = ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...