MySQL與PHP的基礎與應用專題之數(shù)據(jù)完整性
概述
從今天開始, 小白我將帶領大家一起來補充一下 數(shù)據(jù)庫的知識.
數(shù)據(jù)完整性
數(shù)據(jù)完整性 (Data Integrity) 指存儲在數(shù)據(jù)庫 (Databse) 中的數(shù)據(jù), 需要保證一致性和可靠性. 數(shù)據(jù)完整性可以防止數(shù)據(jù)庫中存在不符合語義規(guī)定的數(shù)據(jù)和防止因錯誤信息的輸入輸出造成無效操作.
數(shù)據(jù)完整性包括:
- 實體完整性: RDBMS 中一行代碼表示一個實體. 實體完整性就是保住每一個實體都能被區(qū)別
- 域完整性: 對列的輸入的要求, 通過限制類的數(shù)據(jù)類型, 格式或值的范圍來實現(xiàn)
- 參照完整性: 主要是表與表之間的關系, 可以通過外鍵來實現(xiàn)
- 自定義完整性: 借助存儲過程和觸發(fā)器實現(xiàn)
實體完整性
實體完整性 (Enity Integrity) 要求每張表都有唯一標識符, 每張表中的主鍵字段不能為空且不能重復.
例如:
- id
- 編號
域完整性
域完整性 (Domain Integrity) 是針對某一具體關系數(shù)據(jù)庫約束條件. 域完整性能保證表中某些列不能輸入無效的值.
例如:
- 數(shù)據(jù)類型
- 格式
- 值域范圍
- 是否允許空值
舉個例子, 當我們錄入工資數(shù)據(jù)的時候, 工資的范圍應該確保負數(shù)不會被錄入.
參照完整性
參照完整性 (Referential Integrity) 指關聯(lián)的兩個表之間的約束. 參照完整性保證了表中每條記錄外鍵的值必須是表中存在的.
自定完整性
自定義完整性是針對某一具體關系數(shù)據(jù)庫的約束條件. 自定義完整性反映某一具體應用所涉及的數(shù)據(jù)必須滿足語義要求.
唯一性
在 MySQL 中, 可以使用關鍵字UNIQUE
實現(xiàn)字段的唯一性約束, 從而保證實體的完整性.
UNIQUE 的特性:
- 使用 UNIQUE, 則表中兩條數(shù)據(jù)的同一個字段不能有相同值
- 一個表中可以有多個 UNIQUE 約束
PHP 代碼實現(xiàn):
<?php # 創(chuàng)建連接 $conn = mysqli_connect("localhost", "root", "admin", "study"); # 查看是否連接成功 if ($conn) { echo "服務器連接成功!"; } else { echo mysqli_connect_error(); } # SQL語句 (身份證帶唯一性) $SQL = "CREATE TABLE user_with_id ( id INT(8) AUTO_INCREMENT PRIMARY KEY comment '主鍵id', username VARCHAR(255) NOT NULL comment '姓名', id_number varchar(255) UNIQUE NOT NULL comment '身份證號' )"; # 執(zhí)行SQL語句 $result = mysqli_query($conn, $SQL); # 查看是否執(zhí)行成功 if ($result) { echo "SQL語句執(zhí)行成功!"; } else { echo mysqli_error($conn); } # 關閉連接 mysqli_close($conn); ?>
效果:
外鍵
外鍵 (Foreign KEY) 定義了表之間一致性, 用于強制參照完整性. 外鍵約束定義了對同一表或其他表的列的引用, 這些列具有 PRIMARY KEY 或 UNIQUE 約束.
創(chuàng)建主表 & 從表
<?php # 創(chuàng)建連接 $conn = mysqli_connect("localhost", "root", "admin", "study"); # 查看是否連接成功 if ($conn) { echo "服務器連接成功!"; } else { echo mysqli_connect_error(); } # SQL語句, 創(chuàng)建學生表 $SQL1 = "CREATE TABLE student ( student_id INT(8) PRIMARY KEY COMMENT '學生id', student_name VARCHAR(255) NOT NULL COMMENT '學生姓名' )"; # SQL語句, 創(chuàng)建成績表 $SQL2 = "CREATE TABLE grade ( id INT(8) AUTO_INCREMENT PRIMARY KEY COMMENT '主鍵id', student_id INT(8) NOT NULL COMMENT '學生id', course varchar(255) NOT NULL COMMENT '課程', grade INT(8) NOT NULL COMMENT '成績', FOREIGN KEY (student_id) references student(student_id) )"; # 執(zhí)行SQL語句 $result = mysqli_query($conn, $SQL1); # 查看是否執(zhí)行成功 if ($result) { echo "SQL語句執(zhí)行成功!"; } else { echo mysqli_error($conn); } # 執(zhí)行SQL語句 $result = mysqli_query($conn, $SQL2); # 查看是否執(zhí)行成功 if ($result) { echo "SQL語句執(zhí)行成功!"; } else { echo mysqli_error($conn); } # 關閉連接 mysqli_close($conn); ?>
效果:
插入數(shù)據(jù)
<?php # 創(chuàng)建連接 $conn = mysqli_connect("localhost", "root", "admin", "study"); # 查看是否連接成功 if ($conn) { echo "服務器連接成功!"; } else { echo mysqli_connect_error(); } # SQL語句, 向主表添加數(shù)據(jù) $SQL1 = "INSERT INTO student (student_id, student_name) VALUES(1, '我是小白呀'), (2, '我是大白呀')"; # 執(zhí)行SQL語句 $result = mysqli_query($conn, $SQL1); # SQL語句, 向從表添加數(shù)據(jù) $SQL2 = "INSERT INTO grade (student_id, course, grade) VALUES(1, '語文', 59), (2, '語文', 99)"; # 執(zhí)行SQL語句 $result = mysqli_query($conn, $SQL2); # 查看是否執(zhí)行成功 if ($result) { echo "SQL語句執(zhí)行成功!"; } else { echo mysqli_error($conn); } # 關閉連接 mysqli_close($conn); ?>
錯誤展示
<?php # 創(chuàng)建連接 $conn = mysqli_connect("localhost", "root", "admin", "study"); # 查看是否連接成功 if ($conn) { echo "服務器連接成功!"; } else { echo mysqli_connect_error(); } # SQL語句, 錯誤展示 (主表沒有student_id=3) $SQL = "INSERT INTO grade (student_id, course, grade) VALUES(3, '語文', 88)"; # 執(zhí)行SQL語句 $result = mysqli_query($conn, $SQL); # 查看是否執(zhí)行成功 if ($result) { echo "SQL語句執(zhí)行成功!"; } else { echo mysqli_error($conn); } # 關閉連接 mysqli_close($conn); ?>
報錯:
服務器連接成功!
Fatal error: Uncaught mysqli_sql_exception: Cannot add or update a child row: a foreign key constraint fails (`study`.`grade`, CONSTRAINT `grade_ibfk_1` FOREIGN KEY (`student_id`) REFERENCES `student` (`student_id`)) in C:\Users\Windows\Desktop\數(shù)據(jù)庫\外鍵錯誤.php:19
Stack trace:
#0 C:\Users\Windows\Desktop\數(shù)據(jù)庫\外鍵錯誤.php(19): mysqli_query(Object(mysqli), 'INSERT INTO gra...')
#1 {main}
thrown in C:\Users\Windows\Desktop\數(shù)據(jù)庫\外鍵錯誤.php on line 19
PHP Fatal error: Uncaught mysqli_sql_exception: Cannot add or update a child row: a foreign key constraint fails (`study`.`grade`, CONSTRAINT `grade_ibfk_1` FOREIGN KEY (`student_id`) REFERENCES `student` (`student_id`)) in C:\Users\Windows\Desktop\數(shù)據(jù)庫\外鍵錯誤.php:19
Stack trace:
#0 C:\Users\Windows\Desktop\數(shù)據(jù)庫\外鍵錯誤.php(19): mysqli_query(Object(mysqli), 'INSERT INTO gra...')
#1 {main}
thrown in C:\Users\Windows\Desktop\數(shù)據(jù)庫\外鍵錯誤.php on line 19
到此這篇關于MySQL與PHP的基礎與應用專題之數(shù)據(jù)完整性的文章就介紹到這了,更多相關MySQL 數(shù)據(jù)完整性內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
mysql使用xtrbackup+relaylog增量恢復注意事項
這篇文章主要介紹了mysql使用xtrbackup+relaylog增量恢復,本次實驗mysql5.7.19.使用了GTID,row格式的binlog,本文結合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2023-05-05MySQL使用mysqldump實現(xiàn)數(shù)據(jù)完全備份
mysqldump是MySQL自帶的備份工具,可方便實現(xiàn)對MySQL的備份,也可以將指定的庫、表導出為SQL腳本,下面小編就來教大家如何使用mysqldump實現(xiàn)數(shù)據(jù)完全備份吧2023-07-07Navicat數(shù)據(jù)存放位置和備份數(shù)據(jù)庫路徑設置方式
這篇文章主要介紹了Navicat數(shù)據(jù)存放位置和備份數(shù)據(jù)庫路徑設置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01淺析SQL語句行列轉換的兩種方法 case...when與pivot函數(shù)的應用
SQL語句行列轉換的兩種方法 case...when和pivot函數(shù)應用,運用pivot 函數(shù)只支持數(shù)據(jù)庫版本2005以上的。一般運用case when else end 的方法比較多,比較普遍2013-08-08mysql 5.7.11 winx64.zip安裝配置方法圖文教程
這篇文章主要為大家分享了mysql5.7.11安裝配置方法圖文教程,具有一定的參考價值,感興趣的朋友可以參考一下2017-02-02MySQL ERROR 1045 (28000) 錯誤的解決辦法
這篇文章主要介紹了MySQL ERROR 1045 (28000) 錯誤的解決辦法,很實用的解決方法,感興趣的小伙伴們可以參考一下2016-06-06