1 MySQL約束概述

2021-10-24 13:21:44 字數 1021 閱讀 8439

在 mysql 中,約束是指對錶中資料的一種約束,能夠幫助資料庫管理員更好地管理資料庫,並且能夠確保資料庫中資料的正確性和有效性。

例如,在資料表中存放年齡的值時,如果存入 200、300 這些無效的值就毫無意義了。因此,使用約束來限定表中的資料範圍是很有必要的。

在 mysql 中,主要支援以下 6 種約束:

主鍵約束是使用最頻繁的約束。在設計資料表時,一般情況下,都會要求表中設定乙個主鍵。

主鍵是表的乙個特殊字段,該字段能唯一標識該表中的每條資訊。例如,學生資訊表中的學號是唯一的。

外來鍵約束經常和主鍵約束一起使用,用來確保資料的一致性。

例如,乙個水果攤,只有蘋果、桃子、李子、西瓜 4 種水果,那麼,你來到水果攤要買水果只能選擇蘋果、桃子、李子和西瓜,不能購買其它的水果。

3)唯一約束

唯一約束與主鍵約束有乙個相似的地方,就是它們都能夠確保列的唯一性。與主鍵約束不同的是,唯一約束在乙個表中可以有多個,並且設定唯一約束的列是允許有空值的,雖然只能有乙個空值。

例如,在使用者資訊表中,要避免表中的使用者名稱重名,就可以把使用者名列設定為唯一約束。

檢查約束是用來檢查資料表中,字段值是否有效的乙個手段。

例如,學生資訊表中的年齡欄位是沒有負數的,並且數值也是有限制的。如果是大學生,年齡一般應該在 18~30 歲之間。在設定欄位的檢查約束時要根據實際情況進行設定,這樣能夠減少無效資料的輸入。

非空約束用來約束表中的字段不能為空。例如,在學生資訊表中,如果不新增學生姓名,那麼這條記錄是沒有用的。

預設值約束用來約束當資料表中某個欄位不輸入值時,自動為其新增乙個已經設定好的值

例如,在註冊學生資訊時,如果不輸入學生的性別,那麼會預設設定乙個性別或者輸入乙個「未知」。

預設值約束通常用在已經設定了非空約束的列,這樣能夠防止資料表在錄入資料時出現錯誤。

以上 6 種約束中,乙個資料表中只能有乙個主鍵約束,其它約束可以有多個。

mysql優化(1) mysql事務

事務是mysql等關係型資料庫區別於nosql的重要方面 隨著發展nosql資料庫也開始有了事物的概念 是保證資料一致性的重要手段。本文將首先介紹mysql事務相關的基礎概念,然後介紹事務的acid特性,並分析其實現原理。事務由乙個或多個sql語句組成乙個整體,如果所有的語句執行成功那麼修改將會全部...

MySQL高階1 Mysql架構

安裝目錄 var lib mysql mysql資料庫檔案的存放路徑 usr share mysql 配置檔案目錄 usr bin 相關命令目錄 用於主從複製 預設是關閉的,記錄嚴重的錯誤資訊,每次啟動和關閉等詳細資訊 預設關閉,記錄查詢的sql語句,如果開啟會減低mysql的整體效能,因為記錄日誌...

1 Mysql架構分析

聯結器,例如jdbc。2.manageement services utilities 系統管理和控制工具。3.connection pool mysql連線池,接收請求,建立連線。4.sql inte ce sql介面 接受使用者命令,執行後續操作,並且返回sql的操作結果。5.parse 解析器...