MySQL?數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)
1. 認(rèn)識(shí)數(shù)據(jù)庫(kù)
1.1 數(shù)據(jù)庫(kù)和數(shù)據(jù)結(jié)構(gòu)的關(guān)系
數(shù)據(jù)結(jié)構(gòu):
是指相互之間存在一種或多種特定關(guān)系的數(shù)據(jù)元素的集合,是一個(gè)抽象的學(xué)科
我們熟知的數(shù)據(jù)結(jié)構(gòu)有:
順序表、鏈表、棧、隊(duì)列、二叉樹、哈希表…
數(shù)據(jù)庫(kù):
和數(shù)據(jù)結(jié)構(gòu)不同,它是一類更具體的可以管理數(shù)據(jù)的軟件。但是實(shí)現(xiàn)數(shù)據(jù)庫(kù)的這個(gè)軟件,需要用到很多的數(shù)據(jù)結(jié)構(gòu)
而使用數(shù)據(jù)庫(kù)管理數(shù)據(jù)具體的功能就包括:
- 描述:描述一條數(shù)據(jù)如何表示
- 組織:如何將很多數(shù)據(jù)進(jìn)行匯總
至于管理的目的就是:
為了增刪改查
1.2 為什么需要數(shù)據(jù)庫(kù)
數(shù)據(jù)庫(kù)要將數(shù)據(jù)進(jìn)行管理的前提就是將數(shù)據(jù)進(jìn)行存儲(chǔ)。但是存儲(chǔ)數(shù)據(jù)使用文件就可以了,為什么還要弄個(gè)數(shù)據(jù)庫(kù)呢?
因?yàn)槭褂梦募4鏀?shù)據(jù)有以下幾個(gè)缺點(diǎn):
- 文件的安全性問(wèn)題
- 文件不利于數(shù)據(jù)查詢和管理
- 文件不利于存儲(chǔ)海量數(shù)據(jù)
- 文件在程序中控制不方便
1.3 數(shù)據(jù)庫(kù)的存儲(chǔ)
當(dāng)下絕大部分計(jì)算機(jī)都遵守著馮諾依曼體系結(jié)構(gòu)

數(shù)據(jù)的存儲(chǔ)一般放在內(nèi)存儲(chǔ)器和外存儲(chǔ)器(外存儲(chǔ)器包括:硬盤、光盤、U盤、軟盤等,但這里指硬盤)
數(shù)據(jù)庫(kù)是有多種的,并沒(méi)有統(tǒng)一規(guī)定所有數(shù)據(jù)庫(kù)存放的位置,但主要的數(shù)據(jù)庫(kù)的數(shù)據(jù)存儲(chǔ)位置如下:
- 大部分?jǐn)?shù)據(jù)庫(kù)是把數(shù)據(jù)組織在外存儲(chǔ)上,如:
MySQL、Oracle、SQL Server - 少數(shù)數(shù)據(jù)庫(kù)是把數(shù)據(jù)組織到內(nèi)存上,如:
Redis
補(bǔ)充: MySQL 為什么要把數(shù)據(jù)存儲(chǔ)在外存儲(chǔ)器(硬盤)中呢?這里我們就要先了解下內(nèi)存和硬盤的區(qū)別
| 區(qū)別 | 內(nèi)存 | 外存(硬盤) |
|---|---|---|
| 1 | 內(nèi)存的訪問(wèn)速度快 | 硬盤的訪問(wèn)速度慢 |
| 2 | 內(nèi)存的空間小 | 硬盤的空間大 |
| 3 | 內(nèi)存貴 | 硬盤便宜 |
| 4 | 如果掉電,內(nèi)存上的數(shù)據(jù)會(huì)丟失 | 如果掉電,硬盤的數(shù)據(jù)不會(huì)丟失 |
綜合以上2、3、4的區(qū)別,認(rèn)為 MySQL 使用硬盤來(lái)存儲(chǔ)數(shù)據(jù)更好
2. SQL
2.1 介紹
結(jié)構(gòu)化查詢語(yǔ)言(Structured Query Language)簡(jiǎn)稱 SQL,是一種特殊目的的編程語(yǔ)言,是一種數(shù)據(jù)庫(kù)查詢和程序設(shè)計(jì)語(yǔ)言,用于存取數(shù)據(jù)以及查詢、更新和管理關(guān)系數(shù)據(jù)庫(kù)系統(tǒng)
注意: SQL 和 MySQL 的區(qū)別
- SQL 是一種編程語(yǔ)言
- MySQL 是一種軟件,它屬于關(guān)系型數(shù)據(jù)庫(kù)的一種,而關(guān)系型數(shù)據(jù)庫(kù)都是支持 SQL 的,而非關(guān)系型數(shù)據(jù)庫(kù)有的支持,有的不支持 SQL
2.2 分類
SQL 可以分為6部分:
- 數(shù)據(jù)查詢語(yǔ)言(
DQL): 其語(yǔ)句也稱為“數(shù)據(jù)檢索語(yǔ)句”,用以從表中獲得數(shù)據(jù),確定數(shù)據(jù)怎樣在應(yīng)用程序給出。 - 數(shù)據(jù)操作語(yǔ)言(
DML): 其語(yǔ)句包括動(dòng)詞INSERT、UPDATE和DELETE。它們分別用于添加、修改和刪除。 - 事務(wù)控制語(yǔ)言(
TCL): 它的語(yǔ)句能確保被 DML 語(yǔ)句影響的表的所有行及時(shí)得以更新。包括COMMIT(提交)命令、SAVEPOINT(保存點(diǎn))命令、ROLLBACK(回滾)命令。 - 數(shù)據(jù)控制語(yǔ)言(
DCL): 它的語(yǔ)句通過(guò) GRANT 或 REVOKE 實(shí)現(xiàn)權(quán)限控制,確定單個(gè)用戶和用戶組對(duì)數(shù)據(jù)庫(kù)對(duì)象的訪問(wèn)。某些RDBMS可用 GRANT 或 REVOKE 控制對(duì)表單個(gè)列的訪問(wèn)。 - 數(shù)據(jù)定義語(yǔ)言(
DDL): 其語(yǔ)句包括動(dòng)詞 CREATE、ALTER 和 DROP。在數(shù)據(jù)庫(kù)中創(chuàng)建新表或修改、刪除表(CREATE TABLE 或 DROP TABLE)、為表加入索引等。 - 指針控制語(yǔ)言(CCL): 它的語(yǔ)句,像
DECLARE CURSOR、FETCH INTO和UPDATE WHERE CURRENT用于對(duì)一個(gè)或多個(gè)表單獨(dú)行的操作。
3. 數(shù)據(jù)庫(kù)的類別
數(shù)據(jù)庫(kù)大體可以分為:
- 關(guān)系型數(shù)據(jù)庫(kù)
- 非關(guān)系型數(shù)據(jù)庫(kù)
3.1 關(guān)系型數(shù)據(jù)庫(kù)
介紹:
- 是指采用了關(guān)系模型來(lái)組織數(shù)據(jù)的數(shù)據(jù)庫(kù)。簡(jiǎn)單來(lái)說(shuō),關(guān)系模型指的就是二維表格模型,而一個(gè)關(guān)系型數(shù)據(jù)庫(kù)就是由二維表格及其之間的聯(lián)系所組成的一個(gè)數(shù)據(jù)組織
- 關(guān)系型數(shù)據(jù)庫(kù)都基于標(biāo)準(zhǔn)的 SQL,只是內(nèi)部的一些實(shí)現(xiàn)有區(qū)別
常見(jiàn)關(guān)系型數(shù)據(jù)庫(kù):
Oracle:甲骨文產(chǎn)品,是數(shù)據(jù)庫(kù)中的王者。由于收費(fèi),且隨著數(shù)據(jù)量的增大對(duì)機(jī)器要求比較高,所以使用成本很高。適用于銀行這類對(duì)數(shù)據(jù)的安全和服務(wù)要求很高且本身很有錢的公司MySQL:被甲骨文收購(gòu),開源免費(fèi)?,F(xiàn)在很多公司普遍使用它SQL Server:微軟產(chǎn)品,由于曾經(jīng)這個(gè)數(shù)據(jù)庫(kù)和 windows server 系統(tǒng)進(jìn)行了捆綁,而大多數(shù)服務(wù)器系統(tǒng)都是在 Linux 上,所以逐漸失去市場(chǎng)。如今可以支持 Linux
3.2 非關(guān)系型數(shù)據(jù)庫(kù)
介紹:
非關(guān)系型數(shù)據(jù)庫(kù)一般指 NoSQL,區(qū)別于關(guān)系數(shù)據(jù)庫(kù),它們不保證關(guān)系數(shù)據(jù)的 ACID 特性,都是去掉關(guān)系數(shù)據(jù)庫(kù)的關(guān)系型特性
不規(guī)定基于 SQL 實(shí)現(xiàn)
常見(jiàn)非關(guān)系型數(shù)據(jù)庫(kù):
redis:基于鍵值對(duì)(key-value)mongodb:基于列族hbase:基于文檔型
3.3 區(qū)別
| 區(qū)別 | 關(guān)系型數(shù)據(jù)庫(kù) | 非關(guān)系型數(shù)據(jù)庫(kù) |
|---|---|---|
| 使用 SQL | 是 | 不強(qiáng)制要求,一般不基于 SQL 實(shí)現(xiàn) |
| 事務(wù)支持 | 支持 | 不支持 |
| 復(fù)雜操作 | 支持 | 不支持 |
| 海量讀寫操作 | 效率低 | 效率高 |
| 基本結(jié)構(gòu) | 基于表和列,結(jié)構(gòu)固定 | 靈活性比較高 |
| 使用場(chǎng)景 | 業(yè)務(wù)方面的 OLTP 系統(tǒng) | 用于數(shù)據(jù)的緩存或基于統(tǒng)計(jì)分析的 OLAP 系統(tǒng) |
補(bǔ)充:
OLTP(On-Line Transaction Processing):是指聯(lián)機(jī)事物處理OLAP(On-Line Analytical Processing):是指聯(lián)機(jī)分析處理
4. MySQL 的程序結(jié)構(gòu)
MySQL 其實(shí)是一個(gè)“客戶端-服務(wù)器”結(jié)構(gòu)的程序
那么什么是客戶端和服務(wù)器呢?下面將簡(jiǎn)單介紹
4.1 客戶端和服務(wù)器
介紹:
- 客戶端:是主動(dòng)發(fā)起請(qǐng)求的一方
- 服務(wù)器:是被動(dòng)接受請(qǐng)求的一方
- 客戶端給服務(wù)器發(fā)送的數(shù)據(jù),稱為:請(qǐng)求(
Request) - 服務(wù)器給客戶端返回的數(shù)據(jù),稱為:響應(yīng)(
Response) - 一個(gè)服務(wù)器同時(shí)可能給多個(gè)客戶端提供服務(wù)
- 大部分客戶端服務(wù)器都是這種“一個(gè)請(qǐng)求一個(gè)響應(yīng)”的交互模型
- 客戶端和服務(wù)器是通過(guò)網(wǎng)絡(luò)來(lái)通信的
示例:
你去飯店吃飯,你跟老板說(shuō)來(lái)一碗農(nóng)家一碗香,后面老板給你把你點(diǎn)的餐端上來(lái)。
此時(shí)你就是“客戶端”,飯店老板就是”服務(wù)器“,你跟老板點(diǎn)餐就是你的”請(qǐng)求“,老板把你點(diǎn)的餐端上來(lái)就是”響應(yīng)“。而一個(gè)老板其實(shí)可以服務(wù)多個(gè)客戶。
4.2 MySQL 的客戶端-服務(wù)器結(jié)構(gòu)
當(dāng)我們使用 MySQL 時(shí),我們其實(shí)會(huì)遇見(jiàn)以下幾種情況:
- 在同一臺(tái)主機(jī)安裝
MySQL客戶端和 MySQL 服務(wù)器(我們自己在個(gè)人電腦安裝時(shí)就是這種情況)
- MySQL 客戶端和
MySQL服務(wù)器分別在兩臺(tái)不同的主機(jī)上
- 實(shí)際工作中往往是下面這種情況,多臺(tái)主機(jī)的客戶端連接一臺(tái)主機(jī)的服務(wù)器
注意:
- MySQL 是把數(shù)據(jù)存儲(chǔ)在服務(wù)器上,服務(wù)器才是數(shù)據(jù)庫(kù)的本體,負(fù)責(zé)管理數(shù)據(jù)
- MySQL 客戶端其實(shí)就是一個(gè)非常簡(jiǎn)單的程序,僅僅是用來(lái)和用戶交互的。這個(gè)程序可能是:命令行程序、可視化界面的程序、自己代碼實(shí)現(xiàn)的程序
4.3 MySQL 服務(wù)器
介紹:
- MySQL 服務(wù)器其實(shí)含有若干個(gè)數(shù)據(jù)庫(kù)(每個(gè)數(shù)據(jù)庫(kù)視為是一組邏輯上的集合)
- 一個(gè)數(shù)據(jù)庫(kù)包含了若干個(gè)有關(guān)聯(lián)的表
- 一個(gè)表包含了若干行(每一行都有若干條記錄)
- 一行包含了若干列(每一列都有具體的類型要求)
示例:
假如有一個(gè) MySQL 服務(wù)器存儲(chǔ)著 CSDN 的數(shù)據(jù),它里面可能有3個(gè)數(shù)據(jù)庫(kù)。數(shù)據(jù)庫(kù)1存儲(chǔ)著:用戶信息、用戶排名、文章數(shù)量等數(shù)據(jù)。數(shù)據(jù)庫(kù)2存儲(chǔ)著:活動(dòng)內(nèi)容、投稿文章、獎(jiǎng)品信息等數(shù)據(jù)。數(shù)據(jù)庫(kù)2存儲(chǔ)著:視頻、資源等數(shù)據(jù)。而其中數(shù)據(jù)庫(kù)1中的例如用戶信息等數(shù)據(jù),它其實(shí)就是一個(gè)表,類似于 excel 表,而有關(guān)聯(lián)的幾個(gè)表,就組成了一個(gè)數(shù)據(jù)庫(kù)。
注意:
數(shù)據(jù)庫(kù)的含義其實(shí)要依照上下文,它可能是一門學(xué)科,也可能是一類軟件,有時(shí)也指一個(gè)服務(wù)器,有時(shí)還表示一個(gè)數(shù)據(jù)集合等
到此這篇關(guān)于MySQL 數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)的文章就介紹到這了,更多相關(guān)MySQL 數(shù)據(jù)庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫(kù)壓力
這篇文章主要為大家介紹了MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫(kù)壓力的技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
mysql 8.0.17 winx64(附加navicat)手動(dòng)配置版安裝教程圖解
這篇文章主要介紹了mysql 8.0.17 winx64(附加navicat)手動(dòng)配置版安裝教程圖解,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08
Mac系統(tǒng)下MySql下載MySQL5.7及詳細(xì)安裝圖解
這篇文章主要介紹了Mac系統(tǒng)下MySql下載MySQL5.7及詳細(xì)安裝圖解,本文圖文并茂給大家介紹的非常詳細(xì),需要的朋友可以參考下2017-11-11
MySQL數(shù)據(jù)庫(kù)索引的最左匹配原則
sql查詢用到索引的條件是必須要遵守最左前綴原則,本文就詳細(xì)的介紹了MySQL數(shù)據(jù)庫(kù)索引的最左匹配原則,感興趣的可以了解一下2021-11-11
MySQL的常見(jiàn)存儲(chǔ)引擎介紹與參數(shù)設(shè)置調(diào)優(yōu)
這篇文章主要介紹了MySQL的常見(jiàn)存儲(chǔ)引擎介紹與參數(shù)設(shè)置調(diào)優(yōu),需要的朋友可以參考下2018-03-03
SQL查詢超時(shí)的設(shè)置方法(關(guān)于timeout的處理)
為了優(yōu)化OceanBase的query timeout設(shè)置方式,特調(diào)研MySQL關(guān)于timeout的處理,下面與大家分享下處理記錄,感興趣的朋友可以參考下哈2013-04-04




