mysql8数据库安装教程_MySQL8数据库安装教程

本文提供MySQL8在Windows和Linux环境下的详细安装教程。包括下载、解压、配置环境变量、初始化数据库、设置密码及远程访问等关键步骤,确保数据库成功安装和运行。
摘要由CSDN通过智能技术生成

mysql视频教程栏目详细解释MySQL8数据库安装教程。

c43703bbc280d2579f016886b721cadd.png

一、Windows 环境下安装

A、下载 MySQL

Select Operating System:

Microsoft Windows

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

B、解压并配置MySQL环境变量MYSQL_HOME:

C:\MySQL\mysql-8.0.22-winx64

C、在解压根目录创建my.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 (以下操作必须是管理员身份)初始化MySQLmysqld --defaults-file=C:\MySQL\mysql-8.0.22-winx64\my.ini --initialize --console

注意:复制保存 MySQL初始化密码 fVdpg:bM9pAk安装MySQL服务mysqld --install mysql8启动MySQL服务net start mysql8

E、登录、修改密码登录 MySQLmysql -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登录后使用MySQL修改密码ALTER USER root@localhost IDENTIFIED BY '123456';开启远程访问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

Select Operating System:

Source Code

Select OS Version:

Generic Linux (Architecture Independent)

快捷下载:mysql-8.0.22.tar.gz

B、把下载的 MySQL 压缩包上传到 Linux 服务器

C、解压mysql-8.0.22.tar.gztar -zxvf mysql-8.0.22.tar.gz

D、把解压后的文件移动到 /usr/local 目录下mv mysql-8.0.22 /usr/local/mysql

E、添加MySQL组合用户 (默认会添加,没有添加就手动添加)groupadd mysql

useradd -r -g mysql mysql

F、进入 /usr/local/mysql 目录,修改相关权限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

注意:复制保存 MySQL初始化密码 fVdpg:bM9pAk

H、创建MySQL配置文件 /etc/my.cnfcd /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服务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、开启远程访问CREATE USER 'root' @'%' IDENTIFIED BY '123456'; -- 这一步执行失败也没关系

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

FLUSH privilege;

MySQL 数据库操作

数据库操作

创建数据库CREATE DATABASE db_name DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

查询数据库-- 查询所有数据库

SHOW DATABASES;

-- 查询数据库建表时的sql脚本

SHOW CREATE DATABASE db_name;

删除数据库DROP DATABASE db_name;

修改数据库-- 修改数据库的字符编码和排序方式

ALTER DATABASE db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

选择数据库USE db_name;

设置操作的编码格式SET NAMES utf8;

表操作

创建表CREATE TABLE tb_name (建表的字段、类型、长度、约束、默认、注释)

约束非空 NOT NULL

非负 UNSIGNED

主键 PRIMARY KEY

自增 AUTO_INCREMENT

默认 DEFAULT

注释 COMMENT-- 数据库存在就删除

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 )

);-- 使用数据库

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-- 创建表的操作

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效率# 删除主键索引

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 字段 字段类型 非空约束 默认值 注释

ALTER TABLE tb_name ADD address VARCHAR ( 100 ) NOT NULL DEFAULT COMMENT '用户地址';

字段类型修改# ALTER TABLE tb_name MODIFY 字段 新的字段类型 非空约束 默认值 注释

ALTER TABLE tb_name MODIFY address VARCHAR ( 50 ) NOT NULL DEFAULT COMMENT '用户地址';

字段名称类型修改# ALTER TABLE tb_name MODIFY 旧的字段 新的字段 新的字段类型 非空约束 默认值 注释

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 操作

新增数据# 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);

修改数据# 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;

删除数据# delete from 表名 where 条件

DELETE FROM `tb_user` WHERE user_id=2;

查询数据# 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 用户数量;# 创建分数表

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,10

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值