失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > MySQL常见问题的解决 root用户密码忘记 不是内部或外部命令 修改数据库和表的字符

MySQL常见问题的解决 root用户密码忘记 不是内部或外部命令 修改数据库和表的字符

时间:2022-04-12 05:58:01

相关推荐

MySQL常见问题的解决 root用户密码忘记 不是内部或外部命令 修改数据库和表的字符

文章目录

问题1:root用户密码忘记,重置的操作问题2:mysql命令报“不是内部或外部命令”问题3:错误ERROR :没有选择数据库就操作表格和数据问题4:命令行客户端的字符集问题问题5:修改数据库和表的字符编码

问题1:root用户密码忘记,重置的操作

1: 通过任务管理器或者服务管理,关掉mysqld(服务进程)

2: 通过命令行+特殊参数开启mysqld mysqld – defaults-file=“D:\ProgramFiles\mysql\MySQLServer5.7Data\my.ini” --skip-grant-tables

3: 此时,mysqld服务进程已经打开。并且不需要权限检查

4: mysql -uroot 无密码登陆服务器。另启动一个客户端进行

5: 修改权限表 (1) use mysql; (2)update user set authentication_string=password(‘新密码’) where user=‘root’ and Host=‘localhost’; (3)flush privileges;

6: 通过任务管理器,关掉mysqld服务进程。

7: 再次通过服务管理,打开mysql服务。 8: 即可用修改后的新密码登陆。

问题2:mysql命令报“不是内部或外部命令”

如果输入mysql命令报“不是内部或外部命令”,把mysql安装目录的bin目录配置到环境变量path中。如下:

问题3:错误ERROR :没有选择数据库就操作表格和数据

ERROR 1046 (3D000): No database selected

解决方案一:就是使用“USE 数据库名;”语句,这样接下来的语句就默认针对这个数据库进行操作

解决方案二:就是所有的表对象前面都加上“数据库.”

问题4:命令行客户端的字符集问题

mysql> INSERT INTO t_stu VALUES(1,‘张三’,‘男’); ERROR 1366 (HY000):

Incorrect string value: ‘\xD5\xC5\xC8\xFD’ for column ‘sname’ at row 1

原因:服务器端认为你的客户端的字符集是utf-8,而实际上你的客户端的字符集是GBK。

查看所有字符集:SHOW VARIABLES LIKE ‘character_set_%’;

解决方案,设置当前连接的客户端字符集 “SET NAMES GBK;”

问题5:修改数据库和表的字符编码

修改编码:

①先停止服务②修改my.ini文件③重新启动服务

说明:如果是在修改my.ini之前建的库和表,那么库和表的编码还是原来的Latin1,要么删了重建,要么使用alter语句修改编码。

mysql> create database 0728db charset Latin1;Query OK, 1 row affected (0.00 sec)mysql> use 0728db;Database changedmysql> create table student (id int , name varchar(20)) charset Latin1;Query OK, 0 rows affected (0.02 sec)mysql> show create table student\G*************************** 1. row ***************************Table: studentCreate Table: CREATE TABLE `student` (`id` int(11) NOT NULL,`name` varchar(20) DEFAULT NULL,PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=latin11 row in set (0.00 sec)mysql> alter table student charset utf8; #修改表字符编码为UTF8Query OK, 0 rows affected (0.01 sec)Records: 0 Duplicates: 0 Warnings: 0mysql> show create table student\G*************************** 1. row ***************************Table: studentCreate Table: CREATE TABLE `student` (`id` int(11) NOT NULL,`name` varchar(20) CHARACTER SET latin1 DEFAULT NULL, #字段仍然是latin1编码PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf81 row in set (0.00 sec)mysql> alter table student modify name varchar(20) charset utf8; #修改字段字符编码为UTF8Query OK, 0 rows affected (0.05 sec)Records: 0 Duplicates: 0 Warnings: 0mysql> show create table student\G*************************** 1. row ***************************Table: studentCreate Table: CREATE TABLE `student` (`id` int(11) NOT NULL,`name` varchar(20) DEFAULT NULL,PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf81 row in set (0.00 sec)mysql> show create database 0728db;;+--------+-----------------------------------------------------------------+|Database| Create Database |+------+-------------------------------------------------------------------+|0728db| CREATE DATABASE `0728db` /*!40100 DEFAULT CHARACTER SET latin1 */ |+------+-------------------------------------------------------------------+1 row in set (0.00 sec)mysql> alter database 0728db charset utf8; #修改数据库的字符编码为utf8Query OK, 1 row affected (0.00 sec)mysql> show create database 0728db;+--------+-----------------------------------------------------------------+|Database| Create Database |+--------+-----------------------------------------------------------------+| 0728db | CREATE DATABASE `0728db` /*!40100 DEFAULT CHARACTER SET utf8 */ |+--------+-----------------------------------------------------------------+1 row in set (0.00 sec)

MySQL常见问题的解决 root用户密码忘记 不是内部或外部命令 修改数据库和表的字符编码 命令行客户端的字符集问题

如果觉得《MySQL常见问题的解决 root用户密码忘记 不是内部或外部命令 修改数据库和表的字符》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。