mysql約束和高級(jí)sql詳解
約束
MySQL中的約束用于定義表中數(shù)據(jù)的規(guī)則,以確保數(shù)據(jù)的準(zhǔn)確性和可靠性。以下是MySQL中常用的一些約束類(lèi)型及其概述:
- PRIMARY KEY(主鍵):唯一標(biāo)識(shí)表中每條記錄的字段或字段組合, 一個(gè)表中只能有一個(gè)主鍵。
- 主鍵字段的值不能為NULL。
- FOREIGN KEY(外鍵):用于建立兩個(gè)表之間的關(guān)系,確保引用的數(shù)據(jù)的完整性,外鍵字段的值必須在它所引用的表中存在,或者為NULL(取決于外鍵約束的設(shè)置)。
- UNIQUE(唯一約束):保證列中的所有值都是唯一的,即不允許有重復(fù)的值
- NOT NULL(非空約束):確保列中的值不能為NULL。
- CHECK(檢查約束):用于限制列中的值必須滿(mǎn)足的條件。(在MySQL 8.0.16及更高版本中支持)
- DEFAULT(默認(rèn)值):當(dāng)沒(méi)有為列提供值時(shí),將使用默認(rèn)值。
- AUTO_INCREMENT(自增):用于整數(shù)類(lèi)型的列,自動(dòng)為新記錄生成一個(gè)唯一的數(shù)字。
高級(jí)sql
MySQL 提供了多種高級(jí)功能來(lái)處理復(fù)雜的數(shù)據(jù)操作和業(yè)務(wù)邏輯。以下是你提到的幾個(gè)關(guān)鍵概念的簡(jiǎn)要介紹:
1.子查詢(xún)(Subquery):子查詢(xún)是嵌套在另一個(gè)查詢(xún)中的 SQL 查詢(xún)。它可以返回單個(gè)值、一行或多行結(jié)果。子查詢(xún)通常用在SELECT、INSERT、UPDATE和DELETE語(yǔ)句中,可以用于條件表達(dá)式或作為值提供者。
SELECT name, MAX(salary) AS max_salary FROM employees WHERE salary = ( SELECT MAX(salary) FROM salaries );
首先確定 salaries 表中最高的薪資是多少,然后在外層查詢(xún)中查找 employees 表中薪資等于這個(gè)最高值的員工信息。
2. 連接(JOIN):連接用于結(jié)合兩個(gè)或多個(gè)表的行,基于相關(guān)的列。MySQL 支持多種類(lèi)型的連接,包括內(nèi)連接、左連接、右連接和全連接(FULL JOIN)。
SELECT books.title, authors.name FROM books INNER JOIN authors ON books.author_id = authors.id;
這個(gè)查詢(xún)的結(jié)果將是一個(gè)包含兩列的表 books.title 和 authors.name,每一行都對(duì)應(yīng)一個(gè)書(shū)籍及其作者的名稱(chēng)。
3.事務(wù) (Transaction) : 事務(wù)用于處理操作量大,復(fù)雜度高的數(shù)據(jù)。事務(wù)是一組SQL語(yǔ)句的集合,它們要么全部成功執(zhí)行,要么全部不執(zhí)行,把一系列的操作放在一個(gè)地方,然后再?zèng)Q定是否生效。這種特性被稱(chēng)為原子性(Atomicity)。事務(wù)還必須滿(mǎn)足一致性(Consistency)、隔離性(Isolation)和持久性(Durability)這三個(gè)特性,通常合稱(chēng)為ACID特性。
事務(wù)的基本操作MySQL通過(guò)以下三個(gè)主要的SQL語(yǔ)句來(lái)管理事務(wù):
- START TRANSACTION 或 BEGIN:標(biāo)記事務(wù)的開(kāi)始。
- COMMIT:提交事務(wù),將事務(wù)中的所有更改永久保存到數(shù)據(jù)庫(kù)中。
- ROLLBACK:回滾事務(wù),撤銷(xiāo)自事務(wù)開(kāi)始以來(lái)的所有更改,使數(shù)據(jù)庫(kù)回到事務(wù)開(kāi)始前的狀態(tài)。
自動(dòng)提交模式默認(rèn)情況下,MySQL在執(zhí)行每個(gè)SQL語(yǔ)句后會(huì)自動(dòng)提交事務(wù)。但是,你可以通過(guò)設(shè)置autocommit變量來(lái)控制這個(gè)行為:
- SET autocommit=OFF或SET autocommit=0:關(guān)閉自動(dòng)提交,這樣就需要顯式地使用COMMIT或ROLLBACK來(lái)結(jié)束事務(wù)。
- SET autocommit=ON或SET autocommit=1:開(kāi)啟自動(dòng)提交,每個(gè)SQL語(yǔ)句執(zhí)行后都會(huì)自動(dòng)提交。
事務(wù)的使用示例:
-- 開(kāi)始事務(wù) START TRANSACTION; -- 給學(xué)生ID為1的學(xué)生增加10分 UPDATE student_scores SET score = score + 10 WHERE student_id = 1; -- 檢查是否更新成功 IF (SELECT ROW_COUNT()) > 0 THEN -- 如果更新成功,提交事務(wù) COMMIT; -- 查詢(xún)更新后的結(jié)果 SELECT * FROM student_scores WHERE student_id = 1; ELSE -- 如果更新失敗,回滾事務(wù) ROLLBACK; -- 查詢(xún)當(dāng)前的分?jǐn)?shù),確認(rèn)沒(méi)有變化 SELECT * FROM student_scores WHERE student_id = 1; END IF;
正確使用事務(wù)可以確保數(shù)據(jù)庫(kù)操作的原子性和一致性,避免數(shù)據(jù)不一致的問(wèn)題。
4.存儲(chǔ)過(guò)程: MySQL存儲(chǔ)過(guò)程是一組為了完成特定功能的SQL語(yǔ)句集合,它被編譯并存儲(chǔ)在數(shù)據(jù)庫(kù)中,可被多次調(diào)用執(zhí)行,使用存儲(chǔ)過(guò)程可以提高性能,加強(qiáng)可維護(hù)性。
1.創(chuàng)建存儲(chǔ)過(guò)程
- DELIMITER:改變MySQL的命令結(jié)束符,因?yàn)榇鎯?chǔ)過(guò)程中會(huì)用;作為SQL語(yǔ)句的結(jié)束,如果不改變結(jié)束符,MySQL會(huì)錯(cuò)誤地在第一個(gè);處結(jié)束存儲(chǔ)過(guò)程的定義。
- CREATE PROCEDURE:用來(lái)創(chuàng)建新的存儲(chǔ)過(guò)程。
- 參數(shù):存儲(chǔ)過(guò)程可以有參數(shù),參數(shù)有三種類(lèi)型:IN(輸入?yún)?shù))、OUT(輸出參數(shù))和INOUT(既可輸入也可輸出)。
2.存儲(chǔ)過(guò)程體
- BEGIN ... END:存儲(chǔ)過(guò)程的主體部分,包含了要執(zhí)行的SQL語(yǔ)句。
- DECLARE:用來(lái)聲明局部變量。
- SET:用來(lái)給變量賦值。
示例:
DELIMITER // CREATE PROCEDURE SumTwoNumbers(IN num1 INT, IN num2 INT, OUT result INT) BEGIN SET result = num1 + num2; END // DELIMITER ;
- DELIMITER //改變了MySQL的默認(rèn)分隔符,這樣我們就可以在存儲(chǔ)過(guò)程內(nèi)部使用分號(hào)。
- CREATE PROCEDURE SumTwoNumbers 創(chuàng)建了一個(gè)名為 SumTwoNumbers 的存儲(chǔ)過(guò)程。
- IN num1 INT, IN num2 INT 定義了兩個(gè)輸入?yún)?shù) num1 和 num2 ,它們都是整數(shù)類(lèi)型。
- OUT result INT 定義了一個(gè)輸出參數(shù) result ,它也是整數(shù)類(lèi)型,用于存儲(chǔ)計(jì)算結(jié)果。
- SET result = num1 + num2; 是存儲(chǔ)過(guò)程的核心,它將兩個(gè)輸入?yún)?shù)相加,并將結(jié)果賦值給輸出參數(shù) result 。
- END 標(biāo)記了存儲(chǔ)過(guò)程的結(jié)束。
- DELIMITER ; 將分隔符重置回默認(rèn)的分號(hào)。
如果要調(diào)用該存儲(chǔ)內(nèi)容:
CALL SumTwoNumbers(10, 20, @sumResult); SELECT @sumResult;
到此這篇關(guān)于mysql約束和高級(jí)sql的文章就介紹到這了,更多相關(guān)mysql約束和高級(jí)sql內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
通過(guò)Query Profiler查看MySQL語(yǔ)句運(yùn)行時(shí)間的操作方法
這篇文章主要介紹了通過(guò)Query Profiler查看MySQL語(yǔ)句運(yùn)行時(shí)間的操作方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03詳解Mysql自動(dòng)備份與恢復(fù)的幾種方法(圖文教程)
本篇文章主要介紹了Mysql 自動(dòng)備份與恢復(fù),主要有三種方法,有需要的可以了解一下。2016-11-11MySQL同步數(shù)據(jù)Replication的實(shí)現(xiàn)步驟
本文主要介紹了MySQL同步數(shù)據(jù)Replication的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03Mysql中批量替換某個(gè)字段的部分?jǐn)?shù)據(jù)(推薦)
這篇文章主要介紹了Mysql中批量替換某個(gè)字段的部分?jǐn)?shù)據(jù),通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02MySQL安裝第四步報(bào)錯(cuò)(initializing?database報(bào)錯(cuò))的圖文解決方法
這篇文章主要給大家介紹了關(guān)于MySQL安裝第四步報(bào)錯(cuò)(initializing?database報(bào)錯(cuò))的解決方法,"initializing?database"?通常出現(xiàn)在安裝MySQL的過(guò)程中,表示MySQL數(shù)據(jù)庫(kù)初始化過(guò)程中遇到了問(wèn)題,需要的朋友可以參考下2024-06-06使用dreamhost空間實(shí)現(xiàn)MYSQL數(shù)據(jù)庫(kù)備份方法
使用dreamhost空間實(shí)現(xiàn)MYSQL數(shù)據(jù)庫(kù)備份方法...2007-07-07php mysql insert into 結(jié)合詳解及實(shí)例代碼
在mysql中如果要保存數(shù)據(jù)到數(shù)據(jù)庫(kù)我們就會(huì)用到insert into命令了,下面我來(lái)給大家介紹mysql insert into幾種常用的使用方法,需要的朋友可以參考下2016-11-11MySQL物理備份與恢復(fù)工具XtraBackup使用小結(jié)
本文主要介紹了MySQL物理備份與恢復(fù)工具XtraBackup使用小結(jié),借助Percona XtraBackup工具實(shí)現(xiàn)MySQL的物理備份與恢復(fù),相當(dāng)于將整個(gè)MySQL進(jìn)行了復(fù)制,再粘貼到其他地方運(yùn)行,感興趣的可以了解一下2024-07-07Mysql日期格式以及內(nèi)置日期函數(shù)用法詳解
MySQL中有多種數(shù)據(jù)類(lèi)型可以用于日期和時(shí)間的表示,這篇文章主要給大家介紹了關(guān)于Mysql日期格式以及內(nèi)置日期函數(shù)用法的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05