MySQL学习笔记第一天

第02章 MySQL环境搭建

1.MySQL的卸载

步骤1:停止MySQL服务

在卸载之前,先停止MySQL8.0的服务。按键盘上的“Ctrl + Alt + Delete”组合键,打开“任务管理器”对话框,可以在“服务”列表找到“MySQL8.0”的服务,如果现在“正在运行”状态,可以右键单击服务,选择“停止”选项停止MySQL8.0的服务。

步骤2:软件的卸载

方式1:通过控制面板方式
卸载MySQL8.0的程序可以和其他桌面应用程序一样直接在“控制面板”选择“卸载程序”,并在程序列表中找到MySQL8.0服务器程序,直接双击卸载即可,这种方式删除,数据目录下的数据不会跟着删除。
MySQL学习笔记第一天_第1张图片
方式2:通过360或电脑管家等软件卸载

方式3:通过安装包提供的卸载功能卸载
你也可以通过安装向导程序进行MySQL8.0服务器程序的卸载。
① 再次双击下载的mysql-installer-community-8.0.26.0.msi文件,打开安装向导。安装向导会自动检测已安装的MySQL服务器程序。
② 选择要卸载的MySQL服务器程序,单击“Remove”(移除),即可进行卸载。
③ 单击“Next”(下一步)按钮,确认卸载。
④ 弹出是否同时移除数据目录选择窗口。如果想要同时删除MySQL服务器中的数据,则勾选“Remove thedata directory”。
⑤ 执行卸载。单击“Execute”(执行)按钮进行卸载。
⑥ 完成卸载。单击“Finish”(完成)按钮即可。如果想要同时卸载MySQL8.0的安装向导程序,勾选“Yes,Uninstall MySQL Installer”即可。

步骤3:残余文件的清理

如果再次安装不成功,可以卸载后对残余文件进行清理后再安装。
(1)服务目录:mysql服务的安装目录,我的放在C盘的progam files里面
(2)数据目录:默认在C:\ProgramData\MySQL
如果自己单独指定过数据目录,就找到自己的数据目录进行删除即可。
注意:请在卸载前做好数据备份。
在操作完以后,需要重启计算机,然后进行安装即可。

步骤4:清理注册表(选做)

如果仍然安装失败,需要继续操作如下步骤4。
如果前几步做了,再次安装还是失败,那么可以清理注册表。
如何打开注册表编辑器:在系统的搜索框中输入 regedit。

HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\MySQL服务 目录删除
HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\Eventlog\Application\MySQL服务 目录删除
HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\MySQL服务 目录删除
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application\MySQL服务目录
删除
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\MySQL服务删除

注册表中的ControlSet001,ControlSet002,不一定是001和002,可能是ControlSet005、006之类

步骤5:删除环境变量配置

找到path环境变量,将其中关于mysql的环境变量删除,切记不要全部删除。
例如:删除D:\develop_tools\mysql\MySQLServer8.0.26\bin; 这个部分

2.MySQL的下载、安装、配置

3.MySQL的登录

3.1 服务的启动与停止

MySQL安装完毕之后,需要启动服务器进程,不然客户端无法连接数据库。
在前面的配置过程中,已经将MySQL安装为Windows服务,并且勾选当Windows启动、停止时,MySQL也自动启动、停止。

方法1:使用图形界面工具

  • 步骤1:打开windows服务
    方式1:计算机(点击鼠标右键)→ 管理(点击)→ 服务和应用程序(点击)→ 服务(点击)
    MySQL学习笔记第一天_第2张图片
    方式2:控制面板(点击)→ 系统和安全(点击)→ 管理工具(点击)→ 服务(点击)
    方式3:任务栏(点击鼠标右键)→ 启动任务管理器(点击)→ 服务(点击)
    方式4:单击【开始】菜单,在搜索框中输入“services.msc”,按Enter键确认

  • 步骤2: 找到MySQL80(点击鼠标右键)→ 启动或停止(点击)

方法2:使用命令行工具

启动 MySQL 服务命令(记得要以管理员身份运行cmd命令提示符):
net start MySQL服务名
停止 MySQL 服务命令:
net stop MySQL服务名


MySQL学习笔记第一天_第3张图片

  • 说明:
  1. start和stop后面的服务名应与之前配置时指定的服务名一致。
  2. 如果当你输入命令后,提示“拒绝服务”,请以 系统管理员身份 打开命令提示符界面重新尝试。

3.2 自带客户端的登录与退出

当MySQL服务启动完成后,便可以通过客户端来登录MySQL数据库。注意:确认服务是开启的。

登录方式1:MySQL自带客户端

开始菜单 → 所有程序 → MySQL → MySQL 8.0 Command Line Client
MySQL学习笔记第一天_第4张图片

说明:仅限于root用户

登录方式2:windows命令行

格式:

mysql -h 主机名 -P 端口号 -u 用户名 -p密码

注意:
(1)-p与密码之间不能有空格,其他参数名与参数值之间可以有空格也可以没有空格。如:

mysql -hlocalhost -P3306 -uroot -pabc123

2)密码建议在下一行输入,保证安全

mysql -h localhost -P 3306 -u root -p
Enter password:******

(3)客户端和服务器在同一台机器上,所以输入localhost或者IP地址127.0.0.1。同时,因为是连接本机: -hlocalhost就可以省略,如果端口号没有修改:-P3306也可以省略
简写成:

mysql -u root -p
Enter password:****

连接成功后,有关于MySQL Server服务版本的信息,还有第几次连接的id标识。也可以在命令行通过以下方式获取MySQL Server服务版本的信息:

c:> mysql -V
c:> mysql --version

登录后,通过以下方式查看当前版本信息:

mysql> select version();

退出登录:

exit

quit

4.MySQL演示使用

4.1 MySQL的使用演示

1、查看所有的数据库

show databases;

MySQL学习笔记第一天_第5张图片

“information_schema”是 MySQL 系统自带的数据库,主要保存 MySQL数据库服务器的系统信息,比如数据库的名称、数据表的名称、字段名称、存取权限、数据文件 所在的文件夹和系统使用的文件夹,等等
“mysql”数据库保存了 MySQL 数据库服务器运行时需要的系统信息,比如数据文件夹、当前使用的字符集、约束检查信息,等等
“performance_schema”是 MySQL 系统自带的数据库,可以用来监控 MySQL 的各类性能指标。
“sys”数据库是 MySQL 系统自带的数据库,主要作用是以一种更容易被理解的方式展示 MySQL数据库服务器的各类性能指标,帮助系统管理员和开发人员监控 MySQL 的技术性能。

2、创建自己的数据库

create databases 数据库名
#创建dbtest1数据库,该名称不能与已经存在的数据库重名。
create database dbtest1;

MySQL学习笔记第一天_第6张图片
3、使用自己的数据库

use 数据库名;
#使用dbtest1数据库
use dbtest1;

4、查看某个库的所有表格

show tables from 数据库名;
MySQL学习笔记第一天_第7张图片
5、创建新的表格
create table 表名称(
字段名 数据类型,
字段名 数据类型
);
#创建一个名为emploees的新表
create table employees(id int,name verchar(15));#说名字最长不超过15个字符

6、查看一个表的数据

select * from 数据库表名称;
#查看employees表的数据
select * from employees;

7.添加一条记录

insert into 表名称 values(值列表);
#添加两条记录到employees表中
insert into employees values(1001,‘wowotou’);
insert into employees values(1002,‘baobao’);
insert into employees values(1003’张三’);

5.7版本会报错:(字符集的问题)

mysql> insert into employees values(1003,‘张三’);
ERROR 1366 (HY000): Incorrect string value: ‘\xD5\xC5\xC8\xFD’ for column ‘name’ at
row 1

8.0版本不会报错
MySQL学习笔记第一天_第8张图片

8、查看表的创建信息

show create table 表名称;
#查看employees表的详细创建信息
show create table employees;

MySQL学习笔记第一天_第9张图片
上面的结果显示employees的表格的默认字符集是“utf8mb4”支持中文。

9、查看数据库的创建信息

在这里插入图片描述
10、删除表格

drop table 表名称;

11、删除数据库

drop database 数据库名;

#以下均是在8.0版本输出
create database dbtext1;
#输出:Query OK, 1 row affected (0.02 sec)

show databases;
#输出:(多了dbtext1)
#+--------------------+
#| Database           |
#+--------------------+
#| information_schema |
#| dbtext1            |
#| mysql              |
#| performance_schema |
#| sys                |
#+--------------------+
#5 rows in set (0.00 sec)

use dbtext1;
#输出:Database changed
create table employees(id int,name verchar(15));
#输出 Query OK, 0 rows affected (0.04 sec)

show tables;
/*输出
+-------------------+
| Tables_in_dbtext1 |
+-------------------+
| employees         |
+-------------------+
1 row in set (0.01 sec)
*/

insert into employees values(1001,'wowotou');
#输出 Query OK, 1 row affected (0.01 sec)
insert into employees values(1002,'baobao');
#输出 Query OK, 1 row affected (0.01 sec)
select *from employees;
#输出
+------+---------+
| id   | name    |
+------+---------+
| 1001 | wowotou |
| 1002 | baobao  |
+------+---------+
2 rows in set (0.00 sec)

insert into employees values(1003,'宝宝');
#5.7版本出错 不支持汉字
# 8.0版本输出:Query OK, 1 row affected (0.00 sec)
mysql> select *from employees;
+------+---------+
| id   | name    |
+------+---------+
| 1001 | wowotou |
| 1002 | baobao  |
| 1003 | 宝宝    |
+------+---------+
3 rows in set (0.01 sec)

mysql> show create table employees;
+-----------+---------------------------------------------------------------------------------------------------------------+
| Table     | Create Table
                                               |
+-----------+----------------------------------------------------------------------------------------------------------------+
| employees | CREATE TABLE `employees` (
  `id` int DEFAULT NULL,
  `name` varchar(15) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci |
+-----------+---------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> show variables like 'character_%';
+--------------------------+---------------------------------------------------------+
| Variable_name            | Value                                                   |
+--------------------------+---------------------------------------------------------+
| character_set_client     | gbk                                                     |
| character_set_connection | gbk                                                     |
| character_set_database   | utf8mb4                                                 |
| character_set_filesystem | binary                                                  |
| character_set_results    | gbk                                                     |
| character_set_server     | utf8mb4                                                 |
| character_set_system     | utf8mb3                                                 |
| character_sets_dir       | C:\Program Files\MySQL\MySQL Server 8.0\share\charsets\ |
+--------------------------+---------------------------------------------------------+
8 rows in set, 1 warning (0.02 sec)

mysql> show variables like 'collation_%';
+----------------------+--------------------+
| Variable_name        | Value              |
+----------------------+--------------------+
| collation_connection | gbk_chinese_ci     |
| collation_database   | utf8mb4_0900_ai_ci |
| collation_server     | utf8mb4_0900_ai_ci |
+----------------------+--------------------+
3 rows in set, 1 warning (0.00 sec)

4.2 MySQL的编码设置

MySQL版本5.7中

问题再现:命令行操作sql乱码问题

mysql> INSERT INTO t_stu VALUES(1,‘张三’,‘男’);
ERROR 1366 (HY000): Incorrect string value: ‘\xD5\xC5\xC8\xFD’ for column ‘sname’ at
row 1

问题解决:
步骤1:查看编码命令

#编码方式
show variables like ‘character_%’;
#比较规则
show variables like ‘collation_%’;

步骤2:修改mysql的数据目录下的my.ini配置文件:在my.ini文件里找到[mysqld]

[mysql] #大概在63行左右,在其下添加
default-character-set=utf8 #默认字符集
[mysqld] # 大概在76行左右,在其下添加
character-set-server=utf8
collation-server=utf8_general_ci

MySQL学习笔记第一天_第10张图片
步骤3:重启服务
步骤4:查看编码命令

MySQL版本8.0中

在MySQL 8.0版本之前,默认字符集为latin1,utf8字符集指向的是utf8mb3。网站开发人员在数据库设计的时候往往会将编码修改为utf8字符集。如果遗忘修改默认的编码,就会出现乱码的问题。从MySQL 8.0开始,数据库的默认编码改为 utf8mb4 ,从而避免了上述的乱码问题。

在8.0版本使用查看编码命令:
MySQL学习笔记第一天_第11张图片

5. MySQL图形化管理工具

MySQL图形化管理工具极大地方便了数据库的操作与管理,常用的图形化管理工具有:MySQLWorkbench、phpMyAdmin、Navicat Preminum、MySQLDumper、SQLyog、dbeaver、MySQL ODBC Connector。

6. MySQL目录结构与源码

6.1 主要目录结构

MySQL的目录结构 说明
bin目录 所有MySQL的可执行文件。如:mysql.exe
MySQLInstanceConfig.exe 数据库的配置向导,在安装时出现的内容
data目录 系统数据库所在的目录
my.ini文件 MySQL的主要配置文件
c:\ProgramData\MySQL\MySQL Server 8.0\data\ 用户创建的数据库所在的目录

6.2 MySQL 源代码获取

首先,你要进入 MySQL下载界面。 这里你不要选择用默认的“Microsoft Windows”,而是要通过下拉栏,找到“Source Code”,在下面的操作系统版本里面, 选择 Windows(Architecture Independent),然后点
击下载。
MySQL学习笔记第一天_第12张图片
接下来,把下载下来的压缩文件解压,我们就得到了 MySQL 的源代码。
MySQL 是用 C++ 开发而成的,我简单介绍一下源代码的组成。
mysql-8.0.22 目录下的各个子目录,包含了 MySQL 各部分组件的源代码:
MySQL学习笔记第一天_第13张图片

  • sql 子目录是 MySQL 核心代码;
  • libmysql 子目录是客户端程序 API;
  • mysql-test 子目录是测试工具;
  • mysys 子目录是操作系统相关函数和辅助函数;
    源代码可以用记事本打开查看,如果你有 C++ 的开发环境,也可以在开发环境中打开查看。

你可能感兴趣的:(数据库之自学成才,mysql,学习,笔记)