- 下载
- Mysql根目录下配置
my.ini
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
#设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=D:\\develop\\mysql\\mysql-5.7.19-winx64
# 设置mysql数据库的数据的存放目录
datadir=D:\\develop\\mysql\\mysql-5.7.19-winx64\\data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 免密码登陆
# skip-grant-tables
# 5.6开始,timestamp 的默认行为已经是 deprecated 了。
# 关闭timestamp警告
# 开启查询缓存
explicit_defaults_for_timestamp=true
-
将MySql设置成window服务
3.1 管理员执行:mysqld --initialize-insecure --user=mysql
执行完上面命令后,MySQL会自建一个data文件夹,并且建好默认数据库,登录的用户名为root,密码为空,之后就可以通过命令net start mysql
启动mysql服务了
3.2 以管理员身份运行添加:mysqld --install [mysql] #默认名称 mysql 移除:mysqld --remove [mysql] #默认名称 mysql 查看服务是否注册成功:services.msc 如果服务启动有问题执行初始化:mysqld --initialize
注:MySQL升级到5.7版本是没有data文件夹的,执行
mysqld --initialize-insecure --user=mysql
命令会自动新建data文件夹。 -
启动关闭服务
启动:net start MySQL 关闭: net stop MySQL
保存为
.bat
文件或 .cmd 文件
修改密码
-
关闭正在运行的 MySQL:
[root@www.woai.it ~]# service mysql stop
-
运行:
[root@www.woai.it ~]# mysqld_safe --skip-grant-tables &
-
为了安全可以这样禁止远程连接:
[root@www.woai.it ~]# mysqld_safe --skip-grant-tables --skip-networking &
-
使用mysql连接server:
[root@www.woai.it ~]# mysql -p
-
更改密码:
1. update mysql.user set authentication_string=password('123qwe') where user='root' and Host = 'localhost'; 2. flush privileges; 3. quit;
-
修改完毕。重启
[root@localhost ~]# service mysql restart
-
然后mysql就可以连接了
-
但此时操不安全,需要修改密码
alter user 'root'@'localhost' identified by '123';
这样也可以:
set password for 'root'@'localhost'=password('123');
特别提醒注意:
新版的mysql数据库下的user表中已经没有Password
字段了 而是将加密后的用户密码存储于authentication_string
字段
-
重点介绍下mysql 5.7 root密码修改
-
MySQL管理者密码设置或修改
依据官方说明5.6以后版本,第一次启动时会在root目录下生产一个随机密码,文件名.mysql_secret
[root@bright ~]# cat /root/.mysql_secret # Password set for user 'root@localhost' at 2015-03-27 23:12:10 :Jj+FTiqvyrF [root@bright ~]# cd /usr/local/mysql/bin/ [root@bright bin]# ./mysqladmin -u root -h localhost password '123456' -p
Enter password: #此行输入.mysql_secret里第二行内容
mysqladmin: [Warning] Using a password on the command line interface can be insecure. Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.
官方的方式,无论是否使用--skip-grant-tables启动mysql都测试失败,亲们可以测试: shell>mysql -uroot -p'password' #password即.mysql_secret里的密码 mysql>SET PASSWORD = PASSWORD('newpasswd');
-
旧版本,安装后ROOT无密码,按如下操作:
方法一:
shell> service mysqld stop #停止mysql服务
shell> mysqld_safe --skip-grant-tables & #以不启用grant-tables模式启动mysql
shell> mysql -uroot -p #输入命令回车进入,出现输入密码提示直接回车。
mysql> use mysql;
mysql> update user set password=PASSWORD("123456")where user="root"; #更改密码为 newpassord
mysql> flush privileges; #更新权限
mysql> quit #退出
方法二:
shell> service mysqld stop #停止mysql服务
shell> mysqld_safe --skip-grant-tables & #以不启用grant-tables模式启动mysql
shell> mysql -uroot -p #输入命令回车进入,出现输入密码提示直接回车。
mysql> set password for root@localhost = password('mysqlroot');
方法三:
shell> /path/mysqladmin -u UserName -h Host password 'new_password' -p
- MySQL修改root密码的4种方法(以windows为例)
方法1: 用SET PASSWORD命令
首先登录MySQL。
格式:mysql> set password for 用户名@localhost = password('新密码');
例子:mysql> set password for root@localhost = password('123');
方法2:用mysqladmin
格式:mysqladmin -u用户名 -p旧密码 password 新密码
例子:mysqladmin -uroot -p123456 password 123
方法3:用UPDATE直接编辑user表
首先登录MySQL。
mysql> use mysql;
mysql> update user set password=password('123') where user='root' and host='localhost';
mysql> flush privileges;#刷新
方法4:在忘记root密码的时候,可以这样
以windows为例:
1. 关闭正在运行的MySQL服务。
2. 打开DOS窗口,转到mysql\bin目录。
3. 输入mysqld --skip-grant-tables 回车。--skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。
4. 再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录。
5. 输入mysql回车,如果成功,将出现MySQL提示符 >。
6. 连接权限数据库: use mysql; 。
6. 改密码:update user set password=password("123") where user="root";(别忘了最后加分号) 。
7. 刷新权限(必须步骤):flush privileges; 。
8. 退出 quit。
9. 注销系统,再进入,使用用户名root和刚才设置的新密码123登录。