1. 程式人生 > >MySQL8資料庫 | MySQL調優|MySQL底層原理|MySQL零基礎新手教程

MySQL8資料庫 | MySQL調優|MySQL底層原理|MySQL零基礎新手教程

## MySQL8資料庫安裝 ### 一、Windows 環境下安裝 #### A、[下載 MySQL](https://dev.mysql.com/downloads/mysql/) Select Operating System: `Microsoft Windows` 快捷下載:[mysql-8.0.22-winx64.zip](https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.22-winx64.zip) #### B、解壓並配置MySQL環境變數 ```wiki MYSQL_HOME: C:\MySQL\mysql-8.0.22-winx64 ``` #### C、在解壓根目錄建立`my.ini`配置檔案 ```ini [mysqld] #設定3306埠 port = 3306 # 設定mysql的安裝目錄 basedir=C:/MySQL/mysql-8.0.22-winx64 # 設定mysql資料庫的資料的存放目錄 datadir=C:/MySQL/mysql-8.0.22-winx64\data # 允許最大連線數 max_connections=200 # 允許連線失敗的次數。這是為了防止有人從該主機試圖攻擊資料庫系統 max_connect_errors=10 # 服務端使用的字符集預設為utf8 character-set-server=utf8mb4 # 建立新表時將使用的預設儲存引擎 default-storage-engine=INNODB # 預設使用 “mysql_native_password” 外掛認證 default_authentication_plugin=mysql_native_password [mysql] # 設定mysql客戶端預設字符集 default-character-set=utf8mb4 [client] # 設定mysql客戶端連線服務端時預設使用的埠 port=3306 # 設定mysql客戶端連線服務端時預設使用的字符集 default-character-set=utf8mb4 ``` #### D、安裝 MySQL (以下操作必須是管理員身份) 1) 初始化MySQL ```bash mysqld --defaults-file=C:\MySQL\mysql-8.0.22-winx64\my.ini --initialize --console ``` **注意**:複製儲存 MySQL初始化密碼 `fVdpg:bM9pAk` 2) 安裝MySQL服務 ``` mysqld --install mysql8 ``` 3) 啟動MySQL服務 ``` net start mysql8 ``` #### E、登入、修改密碼 1) 登入 MySQL ```bash mysql -u賬號 -p密碼 ``` >使用上面方式無法登入的解決方案 > >1、停止 mysql8 `net stop mysql8` > >2、無密碼啟動 `mysqld --console --skip-grant-tables --shared-memory` > >3、前面視窗不能關閉,再開啟一個新的視窗進行無密碼登入 `mysql -u root -p` > >4、清空密碼 `update mysql.user set authentication_string='' where user='root' and host='localhost;'` > >5、重新整理許可權 `plush privilege;` > >6、重新啟動 mysql 服務,再以無密碼登入 mysql 2) 登入後使用MySQL修改密碼 ```mysql ALTER USER root@localhost IDENTIFIED BY '123456'; ``` 3) 開啟遠端訪問 ```mysql CREATE USER 'root' @'%' IDENTIFIED BY '123456'; -- 這一步執行失敗也沒關係 GRANT ALL ON *.* TO 'root' @'%'; # alter user 'root'@'%' identified with mysql_native_password by '123456'; FLUSH privilege; ``` ## 二、Linux 環境下安裝 #### A、[下載 MySQL](https://dev.mysql.com/downloads/mysql/) Select Operating System: `Source Code` Select OS Version: `Generic Linux (Architecture Independent) ` 快捷下載:[mysql-8.0.22.tar.gz](https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.22.tar.gz) #### B、把下載的 MySQL 壓縮包上傳到 Linux 伺服器 #### C、解壓`mysql-8.0.22.tar.gz` ```bash tar -zxvf mysql-8.0.22.tar.gz ``` #### D、把解壓後的檔案移動到 /usr/local 目錄下 ```bash mv mysql-8.0.22 /usr/local/mysql ``` #### E、新增MySQL組合使用者 (預設會新增,沒有新增就手動新增) ```bash groupadd mysql useradd -r -g mysql mysql ``` #### F、進入 `/usr/local/mysql` 目錄,修改相關許可權 ```bash cd /usr/local/mysql chown -R mysql:mysql ./ ``` #### G、MySQL初始化操作,記錄臨時密碼 ```bash cd /usr/local/mysql/bin ./mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data ``` **注意**:複製儲存 MySQL初始化密碼 `fVdpg:bM9pAk` #### H、建立MySQL配置檔案 `/etc/my.cnf` ```bash cd /etc vi my.cnf ``` **my.cnf** ```cnf [mysqld] port = 3306 basedir=/usr/local/mysql datadir=/usr/local/mysql/data max_connections=200 max_connect_errors=10 character-set-server=utf8mb4 default-storage-engine=INNODB default_authentication_plugin=mysql_native_password [mysql] default-character-set=utf8mb4 [client] port=3306 default-character-set=utf8mb4 ``` #### I、啟動MySQL服務 ```bash cd /usr/local/mysql/support-files ./mysql.server start ``` #### J、通過臨時密碼登入MySQL並修改密碼 ```bash cd /usr/local/mysql/bin ./mysql -u root -p生成的臨時密碼 ALTER USER 'root' @'localhost' IDENTIFIED BY '123456'; ``` #### K、開啟遠端訪問 ```bash CREATE USER 'root' @'%' IDENTIFIED BY '123456'; -- 這一步執行失敗也沒關係 GRANT ALL ON *.* TO 'root' @'%'; FLUSH privilege; ``` ## MySQL 資料庫操作 #### 資料庫操作 **建立資料庫** ```mysql CREATE DATABASE db_name DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; ``` **查詢資料庫** ```mysql -- 查詢所有資料庫 SHOW DATABASES; -- 查詢資料庫建表時的sql指令碼 SHOW CREATE DATABASE db_name; ``` **刪除資料庫** ```mysql DROP DATABASE db_name; ``` **修改資料庫** ```mysql -- 修改資料庫的字元編碼和排序方式 ALTER DATABASE db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; ``` **選擇資料庫** ```mysql USE db_name; ``` **設定操作的編碼格式** ```mysql SET NAMES utf8; ``` #### 表操作 ##### 建立表 > CREATE TABLE tb_name (建表的欄位、型別、長度、約束、預設、註釋) **約束** * 非空 `NOT NULL` * 非負 `UNSIGNED` * 主鍵 `PRIMARY KEY` * 自增 `AUTO_INCREMENT` * 預設 `DEFAULT` * 註釋 `COMMENT` ```mysql -- 資料庫存在就刪除 DROP DATABASE IF EXISTS testdb; -- 建立資料庫的操作 CREATE DATABASE IF NOT EXISTS testdb; -- 使用資料庫 USE testdb; -- 資料表存在就刪除 DROP TABLE IF EXISTS testdb; -- 建立表的操作 CREATE TABLE IF NOT EXISTS tb_test ( test_id INTEGER ( 10 ), test_name VARCHAR ( 50 ) ); ``` ```mysql -- 使用資料庫 USE testdb; -- 資料表存在就刪除 DROP TABLE IF EXISTS testdb; -- 建立表的操作 CREATE TABLE IF NOT EXISTS tb_test ( test_id INTEGER (10) AUTO_INCREMENT PRIMARY KEY COMMENT '測試ID', test_name VARCHAR (50) NOT NULL COMMENT '測試名稱', test_password VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '測試密碼' ); ``` **常用型別** * 極小整形 `TIYINT` 1個位元組,無符號最大值 256 (2^8 -1),正負 -128 ~ 127 (-2^7 -1 ~ 2^7 -1) * 小整形 `SMALLINT` 2個位元組,無符號最大值 65535 (2^16 - 1),正負 -32768 ~ 32767 (-2^15 - 1 ~ 2^15 - 1) * 中整形 `MEDIUMINT` 3個位元組,無符號最大值 16777215 (2^24 - 1),正負 (-2^23-1 ~ 2^23-1) * 整形 `INT` 4個位元組,無符號最大值 2^32 -1,正負 (-2^31-1 ~ 2^31-1) * 長整形 `BIGINT` 8個位元組,無符號最大值 2^64 - 1, 正負 (-2^63-1 ~ 2^63-1) * 單精度 `FLOAT` 4個位元組 Float [(M,D)] -3.4E+38~3.4E+38( 約 ) * 雙精度 `DOUBLE` 8個位元組 Double [(M,D)] -1.79E+308~1.79E+308( 約 ) * 小數值 `DECIMAL` `M>D ? M+2 : D+2` 個位元組 Decimal [(M,D)] 注:M 為長度, D 為小數 * 定長字串`CHAR` 最大儲存255個位元組,如果值沒有達到給定的長度,使用空格補充 * 變長字串`VARCHAR` 最大儲存255個位元組,用多大長度佔多大長度 * 極小文字 `TINYTEXT` 最大長度255個位元組(2^8-1) * 中文字 `MEDIUMTEXT` 最大長度 16777215 個位元組(2^24-1) * 文字 `TEXT` 最大長度65535個位元組(2^16-1) * 長文字 `LONGTEXT` 最大長度4294967295個位元組 (2^32-1) * 日期 `DATE` 日期(yyyy-mm-dd) * 時間 `TIME ` 時間(hh:mm:ss) * 日期時間 `DATETIME` 日期與時間組合(yyyy-mm-dd hh:mm:ss) * 時間戳 `TIMESTAMP` yyyymmddhhmmss * 年份 `YEAR` 年份yyyy ```mysql -- 建立表的操作 CREATE TABLE IF NOT EXISTS tb_user ( user_id int(11) AUTO_INCREMENT PRIMARY KEY COMMENT '使用者ID', user_name VARCHAR (30) NOT NULL COMMENT '使用者名稱稱', user_birthday date COMMENT '使用者生日', user_gender CHAR(3) COMMENT '使用者性別', user_status TINYINT(1) NOT NULL COMMENT '使用者狀態', user_height DECIMAL(4,1) NOT NULL COMMENT '使用者身高', user_desc text COMMENT '使用者簡介' ); ``` **表字段索引** * 主鍵索引:ALTER TABLE `table_name` ADD PRIMARY KEY (`column`),用於唯一標識一條記錄 * 唯一索引:ALTER TABLE `table_name` ADD UNIQUE (`column`) 往往不是為了提高訪問速度,而是為了避免資料出現重複 * 普通索引:ALTER TABLE `table_name` ADD INDEX index_name (`column`),唯一任務是加快對資料的訪問速度 * 全文索引:ALTER TABLE `table_name` ADD FULLTEXT index_name (`column1`, `column2`) ,僅可用於 MyISAM 表,針對較大的資料,生成全文索引很耗時好空間 * 聯合索引:ALTER TABLE `table_name` ADD INDEX index_name (`column1`, `column2`, `column3`) ,為了更多的提高mysql效率 ```mysql # 刪除主鍵索引 ALTER TABLE `table_name` DROP PRIMARY KEY # 刪除唯一索引 ALTER TABLE `table_name` DROP INDEX unique_index_name; ALTER TABLE `table_name` DROP INDEX cloumn; # 刪除普通索引 ALTER TABLE `table_name` DROP INDEX index_name; # 刪除全文索引 ALTER TABLE `table_name` DROP INDEX fulltext_index_name; ALTER TABLE `table_name` DROP INDEX cloumn; ``` ##### 修改表 **欄位新增** ```mysql # ALTER TABLE tb_name ADD 欄位 欄位型別 非空約束 預設值 註釋 ALTER TABLE tb_name ADD address VARCHAR ( 100 ) NOT NULL DEFAULT COMMENT '使用者地址'; ``` **欄位型別修改** ```mysql # ALTER TABLE tb_name MODIFY 欄位 新的欄位型別 非空約束 預設值 註釋 ALTER TABLE tb_name MODIFY address VARCHAR ( 50 ) NOT NULL DEFAULT COMMENT '使用者地址'; ``` **欄位名稱型別修改** ```mysql # ALTER TABLE tb_name MODIFY 舊的欄位 新的欄位 新的欄位型別 非空約束 預設值 註釋 ALTER TABLE tb_name CHANGE address addr VARCHAR ( 50 ) NOT NULL DEFAULT COMMENT '使用者地址'; ``` **欄位型別查詢** ```mysql DESC tb_name; ``` **欄位刪除** ```mysql # ALTER TABLE tb_name DROP 欄位 ALTER TABLE tb_name DROP addr; ``` **表名修改** ```mysql # ALTER TABLE 舊錶名 RENAME TO 新表名 ALTER TABLE tb_name RENAME TO tb_name1 ``` **表引擎修改** ```mysql # ALTER TABLE tb_name ENGINE = 新引擎 ALTER TABLE tb_name ENGINE = MyISAM; ``` ##### 刪除表 ```mysql # DROP TABLE 表名 DROP TABLE tb_name; # 如果表存在就刪除 DROP TABLE IF EXISTS tb_name; ``` ##### 查詢表 ```mysql # 查詢所有表 SHOW TABLES; # 查詢建表時的指令碼 SHOW CREATE TABLE tb_name; ``` ## MySQL DML 操作 ##### 新增資料 ```mysql # insert into 表名 (欄位名:欄位1,欄位2,...欄位n) values (值1,值2,...值n); # 全表插入 INSERT INTO `tb_user`(`user_name`, `user_birthday`, `user_gender`, `user_status`, `user_height`, `user_desc`) VALUES ('曾小賢', '2020-11-22', '男', 1, 174.5, '好男人就是我,我就是好男人曾小賢'); # 指定列插入,前提是其他列沒有非空的約束 INSERT INTO `tb_user`(`user_name`, `user_birthday`, `user_gender`, `user_status`, `user_height`) VALUES ('胡小梅', '2020-11-22', '女', 1, 174.5); ``` ##### 修改資料 ```mysql # update 表名 set 欄位1=新值1,欄位2=新值2,...欄位n=新值n where 條件 UPDATE `tb_user` SET user_birthday='1995-10-20' WHERE user_id=2; UPDATE `tb_user` SET user_birthday='1995-10-20', user_status = 2 WHERE user_id=2; UPDATE `tb_user` SET user_status = 1 where user_id > 1; UPDATE `tb_user` SET user_status = 1; ``` ##### 刪除資料 ```mysql # delete from 表名 where 條件 DELETE FROM `tb_user` WHERE user_id=2; ``` ##### 查詢資料 ```mysql # select 欄位1,欄位2,...欄位n from 表名 where 條件 # 不帶條件查詢 select * from tb_user; select user_id,user_name from tb_user; # 帶條件查詢 (比較運算 >, <, >=, <=, !=, <>, =) select * from tb_user where user_id > 1; # 帶邏輯條件查詢 (and,or) select * from tb_user where user_status = 1 and user_id > 1; select * from tb_user where user_id = 1 or user_name = '胡小梅'; # 模糊查詢 (like %%) select * from tb_user where user_name like '曾%'; select * from tb_user where user_name like '%閒'; select * from tb_user where user_name like '%小%'; # 範圍查詢 select * from tb_user where tb_status in (0,1,2); # 聚合函式 -- count(field) select count(user_id) 使用者數量 from tb_user; -- sum(field) select sum(user_height) 總身高 from tb_user; -- avg(field) select avg(user_height) 平均身高 from tb_user; ... # 分組查詢 -- group by 統計男女的平均身高: group by 查詢中出現的欄位必須是 group by 後面的欄位 select user_gender as 性別,avg(user_height) 平均身高 from tb_user group by user_gender; select user_status,user_gender as 性別,avg(user_height) 平均身高 from tb_user group by user_gender,user_status; select user_gender as 性別,avg(user_height) 平均身高,sum(user_height),count(user_id) 使用者數量 from tb_user group by user_gender; # 排序查詢 -- order by 預設是 asc 升序, desc 降序; order by 是放在 group by 之後的 select * from tb_user order by user_id asc; select * from tb_user order by user_id desc; select * from tb_user where user_id < 10 order by user_id desc; select * from tb_user where user_id < 10 order by user_id,user_status desc; select user_gender as 性別,avg(user_height) 平均身高,sum(user_height),count(user_id) 使用者數量 from tb_user group by user_gender order by 使用者數量; ``` ```mysql # 建立分數表 CREATE TABLE `tb_score` ( `id` int(11) NOT NULL PRIMARY KEY AUTO_INCREMENT, `stu_id` int(11) NOT NULL, `cou_id` int(11) NOT NULL, `score` decimal(4,1) NOT NULL ); -- 插入測試資料 INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(1,1,89.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(1,2,78.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(1,3,94.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(1,4,77.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(1,5,99.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(3,1,90.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(3,2,88.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(3,3,69.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(3,4,83.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(3,5,92.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(2,1,77.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(2,2,84.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(2,3,91.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(2,4,80.0); INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(2,5,99.0); # 分頁查詢 -- 查詢科目id為1的最高成績 select max(score) from tb_score where course_id = 1; select * from tb_score where course_id = 1 limit 1; -- 查詢課程id為4的前五名成績資訊 select * from tb_score where course_id = 4 order by score limit 5; -- limit 分頁, 起始值是 0: (pageIndex - 1) * pageSize, pageSize select * from tb_score limit 0,10 select * from tb_score limit 10,10 select * from tb_score limit 20