MySQL_Ch7
#1、权限
#登录root用户
#创建用户
create user ‘用户名’@‘主机名’ identified by ‘密码’;
#localhost 本地主机 — 127.0.0.1(本地地址、回环地址)
– 具体ip
#用户名 : 自己创建的用户名字,随意取,但是不要是中文
#主机名:指定该用户在哪个主机上可以登录,
如果是本地用户可以用localhost,如果想让该用户从指定远程电脑上登录,
可以使用通配符%
#密码:登录密码,密码可以为空,登录的时候是不需要添加密码信息的
#在只能在localhost这个服务器登录mysql的服务器
create user ‘user1’@‘localhost’ identified by ‘123’;
#在任何电脑上都可以登录mysql的服务器
create user ‘user2’@’%’ identified by ‘123’;
#给用户授权(复杂的)
#用户创建之后,没有什么权限的,需要管理员重新授予权限
#语法格式
#grant 权限1,权限2,… on 数据库名.表名 to ‘用户名’@‘主机名’
#权限:create、alter、select、insert、update等等,
如果权限最大,可以使用all
数据库名.表名
:该用户可以操作哪个数据库的哪些表,
#如果要授予该用户对所有的数据库和表都有相应的操作可以写成*.*
'用户名'@'主机名'
给哪个用户授权
grant create,alter,insert,update,select
on . to ‘user1’@‘localhost’;
grant all
on . to ‘user2’@’%’;
#撤销权限
#revoke 权限1,权限2,… on 数据库名.表名 from ‘用户名’@‘主机名’
revoke all
on . from ‘user1’@‘localhost’;
#查看权限
show grants for ‘user2’@’%’;
show grants for ‘user1’@‘localhost’;
show grants for ‘root’@‘localhost’;
#删除用户
#格式:drop user ‘用户名’@‘主机名’;
drop user ‘user1’@‘localhost’;
#修改管理员密码
#mysqladmin -uroot -p password 新密码
#注意:需要在未登录mysql的情况下操作,新密码不需要加引号的
#修改普通用户
set password for ‘用户名’@‘主机名’ = password(‘新密码’);
#注意:需要登录mysql的情况下操作
set password for ‘user2’@’%’ = password(‘123456’);
#多个新表
#1)找主键和外键 第一列和最后一列(大概率是外键)
#2)中间表 除了第一列其他列都是外键
#3)意义相同的列(列名不同)
#4)列名含义
#5)有没有层次关系
#综合练习:
#1、查询所有学生的姓名,年龄(显示整数,24.75,按照24显示),
#所学的专业名称,所属的班级名称
#查询的结果、数据来源
select s.STU_NAME,(year(curdate()) - year(s.STU_BIRTHDAY)),
m.major_name, sc.class_name
from student s, major m, sclass sc
where s.STU_MAJOR = m.MAJOR_ID
and s.STU_CLASS = sc.CLASS_ID;
#2、查询专业编号,专业名称,专业人数
select m.MAJOR_ID,m.MAJOR_NAME,count(*)
from student s,major m
where s.STU_MAJOR = m.MAJOR_ID
group by m.MAJOR_ID,m.MAJOR_NAME;
#3、查询班级人数高于各班平均人数的班级编号,班级名称,班级人数
#分组函数在mysql下不能嵌套
select sc.CLASS_ID, sc.CLASS_NAME,count()
from student s,sclass sc
where s.STU_CLASS = sc.CLASS_ID
group by sc.CLASS_ID, sc.CLASS_NAME
having count() > any(select avg(t.c)
from student s,(select STU_CLASS,
count(*) as c
from student
group by STU_CLASS) t
group by s.STU_CLASS = t.STU_CLASS);
#分组函数在oracle下可以嵌套
select sc.CLASS_ID, sc.CLASS_NAME,count()
from student s,sclass sc
where s.STU_CLASS = sc.CLASS_ID
group by sc.CLASS_ID, sc.CLASS_NAME
having count() > (select avg(count(*))
from student
group by STU_CLASS);