31. 資料庫基礎

hbutmeng發表於2024-10-09

1. 資料庫基礎知識

1.1 關係型資料庫與非關係型資料庫

1.2 關係型資料庫的結構

庫 Database

庫,也稱資料庫,用於組織、儲存和管理資料

類比於資料夾

表 Table

表,是資料庫中基本的資料儲存單位,由行(Row)和列(Column)組成

類比於excel檔案

記錄 Record

記錄,是表中的一行的所有資料

例如:在一個訂單表中,每一條記錄可能代表一個訂單所有資訊,包含訂單號、訂單日期、訂單金額等。

表頭 Header

表頭,是表格中列的名稱

可以看作是資料的結構化資訊,幫助使用者理解和運算元據

表單 Form

嚴格來說不直接屬於資料庫結構的一部分,但表單是一種常用的介面元素,用於收集並展示資料。

表單可以用於輸入、修改或查詢資料庫中的資料。

表單通常包含多個欄位,每個欄位對應資料庫表中的一個列。使用者透過填寫表單並提交,可以將資料填寫到資料庫中或更新現有資料。

2. SQL語句基礎概念

2.1 SQL語句規範

SQL語句不區分大小寫,為了提高程式碼的可讀性,建議採用統一的書寫規範。

關鍵字大寫:SELECT, FROM, WHERE, JOIN。

表名、列名小寫,用雙引號括起來以確保大小寫的敏感性。

字串與日期:字串與日期型別的資料應使用單引號' '括起來,單詞之間用英文半形空格隔開。

SQL語句可單行或多行書寫,預設以英文半形分號 ; 結尾,關鍵詞不能跨多行

單行註釋:--或#

多行註釋:

/*

註釋內容

*/

2.2 SQL語句型別

根據用途,SQL語句可以分為幾種主要型別:

1. 資料查詢語言 (DQL Data Query Language)
用於從一個或多個表中檢索資料。
主要命令是 SELECT。

2. 資料定義語言 (DDL Data Definition Language)
用於定義或改變資料庫結構。
常用命令包括:
CREATE:建立資料庫、表、檢視等。
ALTER:修改現有資料庫物件的結構。
DROP:刪除資料庫物件。
TRUNCATE:清除表中的所有資料但保留表結構。
RENAME:重新命名資料庫物件(某些資料庫系統可能使用不同的語法)。

3. 資料操縱語言 (DML Data Manipulation Language)
用於新增、更新和刪除資料庫中的資料。
常用命令包括:
INSERT:向表中插入新記錄。
UPDATE:更新表中的現有記錄。
DELETE:從表中刪除記錄。
MERGE:在某些資料庫中,用於基於條件更新或插入資料。

4. 事務控制語言 (TCL Transaction Control Language)
用於管理事務,確保資料的一致性和完整性。
常用命令包括:
COMMIT:提交當前事務,使更改永久化。
ROLLBACK:撤銷當前事務,恢復到事務開始前的狀態。
SAVEPOINT:設定儲存點,允許部分回滾事務。
SET TRANSACTION:設定事務的特性(如只讀、隔離級別等)。

5. 資料控制語言 (DCL Data Control Language)
用於控制資料庫訪問許可權。
常用命令包括:
GRANT:授予使用者特定許可權。
REVOKE:撤銷使用者的特定許可權。

6. 其他命令
還有一些其他的命令不屬於上述分類,例如:
EXPLAIN:顯示查詢計劃,幫助最佳化查詢效能。
SHOW:顯示資料庫資訊,如表結構、索引等。
USE:選擇當前工作的資料庫。
BEGIN 或 START TRANSACTION:開始一個新的事務。

2.3 常用命令

3. SQL語句操作庫、表、資料

3.1 運算元據庫(資料夾級別)---對庫的增刪改查

[1]建立資料庫

方法一:create database 資料庫名稱;

方法二:create database if not exists 資料庫名稱;    

    --資料庫不存在則建立,存在則忽略

方法三:create database if not exists 資料庫名稱 charset 字元編碼名稱;

    --latin1:西歐語言字符集

    --utf8mb4(當前中文預設):完整的utf-8編碼,支援所有Unicode字元,包括表情符號,一個字元最多佔4個位元組

    --gbk:簡體中文字符集

[2]檢視資料庫

系統自帶的資料庫:

檢視所有資料庫:

show databases;

模糊查詢,檢視名稱中包含指定字元的資料庫:

show databases like "%obj%";

檢視資料庫的建庫SQL語句:

show create database 資料庫名稱;

示例:

show create database test01;

show create database test02;

show create database test03;

[3]修改資料庫

修改資料庫預設的編碼集:

alter database 資料庫名稱 charset "utf8mb4";

舉例:將test03的字符集由gbk改為utf8mb4

[4]刪除資料庫

以下MySQL自帶的資料庫不能刪除

drop database [if exists] 資料庫名稱;    --中括號裡的內容表示可選

3.2 運算元據庫中的表(檔案級別)---對錶的增刪改查

[1]操作表之前的操作:進入到指定庫、檢視所在的庫

use 庫名稱;    --進入到指定庫

注意:進入到指定資料庫後無法退回到之前剛登入的狀態,但可以透過use進行切換

select database();    --檢視所在的庫

[2] 建立表

語法:

create table 表名(
       列名1 資料型別[(最多字元個數)]  [約束條件],
       列名2 資料型別[(最多字元個數)]  [約束條件],
       ...
       列名n 資料型別[(最多字元個數)]  [約束條件]
);

列名和資料型別必填,中括號裡的內容選填。

列名不可重複。

常見資料型別:

int:整數  括號內的引數預設為11,是顯示寬度,不影響儲存大小,不推薦使用

    有符號 INT
    位數: 32 位  4個位元組
    最小值: -2,147,483,648 (-2^31)
    最大值: 2,147,483,647 (2^31 - 1)
    無符號 INT
    位數: 32 位  4個位元組
    最小值: 0
    最大值: 4,294,967,295 (2^32 - 1)

varchar(n):變長字串,n是字串的最大長度  1~255,預設寬度為1,只能存1個字元
text:長文字
date:日期
datetime:日期和時間
decimal(m, n):小數,m是總位數,n是小數點後的位數

常見約束條件:

not null:不能為空值
primary key:主鍵,列(或列組合的)唯一標識,每個表可以有一個主鍵
unique:列的值必須唯一
default value:列的預設值
auto_increment:自增,通常用於主鍵,自動生成唯一的數字;一般與主鍵配合使用
check:檢查約束,確保列中的值滿足特定條件;MySQL 8.0.16之前的版本要使用觸發器才能實現check的約束功能
foreign key:外來鍵,用於在兩個表之間建立連線,確保參照完整性

主鍵寫法一:

create table product1(
      id int auto_increment primary key,
      name varchar(10) not null,
      unique(name),
      price decimal(10, 2),
      stock int default 20
);

主鍵寫法二:

create table product2( 
       id int auto_increment,
       name varchar(10) not null,
       unique(name),
       price decimal(10, 2),
       stock int default 20,
       primary key(id)
);

id是主鍵,且自增

name不允許為空,且必須唯一

price為小數

stock庫存為整型,預設值是20

[3]檢視錶

show tables;   --檢視庫下所有的表

show create table 表名;  --檢視建立表的SQL語句

檢視錶結構的兩種方法:

describe 表名;

desc 表名;  

[4] 修改表

修改表中的列:

alter table 表名 modify 列名 資料型別;  

  --modify只能修改列的資料型別,不能修改列名

alter table 表名 change 原列名 新列名 資料型別;

  --change既可以修改列的資料型別,又可以修改列名

修改表名:

alter table 原表名 rename 新表名;

新增列:

alter table 表名 add 列名 資料型別;  --預設在表的結尾新增列

alter table 表名 add 列名 資料型別 after 指定列名;   --在指定列的後面新增列

alter table 表名 add 列名 資料型別 first;  --在列的最前面新增列

刪除表中的列:

alter table 表名 drop 列名;

[5] 刪除表

drop table 表名;

  --執行該命令MySQL不會給出任何提示確認的資訊,一旦刪除無法恢復,建議先備份後刪除,或者重新命名錶代替刪除操作

[6] 以絕對路徑的形式操作不同的庫

create table test02.teacher(id int);  --在test01庫中操作test02庫新建一個表

[7] 重置表資訊

TRUNCATE table 表名;

保留表的結構,將表的記錄以及表的狀態回滾

3.3 操作表中的資料---對資料的增刪改查

[1] 增加資料

增加一行資料:

insert into 表名 (列1, 列2, 列3, ...) values (值1, 值2, 值3, ...);    

以上可以不向所有的列中都傳入資料,如果向所有列中傳入資料,可以簡寫為:insert into 表名 values (值1, 值2, 值3, ...);

增加多行資料:

insert into 表名 (列1, 列2, 列3, ...) values (值1, 值2, 值3, ...), (值1, 值2, 值3, ...), (值1, 值2, 值3, ...);

[2] 查詢資料

查詢表中全部資料:

select * from 表名;

檢視指定列的資料:

select 列1,列2,... from 表名;

[3] 修改資料

update 表名 set 列名=新值 where 篩選條件;

舉例:將name為toy的stock改為21

[4] 刪除資料

delete from 表名 where 篩選條件;    ---會刪除所有符合條件的資料

刪除stock為60的一行資料(記錄):

delete from t1 where stock=60;

刪除id大於1的記錄:

delete from t1 where id>1;

清空表中所有資料:

delete from 表名;

4. 儲存引擎

4.1 概念

儲存引擎是用於處理不同表型別的資料儲存、索引、資料檢索的技術,不同的儲存引擎提供了不同的儲存機制、索引型別、鎖定級別和事務支援。

資料庫使用儲存引擎進行建立、查詢、更新和刪除資料等操作。

4.2 MySQL中常見的儲存引擎

[1]InnoDB

是MySQL5.5及以後版本的預設儲存引擎

支援事務處理、行級鎖定、外來鍵約束以及崩潰恢復等高階功能。

[2]MyISAM

是MySQL5.5以前版本的預設儲存引擎

不支援事務處理

插入資料速度較快

[3]MEMORY

MEMORY儲存引擎將資料儲存在記憶體中

訪問速度極快

資料在資料庫重啟後會丟失

[4]Blackhole

黑洞引擎,接受所有資料寫入請求,但不實際儲存任何資料

用於測試或主從複製配置中的日誌記錄

4.3 檢視所有引擎

show engines;

4.4 檢視不同儲存引擎儲存資料的異同

[1] 使用不同的儲存引擎建表

[2] 表的檔案

[3] 表檔案的作用

InnoDB:

.frm:儲存了表的定義資訊,包括列名、型別等。

.ibd:儲存表的資料和索引

MyISAM:

.frm:儲存了表的定義資訊,包括列名、型別等。

.MYD:儲存表的資料

.MYI:儲存表的索引

MEMORY:

.frm:儲存了表的定義資訊,包括列名、型別等。

沒有資料檔案,資料儲存在記憶體中,重啟資料庫後資料會丟失。

Blackhole :

.frm:儲存了表的定義資訊,包括列名、型別等。

[4] 表中依次存入資料

[5] 檢視資料

Blackhole儲存引擎建立的表中沒有存入資料

memory儲存引擎建立的表在資料庫重啟後資料丟失

相關文章