MySQL8數(shù)據(jù)庫(kù)安裝及SQL語(yǔ)句詳解
MySQL8數(shù)據(jù)庫(kù)安裝
一、Windows 環(huán)境下安裝
A、下載 MySQL
Select Operating System:Microsoft Windows
B、解壓并配置MySQL環(huán)境變量
MYSQL_HOME: C:\MySQL\mysql-8.0.22-winx64
C、在解壓根目錄創(chuàng)建my.ini配置文件
[mysqld] #設(shè)置3306端口 port = 3306 # 設(shè)置mysql的安裝目錄 basedir=C:/MySQL/mysql-8.0.22-winx64 # 設(shè)置mysql數(shù)據(jù)庫(kù)的數(shù)據(jù)的存放目錄 datadir=C:/MySQL/mysql-8.0.22-winx64\data # 允許最大連接數(shù) max_connections=200 # 允許連接失敗的次數(shù)。這是為了防止有人從該主機(jī)試圖攻擊數(shù)據(jù)庫(kù)系統(tǒng) max_connect_errors=10 # 服務(wù)端使用的字符集默認(rèn)為utf8 character-set-server=utf8mb4 # 創(chuàng)建新表時(shí)將使用的默認(rèn)存儲(chǔ)引擎 default-storage-engine=INNODB # 默認(rèn)使用 “mysql_native_password” 插件認(rèn)證 default_authentication_plugin=mysql_native_password [mysql] # 設(shè)置mysql客戶(hù)端默認(rèn)字符集 default-character-set=utf8mb4 [client] # 設(shè)置mysql客戶(hù)端連接服務(wù)端時(shí)默認(rèn)使用的端口 port=3306 # 設(shè)置mysql客戶(hù)端連接服務(wù)端時(shí)默認(rèn)使用的字符集 default-character-set=utf8mb4
D、安裝 MySQL (以下操作必須是管理員身份)
- 初始化MySQL
mysqld --defaults-file=C:\MySQL\mysql-8.0.22-winx64\my.ini --initialize --console
注意:復(fù)制保存 MySQL初始化密碼 fVdpg:bM9pAk
- 安裝MySQL服務(wù)
mysqld --install mysql8
- 啟動(dòng)MySQL服務(wù)
net start mysql8
E、登錄、修改密碼
- 登錄 MySQL
mysql -u賬號(hào) -p密碼
使用上面方式無(wú)法登錄的解決方案
1、停止 mysql8
net stop mysql8
2、無(wú)密碼啟動(dòng)
mysqld --console --skip-grant-tables --shared-memory
3、前面窗口不能關(guān)閉,再開(kāi)啟一個(gè)新的窗口進(jìn)行無(wú)密碼登錄
mysql -u root -p
4、清空密碼
update mysql.user set authentication_string='' where user='root' and host='localhost;'
5、刷新權(quán)限
plush privileges;
6、重新啟動(dòng) mysql 服務(wù),再以無(wú)密碼登錄 mysql
- 登錄后使用MySQL修改密碼
ALTER USER root@localhost IDENTIFIED BY '123456';
- 開(kāi)啟遠(yuǎn)程訪問(wèn)
CREATE USER 'root' @'%' IDENTIFIED BY '123456'; -- 這一步執(zhí)行失敗也沒(méi)關(guān)系 GRANT ALL ON *.* TO 'root' @'%'; # alter user 'root'@'%' identified with mysql_native_password by '123456'; FLUSH privileges;
二、Linux 環(huán)境下安裝
A、下載 MySQL
Select Operating System:Source Code
Select OS Version:Generic Linux (Architecture Independent)
快捷下載:mysql-8.0.22.tar.gz
B、把下載的 MySQL 壓縮包上傳到 Linux 服務(wù)器
C、解壓mysql-8.0.22.tar.gz
tar -zxvf mysql-8.0.22.tar.gz
D、把解壓后的文件移動(dòng)到 /usr/local 目錄下
mv mysql-8.0.22 /usr/local/mysql
E、添加MySQL組合用戶(hù) (默認(rèn)會(huì)添加,沒(méi)有添加就手動(dòng)添加)
groupadd mysql useradd -r -g mysql mysql
F、進(jìn)入 /usr/local/mysql 目錄,修改相關(guān)權(quán)限
cd /usr/local/mysql chown -R mysql:mysql ./
G、MySQL初始化操作,記錄臨時(shí)密碼
cd /usr/local/mysql/bin ./mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
注意:復(fù)制保存 MySQL初始化密碼 fVdpg:bM9pAk
H、創(chuàng)建MySQL配置文件 /etc/my.cnf
cd /etc vi my.cnf
my.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、啟動(dòng)MySQL服務(wù)
cd /usr/local/mysql/support-files ./mysql.server start
J、通過(guò)臨時(shí)密碼登錄MySQL并修改密碼
cd /usr/local/mysql/bin ./mysql -u root -p生成的臨時(shí)密碼 ALTER USER 'root' @'localhost' IDENTIFIED BY '123456';
K、開(kāi)啟遠(yuǎn)程訪問(wèn)
CREATE USER 'root' @'%' IDENTIFIED BY '123456'; -- 這一步執(zhí)行失敗也沒(méi)關(guān)系 GRANT ALL ON *.* TO 'root' @'%'; FLUSH privileges;
MySQL 數(shù)據(jù)庫(kù)操作
數(shù)據(jù)庫(kù)操作
創(chuàng)建數(shù)據(jù)庫(kù)
CREATE DATABASE db_name DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
查詢(xún)數(shù)據(jù)庫(kù)
-- 查詢(xún)所有數(shù)據(jù)庫(kù) SHOW DATABASES; -- 查詢(xún)數(shù)據(jù)庫(kù)建表時(shí)的sql腳本 SHOW CREATE DATABASE db_name;
刪除數(shù)據(jù)庫(kù)
DROP DATABASE db_name;
修改數(shù)據(jù)庫(kù)
-- 修改數(shù)據(jù)庫(kù)的字符編碼和排序方式 ALTER DATABASE db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
選擇數(shù)據(jù)庫(kù)
USE db_name;
設(shè)置操作的編碼格式
SET NAMES utf8;
表操作
創(chuàng)建表
CREATE TABLE tb_name (建表的字段、類(lèi)型、長(zhǎng)度、約束、默認(rèn)、注釋)
約束
- 非空
NOT NULL
- 非負(fù)
UNSIGNED
- 主鍵
PRIMARY KEY
- 自增
AUTO_INCREMENT
- 默認(rèn)
DEFAULT
- 注釋
COMMENT
-- 數(shù)據(jù)庫(kù)存在就刪除 DROP DATABASE IF EXISTS testdb; -- 創(chuàng)建數(shù)據(jù)庫(kù)的操作 CREATE DATABASE IF NOT EXISTS testdb; -- 使用數(shù)據(jù)庫(kù) USE testdb; -- 數(shù)據(jù)表存在就刪除 DROP TABLE IF EXISTS testdb; -- 創(chuàng)建表的操作 CREATE TABLE IF NOT EXISTS tb_test ( test_id INTEGER ( 10 ), test_name VARCHAR ( 50 ) );
-- 使用數(shù)據(jù)庫(kù) USE testdb; -- 數(shù)據(jù)表存在就刪除 DROP TABLE IF EXISTS testdb; -- 創(chuàng)建表的操作 CREATE TABLE IF NOT EXISTS tb_test ( test_id INTEGER (10) AUTO_INCREMENT PRIMARY KEY COMMENT '測(cè)試ID', test_name VARCHAR (50) NOT NULL COMMENT '測(cè)試名稱(chēng)', test_password VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '測(cè)試密碼' );
常用類(lèi)型
- 極小整形
TIYINT
1個(gè)字節(jié),無(wú)符號(hào)最大值 256 (2^8 -1),正負(fù) -128 ~ 127 (-2^7 -1 ~ 2^7 -1) - 小整形
SMALLINT
2個(gè)字節(jié),無(wú)符號(hào)最大值 65535 (2^16 - 1),正負(fù) -32768 ~ 32767 (-2^15 - 1 ~ 2^15 - 1) - 中整形
MEDIUMINT
3個(gè)字節(jié),無(wú)符號(hào)最大值 16777215 (2^24 - 1),正負(fù) (-2^23-1 ~ 2^23-1) - 整形
INT
4個(gè)字節(jié),無(wú)符號(hào)最大值 2^32 -1,正負(fù) (-2^31-1 ~ 2^31-1) - 長(zhǎng)整形
BIGINT
8個(gè)字節(jié),無(wú)符號(hào)最大值 2^64 - 1, 正負(fù) (-2^63-1 ~ 2^63-1) - 單精度
FLOAT
4個(gè)字節(jié) Float [(M,D)] -3.4E+38~3.4E+38( 約 ) - 雙精度
DOUBLE
8個(gè)字節(jié) Double [(M,D)] -1.79E+308~1.79E+308( 約 ) - 小數(shù)值
DECIMAL
M>D ? M+2 : D+2
個(gè)字節(jié) Decimal [(M,D)] 注:M 為長(zhǎng)度, D 為小數(shù) - 定長(zhǎng)字符串
CHAR
最大保存255個(gè)字節(jié),如果值沒(méi)有達(dá)到給定的長(zhǎng)度,使用空格補(bǔ)充 - 變長(zhǎng)字符串
VARCHAR
最大保存255個(gè)字節(jié),用多大長(zhǎng)度占多大長(zhǎng)度 - 極小文本
TINYTEXT
最大長(zhǎng)度255個(gè)字節(jié)(2^8-1) - 中文本
MEDIUMTEXT
最大長(zhǎng)度 16777215 個(gè)字節(jié)(2^24-1) - 文本
TEXT
最大長(zhǎng)度65535個(gè)字節(jié)(2^16-1) - 長(zhǎng)文本
LONGTEXT
最大長(zhǎng)度4294967295個(gè)字節(jié) (2^32-1) - 日期
DATE
日期(yyyy-mm-dd) - 時(shí)間
TIME
時(shí)間(hh:mm:ss) - 日期時(shí)間
DATETIME
日期與時(shí)間組合(yyyy-mm-dd hh:mm:ss) - 時(shí)間戳
TIMESTAMP
yyyymmddhhmmss - 年份
YEAR
年份yyyy
-- 創(chuàng)建表的操作 CREATE TABLE IF NOT EXISTS tb_user ( user_id int(11) AUTO_INCREMENT PRIMARY KEY COMMENT '用戶(hù)ID', user_name VARCHAR (30) NOT NULL COMMENT '用戶(hù)名稱(chēng)', user_birthday date COMMENT '用戶(hù)生日', user_gender CHAR(3) COMMENT '用戶(hù)性別', user_status TINYINT(1) NOT NULL COMMENT '用戶(hù)狀態(tài)', user_height DECIMAL(4,1) NOT NULL COMMENT '用戶(hù)身高', user_desc text COMMENT '用戶(hù)簡(jiǎn)介' );
表字段索引
- 主鍵索引:ALTER TABLE
table_name
ADD PRIMARY KEY (column
),用于唯一標(biāo)識(shí)一條記錄 - 唯一索引:ALTER TABLE
table_name
ADD UNIQUE (column
) 往往不是為了提高訪問(wèn)速度,而是為了避免數(shù)據(jù)出現(xiàn)重復(fù) - 普通索引:ALTER TABLE
table_name
ADD INDEX index_name (column
),唯一任務(wù)是加快對(duì)數(shù)據(jù)的訪問(wèn)速度 - 全文索引:ALTER TABLE
table_name
ADD FULLTEXT index_name (column1
,column2
) ,僅可用于 MyISAM 表,針對(duì)較大的數(shù)據(jù),生成全文索引很耗時(shí)好空間 - 聯(lián)合索引:ALTER TABLE
table_name
ADD INDEX index_name (column1
,column2
,column3
) ,為了更多的提高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;
修改表
字段添加
# ALTER TABLE tb_name ADD 字段 字段類(lèi)型 非空約束 默認(rèn)值 注釋 ALTER TABLE tb_name ADD address VARCHAR ( 100 ) NOT NULL DEFAULT COMMENT '用戶(hù)地址';
字段類(lèi)型修改
# ALTER TABLE tb_name MODIFY 字段 新的字段類(lèi)型 非空約束 默認(rèn)值 注釋 ALTER TABLE tb_name MODIFY address VARCHAR ( 50 ) NOT NULL DEFAULT COMMENT '用戶(hù)地址';
字段名稱(chēng)類(lèi)型修改
# ALTER TABLE tb_name MODIFY 舊的字段 新的字段 新的字段類(lèi)型 非空約束 默認(rèn)值 注釋 ALTER TABLE tb_name CHANGE address addr VARCHAR ( 50 ) NOT NULL DEFAULT COMMENT '用戶(hù)地址';
字段類(lèi)型查詢(xún)
DESC tb_name;
字段刪除
# ALTER TABLE tb_name DROP 字段 ALTER TABLE tb_name DROP addr;
表名修改
# ALTER TABLE 舊表名 RENAME TO 新表名 ALTER TABLE tb_name RENAME TO tb_name1
表引擎修改
# ALTER TABLE tb_name ENGINE = 新引擎 ALTER TABLE tb_name ENGINE = MyISAM;
刪除表
# DROP TABLE 表名 DROP TABLE tb_name; # 如果表存在就刪除 DROP TABLE IF EXISTS tb_name;
查詢(xún)表
# 查詢(xún)所有表 SHOW TABLES; # 查詢(xún)建表時(shí)的腳本 SHOW CREATE TABLE tb_name;
MySQL DML 操作
新增數(shù)據(jù)
# 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, '好男人就是我,我就是好男人曾小賢'); # 指定列插入,前提是其他列沒(méi)有非空的約束 INSERT INTO `tb_user`(`user_name`, `user_birthday`, `user_gender`, `user_status`, `user_height`) VALUES ('胡小梅', '2020-11-22', '女', 1, 174.5);
修改數(shù)據(jù)
# 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;
刪除數(shù)據(jù)
# delete from 表名 where 條件 DELETE FROM `tb_user` WHERE user_id=2;
查詢(xún)數(shù)據(jù)
# select 字段1,字段2,...字段n from 表名 where 條件 # 不帶條件查詢(xún) select * from tb_user; select user_id,user_name from tb_user; # 帶條件查詢(xún) (比較運(yùn)算 >, <, >=, <=, !=, <>, =) select * from tb_user where user_id > 1; # 帶邏輯條件查詢(xún) (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 = '胡小梅'; # 模糊查詢(xún) (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 '%小%'; # 范圍查詢(xún) select * from tb_user where tb_status in (0,1,2); # 聚合函數(shù) -- count(field) select count(user_id) 用戶(hù)數(shù)量 from tb_user; -- sum(field) select sum(user_height) 總身高 from tb_user; -- avg(field) select avg(user_height) 平均身高 from tb_user; ... # 分組查詢(xún) -- group by 統(tǒng)計(jì)男女的平均身高: group by 查詢(xún)中出現(xiàn)的字段必須是 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) 用戶(hù)數(shù)量 from tb_user group by user_gender; # 排序查詢(xún) -- order by 默認(rèn)是 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) 用戶(hù)數(shù)量 from tb_user group by user_gender order by 用戶(hù)數(shù)量;
# 創(chuàng)建分?jǐn)?shù)表 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 ); -- 插入測(cè)試數(shù)據(jù) 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); # 分頁(yè)查詢(xún) -- 查詢(xún)科目id為1的最高成績(jī) select max(score) from tb_score where course_id = 1; select * from tb_score where course_id = 1 limit 1; -- 查詢(xún)課程id為4的前五名成績(jī)信息 select * from tb_score where course_id = 4 order by score limit 5; -- limit 分頁(yè), 起始值是 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,10
到此這篇關(guān)于MySQL8數(shù)據(jù)庫(kù)安裝及SQL語(yǔ)句詳解的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Mysql 自定義隨機(jī)字符串的實(shí)現(xiàn)方法
前段時(shí)間接了一個(gè)項(xiàng)目,需要用到隨機(jī)字符串,但是mysql的庫(kù)函數(shù)沒(méi)有直接提供,需要我們自己實(shí)現(xiàn)此功能,下面小編給大家介紹下Mysql 自定義隨機(jī)字符串的實(shí)現(xiàn)方法,需要的朋友參考下吧2016-08-08MySQL數(shù)據(jù)庫(kù)中刪除重復(fù)記錄簡(jiǎn)單步驟
這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫(kù)中刪除重復(fù)記錄的相關(guān)資料,在使用數(shù)據(jù)庫(kù)時(shí),出現(xiàn)重復(fù)數(shù)據(jù)是常有的情況,但有些情況是允許數(shù)據(jù)重復(fù)的,而有些情況是不允許的,當(dāng)出現(xiàn)不允許的情況,我們就需要對(duì)重復(fù)數(shù)據(jù)進(jìn)行刪除處理,需要的朋友可以參考下2023-08-08MySQL數(shù)據(jù)庫(kù)innodb啟動(dòng)失敗無(wú)法重啟的解決方法
這篇文章給大家分享了MySQL數(shù)據(jù)庫(kù)innodb啟動(dòng)失敗無(wú)法重啟的解決方法,通過(guò)總結(jié)自己遇到的問(wèn)題分享給大家,讓遇到同樣問(wèn)題的朋友們可以盡快解決,下面來(lái)一起看看吧。2016-09-09MySQL對(duì)數(shù)據(jù)庫(kù)操作(創(chuàng)建、選擇、刪除)
這篇文章主要介紹了MySQL如何對(duì)數(shù)據(jù)庫(kù)操作,文中講解非常詳細(xì),代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07