zoukankan      html  css  js  c++  java
  • MySQL 5.7版本安装教程-踩坑总结

    下载

    MySQL下载地址
    选择下载64位(看自己电脑是32位还是64位)
    下载

    点击下载之后,它会让你登录,没有Oracle账户,跟着它的步骤注册一个就好了。

    安装

    打开下载好的压缩包解压到你的某一目录下,这里我放到了D:MySQL下

    文件位置

    如上图所示,在你解压的文件夹下是没有my.ini这个配置文件的,需要自己创建并用记事本打开,把下面这些代码粘贴复制进去

    [mysql]
    # 设置mysql客户端默认字符集
    default-character-set=utf8 
    [mysqld]
    #设置3306端口
    port = 3306 
    # 设置mysql的安装目录
    basedir=D:MySQLmysql-5.7.16-winx64
    # 设置mysql数据库的数据的存放目录
    #datadir=D:MySQLmysql-5.7.16-winx64data
    # 允许最大连接数
    max_connections=200
    # 服务端使用的字符集默认为8比特编码的latin1字符集
    character-set-server=utf8
    # 创建新表时将使用的默认存储引擎
    default-storage-engine=INNODB 
    

    我在安装的时候,找了一个教程,教程中上面的#datadir=D:MySQLmysql-5.7.16-winx64data这句代码是没有注释掉的,于是我就在之后的安装中遇到了麻烦。

    填坑

    首先配置默认文件

    当我没有注释掉那句代码时,也就是这样子配置的

    [mysql]
    # 设置mysql客户端默认字符集
    default-character-set=utf8 
    [mysqld]
    #设置3306端口
    port = 3306 
    # 设置mysql的安装目录
    basedir=D:MySQLmysql-5.7.16-winx64
    # 设置mysql数据库的数据的存放目录
    datadir=D:MySQLmysql-5.7.16-winx64data
    # 允许最大连接数
    max_connections=200
    # 服务端使用的字符集默认为8比特编码的latin1字符集
    character-set-server=utf8
    # 创建新表时将使用的默认存储引擎
    default-storage-engine=INNODB 
    

    接下来开始安装

    安装并启动

    直接搜cmd,右键->以管理员身份运行
    进入bin文件目录下

    接下来输入安装、启动命令

    mysql install
    net start mysql

    出现如下图问题

    无法启动却无报错,在计算机管理服务里也无法手动启动。有大神说可以执行

    mysqld --console

    命令查看错误信息,如下图,意思是说没有data文件,而在my.ini配置文件中代码里设置了(datadir=D:MySQLmysql-5.7.16-winx64data)

    所以我就自己跑去新建了个data文件夹,再启动然而依旧错误漫天飞,Excuse me?
    最后终于找到靠谱的答案,data文件是不需要自己配置的,先删除自己自作聪明的data文件,然后注释掉my.ini中的datadir代码,配置环境变量然后执行

    mysqld --initialize

    即可自动生成data文件,这个时候再执行

    net start mysql

    命令,可以看到MySQL启动成功

    登录MySQL

    输入命令 mysql -uroot -p 回车,输入密码,按理说初次登录是没有密码的,直接回车即可登录,然而事实上,在执行 mysqld --initialize命令时它不仅自动创建了data数据,还随机分配了密码,在你的文件中搜索 .err后缀的文件,以记事本方式打开,你会看到下图

    对,这就是你的密码,每个人不一样,看你自己的,输入进去登录就可以了。接下来你想进行一些操作,发现它会提示你,需要先重置密码。那么接下来再看重置密码的坑。

    重置密码

    在网上查找方法,基本上都是如下步骤:

    然而我输入命令结果是这样子的

    正确的打开方式是首先在my.ini配置文件的[mysqld]下面加上

    [mysqld]
    explicit_defaults_for_timestamp = true

    然后输入如下命令,回车后会一直停止,然后打开另一个cmd命令窗口

    mysqld --default-file="D:MySQLmysql-5.7.16-winx64my.ini" --skip-grant-tables

    mysql -u root

    输入更改密码的语句

    use mysql
    UPDATE mysql.user SET password=PASSWORD("lyymysql") WHERE User='root';

    然而结果如图

    所以查看数据库,发现5.7版本里的user表里已经没有了password这个字段

    正确姿势:

    update mysql.user set authentication_string=PASSWORD('lyymysql') WHERE User='root';
    flush privileges
    exit

    吁~这下终于可以启动登录MySQL 了

    这一上午踩坑踩得真呀么欢快~

    小提示:以上命令中的路径都要改为自己的路径,要不然是不对的。如果有什么疑问可以在下方评论。

  • 相关阅读:
    LNMP源码编译安装(centos7+nginx1.9+mysql5.6+php7)
    linux 最大文件查找
    Nginx 日志分享
    ZendGuardLoader安装
    移动端播放直播流(video.js 播放 m3u8 流)
    Linux下 PostgrelSQL 基本操作
    CenterOS7 安装Mysql8 及安装会遇到的问题
    Linux下 导出postgrelSql 数据库
    《编译程序设计原理与技术》笔记之自动机与正规表达式
    Linux定时检测内存,若使用率超过指标,重启Tomcat并清空内存
  • 原文地址:https://www.cnblogs.com/MemoryLily/p/5980413.html
Copyright © 2011-2022 走看看