83.数据库的使用3

-- =================================连接查询=======================================
-- 1.接连查询: 同时查询多个表中的数据
-- SELECT * FROM 表名1,表名2... WHERE 连接条件;
-- 连接查询如果不加连接条件,结果是一个笛卡尔积:(a,b,c)(1,2,3) --> (a1,a2,a3,b1,b2,b3,c1,c2,c3)
-- (a, b, c) (设计学院,信通学院) --> 笛卡尔积

-- 查询每个老师对应的学院
SELECT teaname, collname FROM tb_college, tb_teacher WHERE tb_teacher.collid=tb_college.collid;
-- 查询学生姓名对应的学科名的分数
SELECT stuname, couname, mark FROM tb_student, tb_course, tb_score
WHERE tb_score.stuid=tb_student.stuid and tb_score.couid=tb_course.couid;

-- 查询学生名对应的学生的平均成绩
-- SELECT stuid, AVG(mark) as avg_mark FROM tb_score GROUP BY(stuid);
SELECT stuname, avg_mark FROM
tb_student,
(SELECT stuid, AVG(mark) as avg_mark FROM tb_score GROUP BY(stuid)) as temp_t
WHERE tb_student.stuid = temp_t.stuid;

-- 查询平均分高于80分的学生名字和对应的平均分分数
SELECT stuname, avg_mark FROM
tb_student,
(SELECT stuid, AVG(mark) as avg_mark FROM tb_score GROUP BY(stuid) HAVING AVG(mark)>80) as temp_t
WHERE tb_student.stuid = temp_t.stuid;

-- 查询平均分高于80分的学生名字和对应的平均分分数
-- 注意:如果连接查询的时候既有连接条件又有筛选条件,我们要把筛选条件写在连接条件后边
SELECT stuname, avg_mark FROM
tb_student,
(SELECT stuid, AVG(mark) as avg_mark FROM tb_score GROUP BY(stuid)) as temp_t
WHERE tb_student.stuid = temp_t.stuid and avg_mark>80;

-- 2.内连接
-- SELECT * FROM 表1 inner join 表2 on 表2的连接条件 inner join 表3 on 表3的连接条件 ...;
-- 注意: 中间表写在最前面(存在关联其他表外键的表)
-- 查询学生姓名对应的学科名的分数
SELECT stuname, couname, mark FROM tb_score
INNER JOIN tb_student ON tb_student.stuid=tb_score.stuid
INNER JOIN tb_course ON tb_course.couid=tb_score.couid
WHERE mark < 60;

-- 3.外连接
-- 外连接分为左外连接、右外连接和全连接, 但是在MySQL中支持左外连接和右外连接
-- 表1(左表) left/right/inner join 表2(右表)
-- 左外连接:将左表中对应字段的所有数据取出,然后再对应的右表中字段的值,如果右表对应的值不存在结果就为null
-- 右外连接:将右表中对应字段的所有数据取出,然后再对应的左表中字段的值,如果左表对应的值不存在结果就为null

-- 查所有学生名对应的成绩
-- SELECT stuname, mark FROM tb_score INNER JOIN tb_student ON tb_student.stuid=tb_score.stuid;
SELECT stuname, mark FROM tb_score RIGHT JOIN tb_student ON tb_student.stuid=tb_score.stuid;

-- =================================字段索引=======================================
-- 字段的索引就相当于于目录,作用是为了能够快速的对这个字段进行查找
-- 添加索引的好处是可以大大的提高查询效率; 缺点是:1.会消耗额外的存储空间, 2.会让添加和删除的效率降低
-- 建议: 1.索引不能滥用 2.如果项目中针对某个字段的查询很频繁,建议加个对应的索引
-- EXPLAIN: 获取执行计划

EXPLAIN(解释:explain看执行过程的) SELECT * FROM tb_student WHERE stuid=110;

EXPLAIN SELECT * FROM tb_student WHERE stuname='张三';

-- 添加索引: create index 索引名称 on 表名 (字段名); - 给指定表中的指定字段添加索引
CREATE INDEX index_stuname on tb_student (stuname); -- 给名字加索引
CREATE INDEX index_stuname1 on tb_student (stuname(1)); -- 按姓加索引

-- 删除索引
ALTER TABLE tb_student DROP INDEX index_stuname1;

-- ==================================DCL============================================
-- 1.创建用户
-- create user 用户名@登录地址
-- 登录地址: (限制用户能够登录MySQL的主机地址), ip地址(指定地址), localhost(数据库本机), %(任何位置)
CREATE USER 'zhangshan'@'%' IDENTIFIED BY 'yuting123456';

-- 删除用户: drop user 用户名;
DROP USER 'zhangshan';

-- 2.授权
-- grant 权限类型 on 数据库.对象 to 用户名;
GRANT SELECT on school.tb_student TO 'zhangshan';
GRANT UPDATE on school.tb_student TO 'zhangshan';
GRANT all PRIVILEGES ON school.* TO 'zhangshan'; -- 添加所有权限
GRANT all PRIVILEGES ON school.* TO 'zhangshan' WITH GRANT OPTION; -- 添加所有权限,并且能够将自己的权限再授权给其他用户

-- 3.召回授权
-- REVOKE 权限类型 on 数据库.对象 from 用户名;
REVOKE DELETE on school.* FROM 'zhangshan';
REVOKE all PRIVILEGES on school.* FROM 'zhangshan';
REVOKE all PRIVILEGES on school.* FROM 'zhangshan';
REVOKE SELECT on school.tb_student FROM 'zhangshan';
REVOKE UPDATE on school.tb_student FROM 'zhangshan';

-- 4.事务
-- 完成一个任务需要执行多条sql,但是要求这多个操作中只要有一个操作失败,这个任务就失败,数据全部还原;所有的操作都成功,整个任务才成功的时候就使用事务

-- 开启事务环境
BEGIN;
UPDATE tb_student set stuname='444' WHERE stuname='222';
UPDATE tb_student set birth2='1990-1-1' WHERE stuname='222';
-- 提交事务(只有begin到commit之间的所有的sql都执行成功,才会执行commit; 否则执行rollback)
COMMIT;
-- 事务回滚(放弃beigin到commit之间执行成功的所有sql语句的结果)
ROLLBACK;

having 和where的区别在于:

    select goods_price,goods_name from sw_goods where goods_price > 100
    select goods_price,goods_name from sw_goods having goods_price > 100

因为having是从前筛选的字段再筛选,而where是从数据表中的字段直接进行的筛选的。
总之写having的前提必须是前面已经查询了这项才能才后面写该项的查询条件,不然是会报错的

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容

  • -- 连接查询-- 1.接连查询: 同时查询多个表中的数据-- SELECT * FROM 表名1,表名2... ...
    水果坚果燕麦片阅读 236评论 0 0
  • -- =================================连接查询=================...
    LittleBear_6c91阅读 223评论 0 0
  • 花了3天时间学习MySql,考了个二级MySql 书籍参考:高等教育出版社《全国计算机等级考试二级教程-MySQL...
    如果仲有听日阅读 1,273评论 4 4
  • 关系数据库概述 数据持久化 --将数据保存到(在掉电情况下)能够长久保存数据的存储介质中 数据库发展史 -网状数据...
    寒江雪_独钓阅读 570评论 0 0
  • 基础理论知识来源:《缠论》,《黄金高胜算交易》,《外汇短线交易的24堂精品课》 盈利模型:凯利公式 进场:大级别右...
    Hessen819阅读 132评论 0 0