約束、索引、三範式

来源:https://www.cnblogs.com/gaojinshun/archive/2019/04/30/10744134.html
-Advertisement-
Play Games

1.約束的定義: 約束(constraint):在建表時,為某些列添加一些特定的規則,這些規則稱為約束。約束是在表上強制執行的數據校驗規則保證資料庫的數據滿足某種用戶的要求。添加約束之後,再往表中(插入、更新)數據時,如果數據不滿足約束,則該條語句不能執行。 2.約束的分類: 2.1 非空約束 no ...


1.約束的定義:

  約束(constraint):在建表時,為某些列添加一些特定的規則,這些規則稱為約束。約束是在表上強制執行的數據校驗規則保證資料庫的數據滿足某種用戶的要求。添加約束之後,再往表中(插入、更新)數據時,如果數據不滿足約束,則該條語句不能執行。

2.約束的分類:

2.1 非空約束 not null

非空約束確保欄位值不允許為空
非空約束只能在欄位級定義

-- not null 非空約束
--添加了 not null的列的值不能為null,但可以是空格
create table test01( 
empno number(4) ,
ename varchar2(10) not null
)

2.2 唯一約束 unique

唯一性約束條件確保所在的欄位或者欄位組合不出現重覆值
唯一性約束條件的欄位允許出現空值

--unique 唯一鍵約束
--添加了unique 約束的列的值是唯一的,不能出現重覆的值,但可以有多個null值
create table test02 (
empno number(4) unique,
 ename varchar2(10)
 );
--非空且唯一
--允許同時添加not null和unique表示不能重覆並且不能為null
create table test03 (
empno number(4) not null unique,e
name varchar2(10) );

2.3 自定義檢查約束 check

check約束用於對一個屬性的值加以限制。
在check中定義檢查的條件表達式,在對數據進行插入或修改需要符合設置的條件。

--check 自定義檢查約束
--在插入或修改數據時,值要符合check中定義的條件
create table test04(
empno number(4),
ename varchar2(10),
age number(3) check(age>0 and age<200),
gender varchar2(3) check(gender='' or gender='')
)

2.4 主鍵約束 primary key

主鍵約束是資料庫中最重要的一種約束。在關係中,主鍵值不可為空,也不允許出現重覆,即關係要滿足實體完整性規則。
– 主鍵從功能上看相當於非空且唯一
– 一個表中叧允許一個主鍵
– 主鍵是表中能夠唯一確定一個行數據的欄位
– 主鍵欄位可以是單欄位戒者是多欄位的組合(聯合主鍵)
– Oracle為主鍵創建對應的唯一性索引

--主鍵約束從形式可看成類非空且唯一
create table test05(
empno number(4) primary key,
ename varchar2(10)
)
--聯合主鍵
--一張表只有一個主鍵,但可以選擇多個列,作為聯合主鍵
create table test06(
empno number(4),
ename varchar2(10),
constraint pk_no_name primary key(empno,ename)
--在列中添加約束可以不給約束命名,沒有命名系統會自動命名
--在表中添加約束就需要手動命名
)

2.5 外鍵約束 foreign key


外鍵是表中的一個列,它的值依賴於另一張表的主鍵或者唯一鍵被依賴的表稱為主表,

存在外鍵的表稱為從表外鍵的值必須是主表(指定的)主鍵或者唯一鍵中列出

註:
對於主表的刪除和修改主鍵值的操作,會對依賴關係產生影響,以刪除為例:當要刪除主表的某個主鍵值(依賴的,那麼對依賴的影
響可採取下列3種做法:
1. RESTRICT方式(預設,無法刪除):只有當從表中沒有一個外鍵值與要刪除的主表中主鍵值相對應時,才可執行刪除操作。
2. CASCADE方式(聯級刪除):將從表中所有外鍵值與主表中要刪除的主鍵值相對應的記錄一起刪除
3. SET NULL方式(設置為空):將從表中所有與主表中被刪除的主鍵值相對應的外鍵值設為空值

添加外鍵約束語法:
外鍵列 REFERENCES 表名(主鍵列)
[ON DELETE [CASCADE|SET NULL]] 如省略on短語,預設按第一種處理方式。

--主表
create table t_dept(
deptno number(2) primary key,
dname varchar2(12)
)

--從表
create table t_emp(
empno number(4),
ename varchar2(10),
--添加外鍵,指定主鍵刪除處理方式
deptno number(2) references t_dept(deptno) on delete set null
) 

3.添加和修改約束

可增加或刪除約束,但不能直接修改
語法:
增加
alter table 表名 add constraint 約束名 unique(列名)
刪除
alter table 表名 drop constraint 約束名 [cascade] (加了cascade就為聯級刪除)


4.索引

4.1 概念:

索引是為了加快對數據的搜索速度而設立的。類似於一本書的目錄,資料庫對錶數據進行查詢時可以通過索引快速定位到數據。索引是非顯示的,在創建之後不會再用到,但查詢數據時索引會自動起作用。

4.2 索引創建的兩種情況:

1. 自動: 當在表上定義一個PRIMARY KEY 或者UNIQUE 約束條件時,Oracle資料庫自動創建一個對應的唯一索引。
2. 手動: 手動在某個或多個列上創建索引以加速查詢
語法:CREATE INDEX index 索引名 ON 表名 (列1[,列2]...);
在多個列上創建索引時,需要對多個列同時進行查詢,索引才會起作用

4.3 使用索引需註意:

1. 索引提高檢索操作的性能,但降低數據插入、修改和刪除的性能。在執行這些操作時,DBMS(資料庫管理系統)必須動態地更新索引。
2.索引數據可能需要占用大量空間
3.經常出現重覆的數據不適合使用索引
4.在多個列上創建索引時,需要對多個列同時進行查詢,索引才會起作用

4.4 刪除索引:

語法: drop index 索引名

5. 資料庫設計三範式:

資料庫的設計主要包含了設計表結構和表之間的聯繫,在設計的過程中,應該遵守三範式:
第一範式:資料庫表中的每一個列都必須是不可分割的基礎數據項。例如:“地址”應該拆分成省份、城市、詳細地址等多個部分進行存儲
第二範式:確保表中每列都與主鍵相關
第三範式:一個資料庫表中不能包含已在其它表中已包含的非主關鍵字信息。


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

-Advertisement-
Play Games
更多相關文章
  • 如果不使用checkpoint,文件數會劇增 參考:https://docs.microsoft.com/zh-cn/sql/relational-databases/logs/database-checkpoints-sql-server?view=sql-server-2017 文件還沒有計算完... ...
  • 解決同一程式被並行同時調用時,出現資源等待錯誤問題。 使用DBMS_LOCK.sleep (10); PROCEDURE prc_lock_test(v_engine_id in varchar, v_flag_desc in varchar, v_sysdate in varchar, exitc ...
  • 目前大數據行業異常火爆,不少人都對大數據充滿了興趣,其中有大部分人都是之前沒有接觸過電腦技術的,對編程語言也不太瞭解,那是不是這部分零基礎的朋友就學不了大數據了呢?答案當然是否定的。大數據學習並不是高深莫測的,雖然它並沒有多簡單,但是通過努力,零基礎的朋友也是完全可以掌握大數據的。 推薦一個大數據 ...
  • 創建類型名稱:LOGGER_FACTORY Type 說明: CREATE OR REPLACE TYPE "LOGGER_FACTORY" AS OBJECT( v_program_owner VARCHAR2(100), v_program_name VARCHAR2(100), v_progr ...
  • [20190423]oradebug peek測試腳本.txt--//工作測試需要寫一個oradebug peek測試腳本,不斷看某個區域記憶體地址的值。1.環境:SCOTT@book> @ ver1PORT_STRING VERSION BANNER x86_64/Linux 2.4.xx 11.2 ...
  • 筆記記錄自林曉斌(丁奇)老師的《MySQL實戰45講》 (本篇內圖片均來自丁奇老師的講解,如有侵權,請聯繫我刪除) 20) --幻讀是什麼,幻讀有什麼問題? 我們先來看看表結構和初始化數據: 表t除主鍵id外還有一個索引c,初始化語句在表中插入了6行數據。那麼如果有下麵這樣一段語句 請問是怎麼加鎖的 ...
  • 本總結來自美團內部分享,屏蔽了內部數據與工具 知識準備 索引 索引是存儲引擎用於快速找到記錄的一種數據結構 B Tree,適用於全鍵值,鍵值範圍或鍵最左首碼:(A,B,C): A, AB, ABC,B,C,BC 哪些列建議創建索引:WHERE, JOIN , GROUP BY, ORDER BY等語 ...
  • 本次主要介紹flink1.5.1版本的本地環境安裝部署,該版本要求jdk版本1.8以上。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...