day03 高级查询 视图操作

1 子查询

1:用select返回的值当做查询条件
SELECT * FROM book 
WHERE class = (SELECT class FROM book WHERE NAME = 'Java从入门到精通');

多行比较操作符 IN, ALL, ANY
其中 ALL和 ANY不能单独使用,需要配合单行比较操作符>、>=、<、<=一起使用。

2:in 关键字 查询员工表(employee)数据,保证查出来的员工的部门是存在的。
  (根据部门表department中返回的数据,来查询当前表)
 SELECT * FROM employee
 WHERE d_id IN (SELECT d_id FROM department);

3: EXISTS关键字,子查询语句不返回查询的记录,而是返回一个真假值。
   列出来哪些有员工的部门信息。(d 和 e 为别名的一种形式)
SELECT * FROM department d
WHERE EXISTS (SELECT * FROM employee e WHERE d.d_id = e.d_id);

4: 子查询在 HAVING子句中  (having 多行过虑)
   查询列出最低价格高于传记类图书的最低价格的图书信息。
SELECT NAME ,MIN(price) '最低价格' , class FROM book GROUP BY class
HAVING MIN(price) >= (SELECT MIN(price) FROM book WHERE class = '传记类');

5: 子查询在 FROM子句中
   FROM 子句用来指定要查询的表
   如果要在一个子查询的结果中继续查询,则子查询出现在 FROM 子句中,
   这个子查询也称作行内视图或者匿名视图。
   
   查询出价格比本类图书平均价格要高的图书信
SELECT * FROM book b,
(SELECT class, AVG(price) avg_price FROM book GROUP BY class) xx
WHERE b.class = xx.class AND b.price > xx.avg_price;

6: 子查询在 SELECT 部分
   把子查询放在SELECT 子句部分,可以认为是外连接的另一种表现形式,使用更灵活。
SELECT e.name, e.age,
(SELECT d.d_id FROM department d WHERE d.d_id = e.d_id)
departmentID FROM employee e;

分页查询

1: LIMIT 不指定初始位置时,记录从第一条记录开始显示。
SELECT * FROM book LIMIT 2;

2: LIMIT 可以指定从哪条记录开始显示,并且可以指定显示多少条记录。
SELECT * FROM book LIMIT 1, 2;

3:实现分页
SELECT * FROM book LIMIT pageSize * (page - 1), pageSize;
pageSisz : 要分的页的大小 5 ,  page:第几页 1

如第一页:
SELECT * FROM book LIMIT 5*(1-1), 5; // 示意不能执行
SELECT * FROM book LIMIT 0, 5; // 第一页执行
如第二页:
SELECT * FROM book LIMIT 5*(2-1), 5; // 示意不能执行
SELECT * FROM book LIMIT 5, 5; // 第二页执行

4:分页优化:
SELECT * FROM book WHERE id >= (SELECT id FROM book LIMIT
pageSize*(page - 1), 1) LIMIT pageSize;

SELECT * FROM (SELECT * FROM book ORDER BY id) b
WHERE id >= (SELECT id FROM (SELECT * FROM book ORDER BY id) b LIMIT 3,1) LIMIT 3;

返回id作为limit的起始位置,以page作为一个变量

计算 sum, count, avg,等合计函数时排除null值

SELECT class, AVG(IFNULL(price, 0)) '平均价格' FROM book GROUP BY class;

CASE 函数在分组查询中的应用

1:技术类和传记类是我的最爱favorite,其他书没感觉normal。计算出我喜欢的书。
SELECT
(CASE class WHEN '技术类' THEN 'favorite'
WHEN '传记类' THEN 'favorite'
ELSE 'normal' END ) Favorite,
COUNT(1) COUNT
FROM book
GROUP BY
(CASE class WHEN '技术类' THEN 'favorite'
WHEN '传记类' THEN 'favorite'
ELSE 'normal' END );

2 关联查询

1:连接查询 通常建立在存在相互关系的父子表之间两表都有d_id属性
SELECT e.`name`, d.`d_name` 
FROM employee e, department d 
WHERE e.`d_id` = d.`d_id` ;

2:笛卡尔积 指做关联操作的每个表的第一行者和其它表的每一行做组合
SELECT COUNT(1) FROM department;//4行
SELECT COUNT(1) FROM employee; //4行
SELECT department.`d_name`,employee.`name` FROM department, employee;//关联之后16行


3:等值连接 有主外键关联关系的表间建立,
   并将连接条件设定为有关系的列,使用等号 “=” 连接相关的表。

查询学生姓名、性别、年龄,以及班主任信息
SELECT s.name, s.sex, s.age, t.name
FROM student s, teacher t
WHERE s.teacherNO = t.id;
-----------------------------------------------------------------------------
//创建一个teacher表,其中id为主键。
CREATE TABLE teacher (
  id INT PRIMARY KEY,
  NAME VARCHAR (20) NOT NULL,
  sex VARCHAR (2),
  age INT
);
INSERT INTO teacher VALUE(1,'李老师','男',28);
INSERT INTO teacher VALUE(2,'刘老师','女',22);
INSERT INTO teacher VALUE(3,'胡老师','男',34);
INSERT INTO teacher VALUE(4,'王老师','女',20);

//创建一个student表,其中id为主键,teacherNo为外键与teacher表的id键关联
CREATE TABLE student (
  id INT AUTO_INCREMENT PRIMARY KEY, // 自增 主键
  NAME VARCHAR (20) NOT NULL,
  sex VARCHAR (2),
  age INT,
  teacherNo INT,
  CONSTRAINT teacherNo_fk FOREIGN KEY (teacherNo) REFERENCES teacher (id)
);
INSERT INTO student(NAME, sex, age, teacherNo) VALUES('张三', '男', 19, 1);
INSERT INTO student(NAME, sex, age, teacherNo) VALUES('李四', '女', 18, 2);
INSERT INTO student(NAME, sex, age, teacherNo) VALUES('王五', '男', 19, 2);
INSERT INTO student(NAME, sex, age, teacherNo) VALUES('赵六', '女', 30, 3);

SELECT s.`name` AS '学生',t.`NAME` AS '老师'
FROM  student s ,teacher t
WHERE s.`teacherNo` = t.`id`;
-----------------------------------------------------------------------------
4:内连接,即返回所有满足连接条件的记录
SELECT s.name, t.name 
FROM student s JOIN teacher t
ON(s.`teacherNo` = t.id);

5:外连接,分为左连接和右连接
   返回主表的所有记录,而连接的表,只能查询出匹配的记录,如果没有匹配上的记录,为null

   左连接,
SELECT  NAME, employee.`d_id`, d_name
FROM employee LEFT JOIN department
ON employee.`d_id` = department.`d_id`;

   右连接,
SELECT NAME, employee.`d_id`, d_name
FROM employee RIGHT JOIN department
ON employee.`d_id` = department.`d_id`;

3 视图

视图(VIEW)也被称作虚表,视图本身并不包含任何数据,它只包含映射到基表的一个查询语句, 
当基表数据发生变化, 视图数据也随之变化。

基表分类:

简单视图:SELECT语句是基于单表建立的,且不包含任何函数运算、表达式或分组函数
复杂视图:SELECT语句同样是基于单表,但包含了单行函数、表达式、分组函数或GROUP BY子句
连接视图:SELECT语句是基于多个表的

视图的作用:

1: 如果需要经常执行某项复杂查询,可以基于这个复杂查询建立视图,
此后查询此视图即可,简化复杂查询

2: 视图本质上就是一条 SELECT 语句,所以当访问视图时,
只能访问到所对应的 SELECT 语句中涉及到的列,对基表中的其它列起到安全和保密的作用,
限制数据访问。

给用户授权创建视图

1: 给root用户授权db01下面的所有表,都有create VIEW 的权限
GRANT CREATE VIEW ON db01.* TO 'yxh';

2:查看权限
SHOW GRANTS FOR yxh;

创建视图

CREATE [ALGORITHM={UNDEFINED | MERGE | TEMPTABLE}]
VIEW 视图名 [(属性清单)]
AS SELECT 语句 [WITH [CASCADED | LOCAL] CHECK OPTION];

ALGORITHM表示视图选择的算法。
属性清单是可选参数,指定了视图中各个属性的名词,
默认情况下与SELECT 语句中查询的属性相同。
SELECT语句参数是一个完整的查询语句,
表示从某个表中查出某些满足条件的记录,将这些记录导入视图中。

1:创建简单视图
CREATE VIEW book_view (书名, 作者, 出版编号)
AS SELECT NAME, author, ISBN FROM book;

2:查看视图
   查看视图必须要有 SHOW VIEW 的权限。授权类似于 CREATE VIEW 授权。
DESC book_view; //查看字段信息
SHOW TABLE STATUS LIKE 'book_view';
SHOW CREATE VIEW book_view; //查看创造信息

3:查询视图内容
SELECT * FROM book_view;

对视图进行 INSERT 操作

1:简单视图能够执行 DML 操作,下列情况除外:在基表中定义了非空列, 
   但简单视图对应的SELECT语句并没有包含这个非空列,导致这个非空列对视图不可见,
   这时无法对视图执行INSERT 操作。
  
INSERT INTO book_view
VALUE (11,'三国志','施耐庵','公元200年');

// 对视图进行修改操作同时修改基表内容
DELETE FROM book_view WHERE 号码 = 10;
   
2:如果视图定义中包含了函数、 表达式、 分组语句、DISTINCT关键字或ROWNUM伪列,
   不允许执行DML 操作

3:创建具有 CHECK OPTION约束的视图
   WITH CHECK OPTION 短语表示,通过视图所做的修改,必须在视图的可见范围内。
   假设 INSERT,新增的记录在视图仍可查看
   假设 UPDATE,修改后的结果必须能通过视图查看到
   假设 DELETE,只能删除现有视图里能查到的记录。

//创建一个只有技术类图书的视图
CREATE OR REPLACE VIEW book_view1
AS SELECT id, NAME, author, price, class
FROM book WHERE class='技术类' WITH CHECK OPTION;

//插入 '异类' 的图书,发现无法通过。必须在视图的可见范围内
INSERT INTO book_view1
VALUE (15,'无题','傻叉','99.9','异类'); // 改成技术类才行 

4: 创建复杂视图(多表关联)

CREATE VIEW new_list AS 
SELECT 
  d.d_name AS '部门',
  AVG(e.salary) AS '平均薪水',
  SUM(e.salary) AS '薪水总和',
  MAX(e.salary) AS '最高薪水',
  MIN(e.salary) AS '最低薪水'
FROM
  employee e JOIN department d ON e.d_id = d.d_id
 GROUP BY d.d_name;

//查询
SELECT * FROM new_list;
  
//复杂视图不允许 DML操作。

删除视图

视图虽然是存放在数据字典中的独立对象,但视图仅仅是基于表的一个查询定义,
所以对视图的删除不会导致基表数据的丢失,不会影响基表数据。

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

推荐阅读更多精彩内容

  • 50个常用的sql语句Student(S#,Sname,Sage,Ssex) 学生表Course(C#,Cname...
    哈哈海阅读 1,230评论 0 7
  • 人类的进步需要适当的奢华,好比汽车与建筑。好的性能与结构加上外观内饰肯定是匠人精神的人对品质以及效率的高度重视才得...
    光影轩阅读 295评论 0 0
  • 八朝古都,文化名城。位处中州腹地,立夏商旧畿之上,皇天后土,群雄逐鹿场;背临九曲黄河,怀千里平川沃野,华夏摇篮,农...
    朴雨阅读 2,427评论 5 5
  • 为什么会焦虑 3月底时,我离开了我非常喜欢的公司,当时我非常的迷茫,焦虑,我发现其实很多人跟我一样感到很焦虑,不知...
    余七青阅读 145评论 0 0