MySQL之由修改编码而引起的重装

一:Mysql卸载

本文介绍,在Windows10系统下,如何彻底删除卸载MySQL,原文(https://www.cnblogs.com/dekevin/p/11581907.html)

1.停止MySQL服务

开始——所有应用——Windows管理工具——服务,将MySQL服务停止。(或cmd中net stop mysql)

2.卸载mysql server

控制面板\所有控制面板项\程序和功能,将mysql server卸载掉

3.将MySQL安装目录下的MySQL文件夹删除(我的安装目录是C:\Program Files (x86)\MySQL)

4.运行“regedit”文件,打开注册表。(注册表删除要注意)
删除HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Eventlog\Application\MySQL文件夹
删除HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\Eventlog\Application\MySQL文件夹。
删除HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application\MySQL的文件夹。
如果没有相应的文件夹,就不用删除了。

5.删除C盘下的“C:\ProgramData\MySQL ”文件夹,如果删除不了则用360粉碎掉即可,
该programData文件默认是隐藏的,设置显示后即可见,或者直接复制 C:\ProgramData 到地址栏回车即可进入!
将整个MySQL文件夹删除掉。

6.开始——所有应用——Windows管理工具——服务
如果已经将MySQL卸载,但通过“开始-》所有应用-》Windows管理工具-》服务”查看到MySQL服务仍然残留在
系统服务里。又不想改服务名,改怎么办呢。
只要在CMD里输入一条命令就可以将服务删除:
sc delete mysql //这里的mysql是你要删除的服务名
这样一来服务就被删除了。

7.这样就可以重装MySQL数据库了!

二:MySQL安装

注意:我是免安装版的Mysql,原文(https://www.cnblogs.com/winton-nfs/p/11524007.html)

1.官网下载免安装版MySQL

2.安装配置

解压到全英文路径目录下后,

1.以管理员身份打开命令行

2.在解压的bin目录下,运行mysqld --install来安装mysql的服务(有成功提示)

3.运行mysqld --initialize --console来初始化mysql,在这里,初始化会产生一个随机密码,位置在末尾(一定要截图保存)

4.开启mysql的服务(net start mysql)(这里出现错误,超半个小时没解决就卸载干净重装吧!)

5.登录验证,mysql是否安装成功!(要注意上面产生的随机密码,不包括前面符号前面的空格,否则会登陆失败)

三:加载配置my.ini文件

在使用ZIP安装时,安装好之后默认是没有my.ini配置文件的,原文:https://www.cnblogs.com/RayWang/p/9347874.html

1.删除Mysql服务

打开cmd(记得”使用管理员身份“打开),如果没有配置环境变量,请cd(切换目录)到mysql程序下的bin文件夹下

运行命令:

E:\JavaStudy\tools\mysql-5.7.30-winx64\bin>sc delete MySql

"MySql"为服务名称,你的MysSql服务不一定是这个名称,可以打开电脑的服务窗口查看。

删除完成之后,最好去电脑的服务窗口看下,如果找不到MySql服务,说明已经已经删除成功。

如果还能看到MySql服务,可以手动右击选择”停止“,服务停止之后就会自动消失了。

2.新建my.ini配置文件

位置:E:\JavaStudy\tools\mysql-5.7.30-winx64(在mysql程序的根目录下)

改动:basedir和datadir(data文件夹可以为空)

注意:配置目录是要注意是否有需要转义的字符,如:\t要改成\\t

[client]
port=3306
default-character-set=utf8

[mysql]
default-character-set=utf8

# default-character-set=

[mysqld]
port=3306
character-set-server=utf8

# mysql根目录
basedir=E:\JavaStudy\\tools\mysql-5.7.30-winx64

# 放所有数据库的data目录
datadir=E:\JavaStudy\\tools\mysql-5.7.30-winx64\data

# character-set-server=

# 默认存储引擎innoDB
default-storage-engine=INNODB

# Set the SQL mode to strict
sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

#日志输出为文件
log-output=FILE

# 是否开启sql执行结果记录,必须要设置general_log_file参数,日志的路径地址
# 即日志跟踪,1为开启,0为关闭
general-log=0
general_log_file="execute_sql_result.log"

# 配置慢查询,5.7版本默认为1
#slow-query-log=1
#slow_query_log_file="user-slow.log"
#long_query_time=10

#默认不开启二进制日志
#log-bin=mysql-log

#错误信息文件设置,会将错误信息放在data/mysql.err文件下
log-error=mysql.err

# Server Id.数据库服务器id,这个id用来在主从服务器中标记唯一mysql服务器
server-id=1

#lower_case_table_names: 此参数不可以动态修改,必须重启数据库
#lower_case_table_names = 1  表名存储在磁盘是小写的,但是比较的时候是不区分大小写
#lower_case_table_names=0  表名存储为给定的大小和比较是区分大小写的 
#lower_case_table_names=2, 表名存储为给定的大小写但是比较的时候是小写的
lower_case_table_names=1

#限制数据的导入导出都只能在Uploads文件中操作,这个是在sql语句上的限制。
#secure-file-priv="D:\AppServ\mysql-5.7.23/Uploads"
#值为null ,也就是注释掉这个参数或者secure-file-priv=null。表示限制mysqld 不允许导入|导出
#值为/tmp/ ,即secure-file-priv="/tmp/" 表示限制mysqld 的导入|导出只能发生在/tmp/目录下
#没有具体值时,即secure-file-priv=      表示不对mysqld 的导入|导出做限制

# 最大连接数
max_connections=151
# 打开表的最大缓存数
table_open_cache=2000

# tmp_table_size 控制内存临时表的最大值,超过限值后就往硬盘写,写的位置由变量 tmpdir 决定 
tmp_table_size=16M

# 每建立一个连接,都需要一个线程来与之匹配,此参数用来缓存空闲的线程,以至不被销毁,
# 如果线程缓存中有空闲线程,这时候如果建立新连接,MYSQL就会很快的响应连接请求。
# 最大缓存线程数量
thread_cache_size=10

3.重新生成data文件

删除之前生成的data文件,如果有重要的数据表,请先备份好。

回到cmd,重新生成data文件。运行:

E:\JavaStudy\tools\mysql-5.7.30-winx64\bin>mysqld --initialize-insecure --user=mysql

该命令需要执行大概一分钟左右,完成后会在MySql程序文件夹下重新生成名称为data的文件夹

4.重新安装mysql服务,同时绑定my.ini配置文件

安装MySql服务,同时设置绑定my.ini配置文件。命令:

D:\MySql\bin>mysqld --install "MySql" --defaults-file="E:/JavaStudy/tools/mysql-5.7.30-winx64/my.ini"

“MySql80”是服务名称,当然,也可以自己取别的名字。

”..\my.ini“是新建的配置文件的位置,也可以写成绝对路径”D:\MySql\my.ini“。

5.启动服务

这里有两种启动服务的方式:1)服务窗口启动服务;2)cmd启动服务(net start 服务名) (等待20秒左右,成功后会显示的)

6.重新设置密码

登录

E:\JavaStudy\tools\mysql-5.7.30-winx64\bin>mysql -u root -p

登陆成功后修改(参考:https://www.cnblogs.com/yang82/p/7794712.html)

格式:mysql> set password for 用户名@localhost = password('新密码');

例子:mysql> set password for root@localhost = password('123');

四:修改mysql为utf8编码格式

1.首先查看编码情况

首先通过 show variables like 'character_set_%';查看mysql字符集情况

database和server的字符集使用了latin1编码方式时,需要改为utf8格式

2.修改

在my.ini文件下,复制上面代码到my.ini文件保存覆盖即可,作用代码如下,

[client]
port=3306
default-character-set=utf8

[mysql]
default-character-set=utf8

# default-character-set=

[mysqld]
port=3306
character-set-server=utf8

3.再次查看编码情况

猜你喜欢

转载自www.cnblogs.com/bigbeardhk/p/13173739.html