ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

MySQL_Ch7

2021-11-25 10:59:48  阅读:113  来源: 互联网

标签:Ch7 CLASS STU select MySQL sc ID localhost


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);

标签:Ch7,CLASS,STU,select,MySQL,sc,ID,localhost
来源: https://blog.csdn.net/loser_k/article/details/121503939

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有