MySQL-day03
一、mysql存储引擎
1.1  存储引擎介绍: 是mysql数据库软件自带的功能程序,
每种存储引擎的功能和数据存储方式也不同
存储引擎就处理表的处理器 

创新互联公司是专业的新市网站建设公司,新市接单;提供成都网站建设、网站设计,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行新市网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
1.2  查看数据库服务支持的存储引擎有那些?
mysql>   show  engines;
InnoDB             DEFAULT
1.3  查看已有的表使用的存储引擎
show   create  table 表名;
1.4  修改数据库服务默认使用的存储引擎
]#vim /etc/my.cnf
[mysqld]
default-storage-engine=myisam
:wq
]# systemctl  restart   mysqld
1.5  修改表使用的存储引擎,或 建表时指定表使用的存储引擎
alter  table  表   engine=存储引擎名;
create  table  表(字段列表)engine=存储引擎名;
1.6 常用存储引擎的特点
innodb特点:
支持事务  、 事务回滚   、行级锁  、外键
存储方式: 一个表对应2个存储文件
表名.frm    表结构
表名.ibd     数据和索引
myisam特点
不支持事务  、 事务回滚、外键
支持表级锁
存储方式: 一个表对应3个存储文件
表名.frm     表结构
表名.MYD   数据
表名.MYI     索引
事务:对数据库服务的访问过程(连接数据库服务器 操作数据 断开连接)
事务回滚 : 在事务执行过程中,任何一步操作失败,都会恢复之前的所有操作。
支持事务的表有对应的事务日志文件记录
插卡 (与数据库服务器建立连接)
转账:  对方卡号   888888
金额          50000
ok
提示转账成功   -50000      +50000
提示转账失败   +50000
退卡
mysql数据库服务使用事务日志文件记录,对innodb存储引擎表执行的sql操作。
cd  /var/lib/mysql/
ib_logfile0 -|
|------> 记录SQL命令
ib_logfile1 -|
insert into  t1  values(8888);
ibdata1 ----> 数据源(sql命令执行后产生的数据信息)
锁粒度:
表级锁(myisam)给整张表加锁  (不管你访问一行还是几行 都会把整张表进行加锁)
行级锁 (innodb)    只给表中当前被操作行加锁
锁的作用:解决对表的并发访问冲突问题。
select  *  from  t1  where   id <=20;
insert
delete   from  t1;
update  t1  set  name="bob"  where  name="lucy";
update  t1  set  name="tom"  where  name="jerry";
根据客户端的访问类型 锁又分为读锁和写锁
锁类型
读锁  (共享锁)  select
写锁  (互斥锁/排他锁)  insert update delete
事务特性 (ACID)
• Atomic :原子性
– 事务的整个操作是一个整体,不可分割,要么全部成功,要么全部失败。
• Consistency : 一致性     例如 银行转账
– 事务操作的前后,表中的记录没有变化。
• Isolation :隔离性
– 事务操作是相互隔离不受影响的。
• Durability :持久性
– 数据一旦提交,不可改变,永久改变表数据
1.7 建表时如何决定表使用那种存储引擎
执行写操作多的表适合使用innodb存储引擎,此引擎支持行级锁,这样对表的并发访问量大。
执行查操作多的表适合使用myisam存储引擎,可以节省系统资源,此引擎支持表级锁,
++++++++++++++++++++++++++++++++++++++
二、数据导入导出(批量操作数据)
2.1  数据导入的命令格式及数据导入时的注意事项
导入数据的命令格式:
数据导入:把系统文件的内容存储到数据库服务器的表里。
把系统已有用户的信息保存到db3库下的usertab表里
创建存储数据表
create  database  db3;
create  table  db3.usertab(
username    char(50),
password     char(1),
uid               int(2),
gid              int(2),
comment   char(100),
homedir     char(100),
shell         char(50),
index(username)
);
desc  db3.usertab;
select   * from  db3.usertab;
导入数据
]# cp /etc/passwd    /var/lib/mysql-files/
mysql>
load  data  infile   "/var/lib/mysql-files/passwd"
into  table    db3.usertab
fields  terminated by ":"
lines  terminated  by   "\n";
mysql> alter  table  db3.usertab
add
id  int(2)  primary key  auto_increment  first;
mysql> select    from   db3.usertab;
mysql> select    from   db3.usertab   where  id=20;
load  data  infile   "/mysqldata/passwd"
into  table    db3.usertab
fields  terminated by ":"
lines  terminated  by   "\n";
2.2 数据导出的命令格式及数据导出时的注意事项
mysql>select username,uid from db3.usertab into outfile "/mysqldata/user1.txt";
mysql>select * from db3.usertab into outfile "/mysqldata/user2.txt";
mysql>select username,uid from db3.usertab into outfile "/mysqldata/user3.txt" fields terminated by "###";
]# cat  /mysqldata/user1.txt
]# cat  /mysqldata/user2.txt
]# cat  /mysqldata/user3.txt
三、管理表记录(db3.usertab)
插入记录
mysql> insert into  usertab
values
(43,"yaya","x",1001,1001,"","/home/yaya","/bin/bash");
mysql> insert into  usertab
values (50,"yaya2","x",1002,1002,"","/home/yaya2","/sbin/nologin"),(51,"7yaya","x",1003,1003,"","/home/7yaya","/sbin/nologin");
insert into   usertab(username,homedir,shell)
values
("lucy","/home/lucy","/bin/bash");
insert into   usertab(username,homedir,shell)
values
("lu8cy","/home/lu8cy","/bin/bash"),("tom","/home/tom","/bin/bash"),("lilei","/home/lilei","/bin/bash");
+++++++++查看记录
select  *  from   db3.usertab;
select * from usertab where id = 1;
select id,username,password from db3.usertab;
select username,uid,shell from usertab where id = 1;
------修改记录
update   db3.usertab  set   password="A"  ;
update   db3.usertab  set   password="x"   where id=1;
select   *   from  db3.usertab;
-----删除记录
delete  from   db3.usertab    where   id=3;
四、匹配条件(查看selcet 修改update 删除delete记录时可以加条件)
4.1  数值比较   字段名   符号    数字
=   !=    <      <=       >     >=
select  username  from  usertab  where  uid=10;
select  id,username,uid  from  usertab  where  uid=1001;
select  *  from  usertab  where  id<=10;
4.2  字符比较       字段名   符号    “字符串”
=   !=
select  username  from  usertab  where  username="apache";
select  username,shell  from  usertab  where  shell="/bin/bash";
select  username,shell   from  usertab  where  shell!="/bin/bash";
4.3 范围内比较
字段名  between  数字1  and  数字2         在...之间...
字段名   in  (值列表)                                  在...里
字段名   not  in   (值列表)                         不在...里
select  username    from  usertab  where uid  between 100 and 150;
select username,uid from usertab where uid in (10,20,30,50);
select username,uid from usertab where username in ("root","rsync","mysql");
select username from usertab where username not in ("root","bin");
4.4 逻辑比较(就是有个查询条件)
逻辑与 and            多个条件同时成立    才匹配
逻辑或   or             多个条件,某一个条件成立  就匹配
逻辑非  ! 或 not    取反
select username,uid from usertab where username="root" and uid=0 and shell="/bin/bash";
select username,uid from usertab where username="root" or uid=1 or shell="/bin/bash";
select username,uid from usertab where username="root" or username="apache" or username="bob";
4.5  匹配空     字段名  is  null
匹配空     字段名  is  not  null
select  username,uid,gid  from  usertab
where
uid is null  and  gid  is  null;
mysql> update usertab set uid=3000,gid=3000 where username="lucy";
select id from usertab where name="yaya" and uid is not null;
update usertab set username=null where id=2;
4.6 模糊匹配
字段名  like   '表达式';
%   表示零个或多个字符
_    表任意一个字符
select  username from  usertab where  username like  '   ';
select  username from  usertab where  username like  'a_ _t';
insert into usertab(username)values("a");
select  username from  usertab where  username like  'a%';
select  username from  usertab where  username like  '%';
4.7 正则匹配
字段名  regexp   '正则表达式';
^   $    .    *   [  ]
select  username  from usertab where  username  regexp '[0-9]';
select  username  from usertab where  username  regexp '^[0-9]';
select  username  from usertab where  username  regexp '[0-9]$';
select username from usertab where username regexp 'a.*t';
select username from usertab where username regexp '^a.*t$';
select  username,uid  from usertab where  uid  regexp '..';
select  username,uid  from usertab where  uid  regexp '^..$';
4.7 四则运算(select 和 update 操作是可以做数学计算)
字段类型必须数值类型(整型 或浮点型)
- 
- 
- / %
 
 
- 
select  id,username,uid  from usertab where  id <=10;
update  usertab  set  uid=uid+1  where  id <=10;
select   username ,uid,gid  from usertab where usernane="mysql";
select   username ,uid,gid, uid+gid  as  zh  from usertab where username="mysql";
select username ,uid,gid, uid+gid as zh , (uid+gid)/2 as pjz from usertab where username="mysql";
alter table usertab add age tinyint(2) unsigned default 21 after username;
mysql> select  username,age from usertab;
select  username , age ,  2018-age   s_year   from usertab where username="root";
4.9聚集函数(对字段的值做统计,字段的类型要求是数值类型)
count(字段名)统计字段值的个数
sum(字段名)  求和
max(字段名)  输出字段值的最大值
min(字段名)  输出字段值的最小值
avg(字段名)  输出字段值的平均值
select  max(uid)  from usertab;
select  sum(uid)  from usertab;
select  min(uid)  from usertab;
select  avg(uid)  from usertab;
select  count(id)  from usertab;
select  count(username) from usertab where shell="/bin/bash";
4.10 查询不显示字段重复值 distinct 字段名
select distinct shell from usertab;
select distinct shell from usertab where uid >10 and uid<=100;
4.11查询分组
sql查询   group   by  字段名;
select shell  from  usertab where  uid >10  and uid<=100
group  by  shell;
4.12 查询排序 (按照数值类型的字段排队)
sql查询  order  by  字段名  asc|desc;
select username,uid from usertab where uid >10 and uid<=100 order by uid;
select username,uid from usertab where uid >10 and uid<=100 order by uid desc;
查询结果过滤
基本用法
– SQL 查询 having  条件表达式;
– SQL 查询 where 条件 HAVING 条件表达式;
– SQL 查询 group by 字段名 HAVING 条件表达式;
4.13 限制查询显示行数(默认显示所有查询的记录)
sql查询  limit  数字; 显示查询结果的前几行
sql查询  limit  数字1,数字2;  显示查询结果指定范围的行
select  username,uid   from  usertab where  uid >10  and uid<=100
order  by  uid  desc  limit  1;
select  username,uid   from  usertab where  uid >10  and uid<=100
order  by  uid  desc  limit 2,3;
##########################################################################################
一、多表查询
1.1  复制表
作用?   备份表   和 快速建表
命令格式?   create   table   库.表   sql查询命令;
例子?
create  table  db3.user2   select   *  from  db3.usertab;
create table db3.user3 select username,uid,shell from db3.usertab limit 5;
create  database   db4;
create   table  db4.t1   select   *  from  db3.usertab  where   1 =2;
create table db4.t2 select id,username,uid,homedir from db3.usertab where 1 =2;
1.2 where嵌套查询
select username,uid  from db3.usertab where uid < (select  avg(uid)  from  db3.usertab)
;
mysql> select username,uid from db3.usertab where uid > (select avg(uid) from
db3.usertab);
select  username from  db3.usertab
where username  in
(select user from  mysql.user where host="localhost");
1.3多表查询
mysql> create table db4.t3
-> select  username,uid,shell,homedir from db3.usertab
-> limit  3;
mysql> create  table  db4.t4
-> select username,uid,gid  from db3.usertab limit 5;
                     3  * 5 =  15 select * from t3,t4; 迪卡尔集
mysql> select  t3.username,t4.username from  t3,t4
-> where
-> t3.username =  t4.username;
mysql> select t3.*,t4.username from t3,t4 where t3.username = t4.username;
select   *  from t3,t4
where
t3.uid = t4.uid ;
select   t3.* , t4.gid  from t3,t4
where
t3.uid = t4.uid ;
select   t3.username , t4.username  from t3,t4
where
t3.uid = t4.uid ;
select   t3.username,t4.username  from t3,t4
where
t3.uid = t4.uid
and  t3.username is not null
and  t4.username is not null;
1.4  连接查询
mysql> create  table  db4.t5
select username,uid,gid,shell  from db3.usertab
where uid>=100  and uid<=500;
mysql> create  table  db4.t6
select username,uid,gid,shell  from db3.usertab
where uid>=100  and uid<=500  limit  3;
select   *  from     t6     right  join  t5  on
t6.uid =  t5.uid;
select * from t6 left join t5 on t6.uid = t5.uid;
select   t5.username,t6.username   from     t6     right  join  t5  on
t6.uid =  t5.uid;
select t5.username,t6.username from t6 left join t5 on t6.uid = t5.uid;
2.2  在数据库服务器上安装图形管理工具phpmyadmin
准备软件的运行环境  lamp/lnmp
]# rpm -q httpd  php  php-mysql
]# yum  -y   install   httpd     php    php-mysql
]# systemctl  status httpd
]#systemctl  restart httpd
]#systemctl  enable httpd
测试运行环境
[root@mysql51 mysql]# vim  /var/www/html/test.php
$x=mysql_connect("localhost","root","123456");
if($x){   echo "ok";    }else{    echo "no";    };
?>
[root@mysql51 mysql]#
[root@mysql51 mysql]# yum  -y   install  elinks
]#  elinks   --dump   http://localhost/test.php
ok
安装软件phpMyAdmin-2.11.11-all-languages.tar.gz
]#tar -zxf phpMyAdmin-2.11.11-all-languages.tar.gz -C /var/www/html/
]# cd /var/www/html/
]#mv phpMyAdmin-2.11.11-all-languages  phpmyadmin
修改软件的配置文件定义管理的数据库服务器
]#cd  phpmyadmin
]#cp   config.sample.inc.php   config.inc.php
]#vim   config.inc.php
17 $cfg['blowfish_secret'] = 'plj123';
31 $cfg['Servers'][$i]['host'] = 'localhost';
:wq
在客户端访问软件 管理数据库服务器
打开浏览器输入url地址 访问软件
http://192.168.4.51/phpmyadmin
用户名    root
密   码    123456
三、用户授权与权限撤销
3.0  管理员密码管理
恢复数据库管理员本机登录密码
]#systemctl  stop mysqld
]# vim /etc/my.cnf
[mysqld]
skip-grant-tables
#validate_password_policy=0
#validate_password_length=6
:wq
]# systemctl  start mysqld
]#mysql
mysql> select  host,user,authentication_string  from mysql.user;
mysql>
update  mysql.user
set  authentication_string=password("abc123")
where
host="localhost"  and  user="root";
mysql> flush  privileges;
mysql>quit
]# vim /etc/my.cnf
[mysqld]
#skip-grant-tables
validate_password_policy=0
validate_password_length=6
:wq
]# systemctl  restart mysqld
]#  mysql   -uroot  -pabc123
mysql>
操作系统管理员 修改数据库管理员root本机登录的密码
[root@mysql51 ~]# mysqladmin  -hlocalhost  -uroot  -p  password  "654321"
Enter password:   当前登录密码
3.1 什么是用户授权: 在数据库服务器上添加连接用户,添加时可以设置用户的访问权限和连接的密
码。默认只允许数据库管理员root用户在本机登录。默认只有数据库管理员root用户在本机登录才有
授权权限。
3.2 用户授权命令的语法格式
mysql>  grant   权限列表  on  数库名   to  用户名@"客户端地址"
identified   by  "密码"   [with  grant  option];
例子1: 允许客户端254主机可以使用root连接,连接密码是123456,连接后的访问权限是多所有库
所有表有完全访问权限 ,且有授权权限。
192.168.4.51mysql>
db3.
grant  all on .* to root@"192.168.4.254"
-> identified by "123456"
-> with  grant option;
3.3  在客户端使用授权用户连接数据库服务器
]# ping  -c   2   192.168.4.51
]# which  mysql
]#  yum  -y  install  mariadb
]#  mysql   -h数据库服务器ip地址  -u用户名   -p密码
192.168.4.254]#  mysql  -h292.168.4.51  -uroot  -p123456
mysql>
grant select,update(name) on studb.t8 to yaya3@"%" identified by "123456";
grant select,insert,update on studb.dogperson to yaya@"localhost" identified by
"123456";
grant all on studb.* to admin@"%" identified by "123456";
3.4 数据库服务器使用授权库存储授权信息
mysql库
user      desc  mysql.user; select  * from  mysql.user
db
tables_priv
clomoun_priv
3.3 撤销用户权限命令的语法格式
mysql>   revoke  权限列表  on  数库名  from 用户名@"客户端地址" ;
例子1 : 撤销254主机 使用root用户连接时,授权权限。
mysql> revoke grant option on . from 'root'@'192.168.4.254';
例子2 : 通过修改表记录的方式撤销用户的访问权限
mysql> update  mysql.user
set   Select_priv="N"
where  user= 'root'  and host='192.168.4.254';
mysql> flush privileges;
例子3:  撤销254主机 使用root用户连接时 所有权限
mysql> revoke  all  on .   from   'root'@'192.168.4.254';
例子4  删除授权用户 'root'@'192.168.4.254';
drop  user   'root'@'192.168.4.254';
3.5 工作中如何授权
管理者 给完全权限且有授权权限
使用者  只给对存储数据的库有select和insert的权限
网页名称:数据库的基本操作2
标题来源:http://jxjierui.cn/article/gphhoh.html

 建站
建站
 咨询
咨询 售后
售后
 建站咨询
建站咨询 
 