Mysql学习第一课-mysql的定义及sql语句

时间:2022-10-01 20:03:12
20160829-mysqlday1
1.mysql的定义
1)数据库管理系统
管理数据,数据库当中的最小单位表
文本方式保存:读文件从头开始,速度非常慢
数据库:索引,(图片,视频)
-----
1
2


5000000
-----
读帖子---400000


2)c/s----》b/s
客户端 浏览器
麻烦 方便
安全
稳定


3)开放源码
GNU--》GPL 


4)关系型
表和表之间支持一定的关系


5)sql
结构化查询语言


6)多os
linux、windows


7)mysqlab-->sun-->oracle--->mysql
--mariadb分支


===================================
2.存储引擎
数据库的读写速度的快慢
数据库读写数据的方式---存储引擎
mysql---插件式的
两大知名存储引擎---》表 
默认 事务 锁机制 适用场景
MYISAM  mysql5.5之前 非事务 表锁 线下分析
INNODB mysql5.5开始 事务 行锁 线上金钱类
-----------------------------
# 事务 ACID
----------------
表1--余额表
10000 10000-5000


表2--已购物表
+1手机
----------------------------------
原子性,
begin;
10000-5000
+1
commit;
===============================================
# 锁


写锁和读锁
锁精度:表锁和行锁
写不能写
写不能读
读能读
读不能写
-----------------------
myisam表
-----
superman
batman


-----
batman 发帖----写锁---表
superman发帖---不能
superman读写---能
---------------------
batman 读贴----读锁---表
superman读贴---能
supermna写贴---不能
=================================
innodb表
batman 发帖----写锁---行
superman发帖---写锁---行
superman读写---能
==============================================================
3.安装适用mysql(mariadb)
OS
mysql5.1 rhel6.5
mysql5.5 mariadb5.5 rhel7.2
mysql5.6 mariadb10.0
mysql5.7 mariadb10.1
mariadb10.2


软件名 mariadb-server 5.5
service mariadb
daemon mysqld
配置文件 /etc/my.cnf
/etc/my.cnf.d/*.cnf
数据文件 /var/lib/mysql
日志文件 /var/log/mariadb/mariadb.log(错误日志,启动日志)
端口号 3306


==============================================================
# 安装必要的软件包
[root@mastera0 ~]# yum install -y vim net-tools wget


[root@mastera0 ~]# yum list|grep mariadb
Repodata is over 2 weeks old. Install yum-cron? Or run: yum makecache fast
mariadb-libs.x86_64                     1:5.5.44-2.el7             @anaconda/7.2
mariadb.x86_64                          1:5.5.44-2.el7             rhel_dvd     
mariadb-bench.x86_64                    1:5.5.44-2.el7             rhel_dvd     
mariadb-devel.i686                      1:5.5.44-2.el7             rhel_dvd     
mariadb-devel.x86_64                    1:5.5.44-2.el7             rhel_dvd     
mariadb-libs.i686                       1:5.5.44-2.el7             rhel_dvd     
mariadb-server.x86_64                   1:5.5.44-2.el7             rhel_dvd     
mariadb-test.x86_64                     1:5.5.44-2.el7             rhel_dvd     
[root@mastera0 ~]# yum install -y mariadb-server
# 查看软件架构
[root@mastera0 ~]# rpm -ql mariadb-server
# 启动服务
[root@mastera0 ~]# systemctl start mariadb
# 查看守护进程
[root@mastera0 ~]# ps -ef|grep mysqld
mysql     2496     1  0 13:56 ?        00:00:00 /bin/sh /usr/bin/mysqld_safe --basedir=/usr
mysql     2653  2496  0 13:56 ?        00:00:00 /usr/libexec/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib64/mysql/plugin --log-error=/var/log/mariadb/mariadb.log --pid-file=/var/run/mariadb/mariadb.pid --socket=/var/lib/mysql/mysql.sock
root      2694  2347  0 13:56 pts/0    00:00:00 grep --color=auto mysqld
# 查看监听端口号
[root@mastera0 ~]# netstat -luntp|grep mysqld
tcp        0      0 0.0.0.0:3306            0.0.0.0:*               LISTEN      2653/mysqld 


===========================================
4.客户端


软件名称 mariadb 5.5
命令 mysql 登陆连接mysql服务器
mysqladmin 修改数据库服务器用户密码
mysqldump 备份
mysqlbinlog 二进制日志的查看

-------------------------------------------
命令的使用
mysql
1.服务启动后,mariadb5.5直接登陆,不需要密码
2.退出 \q exit ctrl+d

mysqladmin -uroot password 'uplooking'
-u 用户名 空格可有可无 -u root;-uroot
password 新密码 一定要有空格


mysql -uroot -puplooking
-u 用户名  空格可有可无 -u root;-uroot
-p 密码  不可以有空格 -puplooking


mysqladmin -uroot -puplooking password 'uplooking123'
-u 用户名 可有可无
-p 当前密码 不能有
password 新密码


mysql -uroot -puplooking123
----------------------------------------------
SQL语句
* sql命令不区分大小,数据库,表,数据是区分大小写的
* sql语句以分号提交


# 分类
DDL 数据库定义语言 create\drop\alter

create database [dbname];
drop database [dbname];
create table [tbname] (col1 type,col2 type,col3....);
drop table [tbname];

DML 数据库操作语言 insert into\delete from\update
insert into [tbname] set col1=value,col2=value,col3=value;
insert into [tbname] values (1,'booboo'),(2,'batman'),(3,'superman');
insert into [tbname] (name,id) values ();
delete from [tbname] where id=1 and name='booboo';
update [tbname] set col='superman' where id=2;

DCL 数据库控制语言 grant revoke
认证 + 授权
grant all on *.* to booboo@'172.25.0.11' identified by 'uplooking';
all 权限 
*.* 库.表
flush privileges; 刷新授权表
revoke [权限] on [库].[表] from booboo@'172.25.0.11';


DQL 数据库查询语言 show databases;
use mysql;
show tables;
desc mysql.user;
select * from db1.t1;


-------------------------------------------------
课堂作业:
1.查看mysql库中user表中的host,user,password列的值;
2.删除mysql库中的user表中,user列为空或者password列为空的行;


MariaDB [mysql]> select host,user,password from mysql.user;
+----------------------+------+-------------------------------------------+
| host                 | user | password                                  |
+----------------------+------+-------------------------------------------+
| localhost            | root | *6FF883623B8639D08083FF411D20E6856EB7D2BF |
| mastera0.example.com | root |                                           |
| 127.0.0.1            | root |                                           |
| ::1                  | root |                                           |
| localhost            |      |                                           |
| mastera0.example.com |      |                                           |
+----------------------+------+-------------------------------------------+
6 rows in set (0.00 sec)


MariaDB [mysql]> delete from mysql.user where user=' ' or password=' ';
Query OK, 5 rows affected (0.00 sec)


MariaDB [mysql]> select host,user,password from mysql.user;
+-----------+------+-------------------------------------------+
| host      | user | password                                  |
+-----------+------+-------------------------------------------+
| localhost | root | *6FF883623B8639D08083FF411D20E6856EB7D2BF |
+-----------+------+-------------------------------------------+
1 row in set (0.00 sec)
=====================================================================================
实验2:添加授权用户
实验要求:添加授权用户测试客户机优先使用的哪个密码
user1@'172.25.X.%' uplooking
user1@'172.25.X.12' uplooking123


172.25.X.11 mastera


masterb去登陆连接mastera的mariadb-server:


1.install mariadb
2.friewalld
3.mysql -u -p -h 


======================================================
如何破解mariadb5.5的root密码
1.停止服务 systemctl stop mariadb
2.跳过授权表启动服务 mysqld_safe --skip-grant-tables &  
  查看服务名称的方法: (ps -ef|grep mysqld;rpm -ql mariadb)
3.mysql-->update mysql.user set password=password('uplooking')   where user='root'; 
4.停止跳过授权表启动服务 kill -9
5.启动服务 systemctl start mariadb
===============================


晚自习作业:
1.熟悉sql语句,bookshop
2.查看授权表
3.添加授权用户
4.破解root密码


-------------------------------------------------------