mysql阶段02 数据库基本操作, 误删用户案例解决, 数据库体系结构, mysql服务构成, mysql的逻辑/物理结构
[root@db03 ~]# mysqladmin -uroot password '123456'
#1.正确的登录方式 [root@db03 ~]# mysql -uroot -p123456 [root@db03 ~]# mysql -u root -p123456 #2.错误的登录方式 [root@db03 ~]# mysql -u root -p 123456 #3.原因: #如果使用-p或者--password参数,他们与密码之间不能有空格 #如果只写-p或者--password参数什么都不接,意思是让你手动输入密码 #4.登录数据库直接进行库 [root@db03 ~]# mysql -u root -p mysql
mysql> select user,host from mysql.user; +------+-----------+ | user | host | +------+-----------+ | root | 127.0.0.1 | | root | ::1 | | | db03 | | root | db03 | | | localhost | | root | localhost | +------+-----------+ 6 rows in set (0.00 sec)
mysql> drop user root@'::1'; Query OK, 0 rows affected (0.00 sec) mysql> drop user ''@'db03'; Query OK, 0 rows affected (0.00 sec) mysql> drop user ''@'localhost'; Query OK, 0 rows affected (0.00 sec) mysql> select user,host from mysql.user; +------+-----------+ | user | host | +------+-----------+ | root | 127.0.0.1 | | root | db03 | | root | localhost | +------+-----------+ 3 rows in set (0.00 sec)
mysql> delete from mysql.user where 1=1; Query OK, 3 rows maffected (0.00 sec) mysql> select user,host from mysql.user; Empty set (0.00 sec) #删除所有用户后还是可以登录,重启后登录失效 [root@db03 ~]# systemctl restart mysql [root@db03 ~]# mysql -uroot -p123456 Warning: Using a password on the command line interface can be insecure. ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
2.解决办法
1)停止数据库
[root@db03 ~]# systemctl stop mysql
#1.跳过授权表启动(不推荐) &后台启动 [root@db03 ~]# mysqld_safe --skip-grant-tables & #2.跳过授权表与网络启动数据库(只允许本机连接) [root@db03 ~]# mysqld_safe --skip-grant-tables --skip-networking & #注意:只跳过授权表登录很不安全,任何人都可以远程登录,所以还要限制只允许本机登录数据库 #如果要停止 mysqladmin shutdown
#1.切换到mysql库 mysql> use mysql; #2.插入用户数据 mysql> insert into mysql.user values ('localhost','root',PASSWORD('123456'), 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', '', '', '', '',0,0,0,0,'mysql_native_password','','N'); #3.查看用户 mysql> select user,host from mysql.user; +------+-----------+ | user | host | +------+-----------+ | root | localhost | +------+-----------+ 1 row in set (0.00 sec)
[root@db03 ~]# mysqladmin shutdown [root@db03 ~]# systemctl start mysql [root@db03 ~]# mysql -uroot -p123456 Warning: Using a password on the command line interface can be insecure. Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 2 Server version: 5.6.46 MySQL Community Server (GPL) ...
1)停止数据库
2)跳过授权表和网络登录
3)直接授权创建新用户
#刷新系统权限注册表 mysql> flush privileges; #授权一个新用户,要特别加上grant权限,否则没有 mysql> grant all on *.* to root@'localhost' identified by '123456' with grant option;
1.客户端与服务器模型
1)mysql是一个典型的C/S服务结构
1.mysql自带的客户端程序(/usr/local/mysql/bin) mysql mysqladmin mysqldump 2.mysqld一个二进制程序,后台的守护进程 单进程 多线程
1.TCP/IP的连接方式 2.套接字连接方式,也就是socket连接 3.举例 (通过status可以查看连接方式) 3.1 TCP/IP连接 mysql -uroot -p -h127.0.0.1 mysql -uroot -p -h127.0.0.1 -S /tmp/mysql.sock 3.2 socket连接 mysql -uroot -p -hlocalhost mysql -uroot -p123456 4.注意: 4.1 -h后跟IP地址是TCP/IP连接,-hlocalhost就是socket连接 4.2 socket连接速度比TCP/IP连接快,因为TCP/IP连接需要建立三次握手
1.MySQL的后台进程+线程+预分配的内存结构 2.MySQL在启动的过程中会启动后台守护进程,并生成工作线程,预分配内存结构供MySQL处理数据使用。 3.什么是实例? 一个进程 + 多个线程 + 分配内存空间 4.多实例? 多个进程 + 多个线程 + 分配内存空间
mysqld是一个守护进程
1.验证用户的身份,用户名密码是否匹配 2.提供两种连接方式(TCP/IP连接、socket连接) 3.连接层提供了一个与sql层交互的线程
1.接收连接层传过来的SQL语句 2.验证执行的SQL语法 3.验证SQL的语义(DDL,DML,DQL,DCL) 4.解析器:解析SQL语句,生成执行计划 5.优化器:将解析器传来的执行计划选择最优的一条执行 6.执行器:将最优的一条执行 6.1 与存储引擎层建立交互的线程 6.2 将要执行的sql发给存储引擎层 7.如果有缓存,则走缓存 8.记录日志(binlog)
1.接收SQL层传来的语句 2.与磁盘交互,获取数据,返回给sql层 3.建立与sql层交互的线程
1、库 2、表:元数据+真实数据行 3、元数据:列+其他属性 (行数+占用空间大小+权限) 4、列:列名字+数据类型+其他约束(非空、唯一、主键、非负数、自增长、默认值)
1)MySQL的最底层的物理结果是数据文件,也就是说,存储引擎层,打交道的文件,是数据文件。 2)存储引擎分为很多种类(Linux中的FS) 3)不同存储引擎的区别:存储方式、安全性、性能 #注意:开发创建数据库及表的时候全都要小写