欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL8數(shù)據(jù)庫安裝及SQL語句詳解

 更新時間:2022年02月18日 09:47:10   作者:Run2948  
本文詳細(xì)講解了MySQL8數(shù)據(jù)庫安裝及SQL語句用法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

MySQL8數(shù)據(jù)庫安裝

一、Windows 環(huán)境下安裝

A、下載 MySQL

下載地址

Select Operating System:
Microsoft Windows

快捷下載:mysql-8.0.22-winx64.zip

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ù)庫的數(shù)據(jù)的存放目錄
datadir=C:/MySQL/mysql-8.0.22-winx64\data
# 允許最大連接數(shù)
max_connections=200
# 允許連接失敗的次數(shù)。這是為了防止有人從該主機(jī)試圖攻擊數(shù)據(jù)庫系統(tǒng)
max_connect_errors=10
# 服務(wù)端使用的字符集默認(rèn)為utf8
character-set-server=utf8mb4
# 創(chuàng)建新表時將使用的默認(rèn)存儲引擎
default-storage-engine=INNODB
# 默認(rèn)使用 “mysql_native_password” 插件認(rèn)證
default_authentication_plugin=mysql_native_password

[mysql]
# 設(shè)置mysql客戶端默認(rèn)字符集
default-character-set=utf8mb4

[client]
# 設(shè)置mysql客戶端連接服務(wù)端時默認(rèn)使用的端口
port=3306
# 設(shè)置mysql客戶端連接服務(wù)端時默認(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
  • 啟動MySQL服務(wù)
net start mysql8

E、登錄、修改密碼

  • 登錄 MySQL
mysql -u賬號 -p密碼

使用上面方式無法登錄的解決方案

1、停止 mysql8 net stop mysql8

2、無密碼啟動 mysqld --console --skip-grant-tables --shared-memory

3、前面窗口不能關(guān)閉,再開啟一個新的窗口進(jìn)行無密碼登錄 mysql -u root -p

4、清空密碼 update mysql.user set authentication_string='' where user='root' and host='localhost;'

5、刷新權(quán)限 plush privileges;

6、重新啟動 mysql 服務(wù),再以無密碼登錄 mysql

  • 登錄后使用MySQL修改密碼
ALTER USER root@localhost IDENTIFIED BY '123456';
  • 開啟遠(yuǎn)程訪問
CREATE USER 'root' @'%' IDENTIFIED BY '123456'; -- 這一步執(zhí)行失敗也沒關(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、把解壓后的文件移動到 /usr/local 目錄下

mv mysql-8.0.22 /usr/local/mysql

E、添加MySQL組合用戶 (默認(rèn)會添加,沒有添加就手動添加)

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初始化操作,記錄臨時密碼

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、啟動MySQL服務(wù)

cd /usr/local/mysql/support-files
./mysql.server start

J、通過臨時密碼登錄MySQL并修改密碼

cd /usr/local/mysql/bin
./mysql -u root -p生成的臨時密碼 
ALTER USER 'root' @'localhost' IDENTIFIED BY '123456';

K、開啟遠(yuǎn)程訪問

CREATE USER 'root' @'%' IDENTIFIED BY '123456';  -- 這一步執(zhí)行失敗也沒關(guān)系

GRANT ALL ON *.* TO 'root' @'%';

FLUSH privileges;

MySQL 數(shù)據(jù)庫操作

數(shù)據(jù)庫操作

創(chuàng)建數(shù)據(jù)庫

CREATE DATABASE db_name DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

查詢數(shù)據(jù)庫

-- 查詢所有數(shù)據(jù)庫
SHOW DATABASES;
-- 查詢數(shù)據(jù)庫建表時的sql腳本
SHOW CREATE DATABASE db_name;

刪除數(shù)據(jù)庫

DROP DATABASE db_name;

修改數(shù)據(jù)庫

-- 修改數(shù)據(jù)庫的字符編碼和排序方式
ALTER DATABASE db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

選擇數(shù)據(jù)庫

USE db_name;

設(shè)置操作的編碼格式

SET NAMES utf8;

表操作

創(chuàng)建表

CREATE TABLE tb_name (建表的字段、類型、長度、約束、默認(rèn)、注釋)

約束
  • 非空 NOT NULL
  • 非負(fù) UNSIGNED
  • 主鍵 PRIMARY KEY
  • 自增 AUTO_INCREMENT
  • 默認(rèn) DEFAULT
  • 注釋 COMMENT
-- 數(shù)據(jù)庫存在就刪除
DROP DATABASE IF EXISTS testdb;
-- 創(chuàng)建數(shù)據(jù)庫的操作
CREATE DATABASE IF NOT EXISTS testdb;
-- 使用數(shù)據(jù)庫
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ù)庫
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 '測試ID', 
	test_name VARCHAR (50) NOT NULL COMMENT '測試名稱',
	test_password VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '測試密碼'
);
常用類型
  • 極小整形 TIYINT 1個字節(jié),無符號最大值 256 (2^8 -1),正負(fù) -128 ~ 127 (-2^7 -1 ~ 2^7 -1)
  • 小整形 SMALLINT 2個字節(jié),無符號最大值 65535 (2^16 - 1),正負(fù) -32768 ~ 32767 (-2^15 - 1 ~ 2^15 - 1)
  • 中整形 MEDIUMINT 3個字節(jié),無符號最大值 16777215 (2^24 - 1),正負(fù) (-2^23-1 ~ 2^23-1)
  • 整形 INT 4個字節(jié),無符號最大值 2^32 -1,正負(fù) (-2^31-1 ~ 2^31-1)
  • 長整形 BIGINT 8個字節(jié),無符號最大值 2^64 - 1, 正負(fù) (-2^63-1 ~ 2^63-1)
  • 單精度 FLOAT 4個字節(jié) Float [(M,D)] -3.4E+38~3.4E+38( 約 )
  • 雙精度 DOUBLE 8個字節(jié) Double [(M,D)] -1.79E+308~1.79E+308( 約 )
  • 小數(shù)值 DECIMAL M>D ? M+2 : D+2 個字節(jié) Decimal [(M,D)] 注:M 為長度, D 為小數(shù)
  • 定長字符串CHAR 最大保存255個字節(jié),如果值沒有達(dá)到給定的長度,使用空格補(bǔ)充
  • 變長字符串VARCHAR 最大保存255個字節(jié),用多大長度占多大長度
  • 極小文本 TINYTEXT 最大長度255個字節(jié)(2^8-1)
  • 中文本 MEDIUMTEXT 最大長度 16777215 個字節(jié)(2^24-1)
  • 文本 TEXT 最大長度65535個字節(jié)(2^16-1)
  • 長文本 LONGTEXT 最大長度4294967295個字節(jié) (2^32-1)
  • 日期 DATE 日期(yyyy-mm-dd)
  • 時間 TIME 時間(hh:mm:ss)
  • 日期時間 DATETIME 日期與時間組合(yyyy-mm-dd hh:mm:ss)
  • 時間戳 TIMESTAMP yyyymmddhhmmss
  • 年份 YEAR 年份yyyy
-- 創(chuàng)建表的操作
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 '用戶狀態(tài)',
	user_height DECIMAL(4,1) NOT NULL COMMENT '用戶身高',
    user_desc text COMMENT '用戶簡介'
);
表字段索引
  • 主鍵索引:ALTER TABLE table_name ADD PRIMARY KEY (column),用于唯一標(biāo)識一條記錄
  • 唯一索引:ALTER TABLE table_name ADD UNIQUE (column) 往往不是為了提高訪問速度,而是為了避免數(shù)據(jù)出現(xiàn)重復(fù)
  • 普通索引:ALTER TABLE table_name ADD INDEX index_name (column),唯一任務(wù)是加快對數(shù)據(jù)的訪問速度
  • 全文索引:ALTER TABLE table_name ADD FULLTEXT index_name (column1column2) ,僅可用于 MyISAM 表,針對較大的數(shù)據(jù),生成全文索引很耗時好空間
  • 聯(lián)合索引:ALTER TABLE table_name ADD INDEX index_name (column1column2column3) ,為了更多的提高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 字段 字段類型 非空約束 默認(rèn)值 注釋
ALTER TABLE tb_name ADD address VARCHAR ( 100 ) NOT NULL DEFAULT COMMENT '用戶地址';
字段類型修改
# ALTER TABLE tb_name MODIFY 字段 新的字段類型 非空約束 默認(rèn)值 注釋
ALTER TABLE tb_name MODIFY address VARCHAR ( 50 ) NOT NULL DEFAULT COMMENT '用戶地址';
字段名稱類型修改
# ALTER TABLE tb_name MODIFY 舊的字段 新的字段 新的字段類型 非空約束 默認(rèn)值 注釋
ALTER TABLE tb_name CHANGE address addr VARCHAR ( 50 ) NOT NULL DEFAULT COMMENT '用戶地址';
字段類型查詢
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;

查詢表

# 查詢所有表
SHOW TABLES;
# 查詢建表時的腳本
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, '好男人就是我,我就是好男人曾小賢');

# 指定列插入,前提是其他列沒有非空的約束
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;

查詢數(shù)據(jù)

# select 字段1,字段2,...字段n from 表名 where 條件

# 不帶條件查詢
select * from tb_user;
select user_id,user_name from tb_user;

# 帶條件查詢 (比較運(yùn)算 >, <, >=, <=, !=, <>, =)
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);

# 聚合函數(shù)
-- count(field)
select count(user_id) 用戶數(shù)量 from tb_user;
-- sum(field)
select sum(user_height) 總身高 from tb_user;
-- avg(field)
select avg(user_height) 平均身高 from tb_user;

...

# 分組查詢
-- group by 統(tǒng)計(jì)男女的平均身高: group by 查詢中出現(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) 用戶數(shù)量 from tb_user group by user_gender;

# 排序查詢
-- 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) 用戶數(shù)量 from tb_user group by user_gender order by 用戶數(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
);

-- 插入測試數(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);

# 分頁查詢
-- 查詢科目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,10

到此這篇關(guān)于MySQL8數(shù)據(jù)庫安裝及SQL語句詳解的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java連接Mysql 8.0.18版本的方法詳解

    Java連接Mysql 8.0.18版本的方法詳解

    這篇文章主要介紹了Java和Mysql 8.0.18版本的連接方式,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • mysql 5.7.27 winx64安裝配置方法圖文教程

    mysql 5.7.27 winx64安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.27 winx64安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • MySQL優(yōu)化之分區(qū)表

    MySQL優(yōu)化之分區(qū)表

    這篇文章主要介紹了MySQL優(yōu)化之分區(qū)表,需要的朋友可以參考下
    2016-06-06
  • Mysql 自定義隨機(jī)字符串的實(shí)現(xiàn)方法

    Mysql 自定義隨機(jī)字符串的實(shí)現(xiàn)方法

    前段時間接了一個項(xiàng)目,需要用到隨機(jī)字符串,但是mysql的庫函數(shù)沒有直接提供,需要我們自己實(shí)現(xiàn)此功能,下面小編給大家介紹下Mysql 自定義隨機(jī)字符串的實(shí)現(xiàn)方法,需要的朋友參考下吧
    2016-08-08
  • MySQL數(shù)據(jù)庫中刪除重復(fù)記錄簡單步驟

    MySQL數(shù)據(jù)庫中刪除重復(fù)記錄簡單步驟

    這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫中刪除重復(fù)記錄的相關(guān)資料,在使用數(shù)據(jù)庫時,出現(xiàn)重復(fù)數(shù)據(jù)是常有的情況,但有些情況是允許數(shù)據(jù)重復(fù)的,而有些情況是不允許的,當(dāng)出現(xiàn)不允許的情況,我們就需要對重復(fù)數(shù)據(jù)進(jìn)行刪除處理,需要的朋友可以參考下
    2023-08-08
  • MySQL數(shù)據(jù)庫innodb啟動失敗無法重啟的解決方法

    MySQL數(shù)據(jù)庫innodb啟動失敗無法重啟的解決方法

    這篇文章給大家分享了MySQL數(shù)據(jù)庫innodb啟動失敗無法重啟的解決方法,通過總結(jié)自己遇到的問題分享給大家,讓遇到同樣問題的朋友們可以盡快解決,下面來一起看看吧。
    2016-09-09
  • mysql 5.7.13 解壓縮版(免安裝)安裝配置教程

    mysql 5.7.13 解壓縮版(免安裝)安裝配置教程

    這篇文章主要介紹了MySQL 5.7.13 for Windows解壓縮版(免安裝)安裝配置教程,感興趣的小伙伴們可以參考一下
    2016-06-06
  • MySQL對數(shù)據(jù)庫操作(創(chuàng)建、選擇、刪除)

    MySQL對數(shù)據(jù)庫操作(創(chuàng)建、選擇、刪除)

    這篇文章主要介紹了MySQL如何對數(shù)據(jù)庫操作,文中講解非常詳細(xì),代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • Mysql命令大全(完整版)

    Mysql命令大全(完整版)

    這篇文章主要介紹了Mysql命令大全,分享的命令都是最基本的,推薦給大家,感興趣的小伙伴們可以參考一下
    2015-11-11
  • MySQL 導(dǎo)入慢的解決方法

    MySQL 導(dǎo)入慢的解決方法

    MySQL導(dǎo)出的SQL語句在導(dǎo)入時有可能會非常非常慢,在導(dǎo)出時合理使用幾個參數(shù),可以大大加快導(dǎo) 入的速度。
    2010-12-12

最新評論