子查询的使用

select 字段名称 from tbl_name where col_name=(select col_name from tbl_name);
--内层语句查询的结果可以作为外层语句查询的条件

由in引发的子查询

create table emp(
id int unsigned auto_increment key,
username varchar(20) not null unique comment '编号',
age tinyint unsigned not null default 18 comment '年龄',
sex enum('男','女','保密') not null default '保密' comment '性别',
addr varchar(20) not null default '北京',
depId tinyint unsigned not null comment '部门对应的编号'
)engine=innodb charset=utf8; insert emp(username,age,depId) values('king',24,1),
('queen',25,2),
('imooc',26,1),
('lily',27,1),
('rose',28,3),
('john',29,3); create table dep(
id tinyint unsigned auto_increment key,
depName varchar(50) not null unique,
depDesc varchar(100) not null
)engine=innodb charset=utf8; insert dep(depName,depDesc) values('PHP教学部','研发PHP课件'),
('JAVA教学部','研发JAVA课件'),
('WEB教学部','研发WEB课件'),
('IOS教学部','研发IOS课件'); select * from emp where depId in (1,2,3,4);
select * from emp where depId in (select id from dep); select * from emp where depId not in (select id from dep);

由比较运算符引发的子查询

create table stu(
id tinyint unsigned auto_increment key comment '编号',
username varchar(20) not null unique comment '学员名称',
score tinyint unsigned comment '学员考试分数'
)engine=innodb charset=utf8; insert stu(username,score) values('king',95),
('queen',75),
('zhangsan',69),
('lisi',78),
('wangwu',87),
('zhaoliu',88),
('tianqi',98),
('ceshi',99),
('tiancai',50); create table level(
id tinyint unsigned auto_increment key comment '编号',
score tinyint unsigned comment '分数'
)engine=innodb charset=utf8; insert level(score) values(90),(80),(70); select id,username,score from stu
where score>=(select score from level where id=1); select id,username,score from stu
where score<(select score from level where id=3);

由exists引发的子查询

select * from emp where exists (select depName from dep where id=10); --不存在exists返回假,空集合
select * from emp where exists (select depName from dep where id=1); --存在exists返回真,有集合

带有any、some、all关键字的子查询

运算符\关键字 any some all
>、>= 最小值 最小值 最大值
<、<= 最大值 最大值 最小值
= 任意值 任意值
<>、!= 任意值
select * from stu where score>= any(select score from level); --大于等于子查询结果的最小值,some、all用法差不多
--显示
+----+----------+-------+
| id | username | score |
+----+----------+-------+
| 1 | king | 95 |
| 2 | queen | 75 |
| 4 | lisi | 78 |
| 5 | wangwu | 87 |
| 6 | zhaoliu | 88 |
| 7 | tianqi | 98 |
| 8 | ceshi | 99 |
+----+----------+-------+

联合查询的使用

-- insert ... select
-- cerate ... select
-- updata ... select --创建一个user1表,id username
create table user1(
id int unsigned auto_increment key,
username varchar(20)
)select id,username from emp; --将user表中的用户名写入到user1表中
insert user1(username) select username from user; create table user2 like user1; --创建一个与user1表结构相同的user2
insert user2 select id,username from user1; --将stu表中的tiancai用户名添加到user2表中
insert user2 set username=(select username from stu where id=9); select distinct(username) from user2; --去掉字段的重复记录

联合查询

--union(去掉两个表中重复的值)
--将user1和user2数据合并到一起
select 字段名称,... from tbl_name1
union
select 字段名称,... from tbl_name2; select * from user1
union
select * from user2; --union all(简单的合并)
select 字段名称,... from tbl_name1
union all
select 字段名称,... from tbl_name2;

无限级分类数据表的设计及实现(自身连接查询)

-- pId 0 -- id 1服装
-- pId 1 -- id 4男装 5女装 6内衣 -- pId 0 -- id 2数码
-- pId 2 -- id 7电视 8冰箱 9洗衣机 -- pId 0 -- id 3玩具
-- pId 3 -- id 10爱马仕 11LV 12GUCCI -- pId 4 -- id 13夹克 14衬衫 15裤子 -- pId 7-- id 16液晶电视 17等离子电视 18背投电视 create table cate(
id smallint unsigned auto_increment key,
cateName varchar(100) not null unique,
pId smallint unsigned not null default 0
)engine=innodb charset=utf8; insert cate(cateName,pId) values('服装',0),
('数码',0),
('玩具',0); insert cate(cateName,pId) values('男装',1),
('女装',1),
('内衣',1); insert cate(cateName,pId) values('电视',2),
('冰箱',2),
('洗衣机',2); insert cate(cateName,pId) values('爱马仕',3),
('LV',3),
('GUCCI',3); insert cate(cateName,pId) values('夹克',4),
('衬衫',4),
('裤子',4); insert cate(cateName,pId) values('液晶电视',7),
('等离子电视',7),
('背投电视',7); --查询所有的分类信息,并且得到其父分类
select s.id,s.cateName as sCateName,p.cateName as pCateName
from cate as s
left join cate as p
on s.pId=p.id; --显示
+----+------------+-----------+
| id | sCateName | pCateName |
+----+------------+-----------+
| 1 | 服装 | NULL |
| 2 | 数码 | NULL |
| 3 | 玩具 | NULL |
| 4 | 男装 | 服装 |
| 5 | 女装 | 服装 |
| 6 | 内衣 | 服装 |
| 7 | 电视 | 数码 |
| 8 | 冰箱 | 数码 |
| 9 | 洗衣机 | 数码 |
| 10 | 爱马仕 | 玩具 |
| 11 | LV | 玩具 |
| 12 | GUCCI | 玩具 |
| 13 | 夹克 | 男装 |
| 14 | 衬衫 | 男装 |
| 15 | 裤子 | 男装 |
| 16 | 液晶电视 | 电视 |
| 17 | 等离子电视 | 电视 |
| 18 | 背投电视 | 电视 |
+----+------------+-----------+ -- 查询所有的分类及其子分类
select p.id,p.cateName as pCateName,s.cateName as sCateName
from cate as s
right join cate as p
on s.pId=p.id; --显示
+----+------------+------------+
| id | pCateName | sCateName |
+----+------------+------------+
| 1 | 服装 | 男装 |
| 1 | 服装 | 女装 |
| 1 | 服装 | 内衣 |
| 2 | 数码 | 电视 |
| 2 | 数码 | 冰箱 |
| 2 | 数码 | 洗衣机 |
| 3 | 玩具 | 爱马仕 |
| 3 | 玩具 | LV |
| 3 | 玩具 | GUCCI |
| 4 | 男装 | 夹克 |
| 4 | 男装 | 衬衫 |
| 4 | 男装 | 裤子 |
| 7 | 电视 | 液晶电视 |
| 7 | 电视 | 等离子电视 |
| 7 | 电视 | 背投电视 |
| 12 | GUCCI | NULL |
| 11 | LV | NULL |
| 6 | 内衣 | NULL |
| 8 | 冰箱 | NULL |
| 13 | 夹克 | NULL |
| 5 | 女装 | NULL |
| 9 | 洗衣机 | NULL |
| 16 | 液晶电视 | NULL |
| 10 | 爱马仕 | NULL |
| 17 | 等离子电视 | NULL |
| 18 | 背投电视 | NULL |
| 14 | 衬衫 | NULL |
| 15 | 裤子 | NULL |
+----+------------+------------+ --查询所有的分类并且得到子分类的数目
select p.id,p.cateName as pCateName, count(s.cateName) as count
from cate as s
right join cate as p
on s.pId=p.id
group by p.cateName
order by id asc;
--显示
+----+------------+-------+
| id | pCateName | count |
+----+------------+-------+
| 1 | 服装 | 3 |
| 2 | 数码 | 3 |
| 3 | 玩具 | 3 |
| 4 | 男装 | 3 |
| 5 | 女装 | 0 |
| 6 | 内衣 | 0 |
| 7 | 电视 | 3 |
| 8 | 冰箱 | 0 |
| 9 | 洗衣机 | 0 |
| 10 | 爱马仕 | 0 |
| 11 | LV | 0 |
| 12 | GUCCI | 0 |
| 13 | 夹克 | 0 |
| 14 | 衬衫 | 0 |
| 15 | 裤子 | 0 |
| 16 | 液晶电视 | 0 |
| 17 | 等离子电视 | 0 |
| 18 | 背投电视 | 0 |
+----+------------+-------+

MySQL基础之数据管理【5】的更多相关文章

  1. MySQL基础之数据管理【4】

    外键约束的使用(只有InnoDB存储引擎支持外键) create table news_cate( id tinyint unsigned auto_increment key comment '编号 ...

  2. MySQL基础之数据管理【3】

    MySQL中的多表联查 --查询emp的id username age depName create table emp( id int unsigned auto_increment key, us ...

  3. MySQL基础之数据管理【2】

    where条件筛选记录 select id,username,age from uesr where id=5; alter table user add userDesc varchar(100); ...

  4. MySQL基础之数据管理【1】

    添加记录 insert [into] tbl_name[(col_name,...)] {value|values}(values...); --不指定字段名称时需要按照建表时的字段顺序给每一个字段赋 ...

  5. MySQL基础----py全栈

    目录 MySQL基础----py全栈 一.引言 1.什么是数据? 2.什么是数据库(DB)? 3.什么是数据库管理系统(DBMS)? 4.什么是数据库系统? 5.数据库管理系统由来 6.什么是数据模型 ...

  6. Mysql基础代码(不断完善中)

    Mysql基础代码,不断完善中~ /* 启动MySQL */ net start mysql /* 连接与断开服务器 */ mysql -h 地址 -P 端口 -u 用户名 -p 密码 /* 跳过权限 ...

  7. MYSQL基础操作

    MYSQL基础操作 [TOC] 1.基本定义 1.1.关系型数据库系统 关系型数据库系统是建立在关系模型上的数据库系统 什么是关系模型呢? 1.数据结构可以规定,同类数据结构一致,就是一个二维的表格 ...

  8. 【夯实Mysql基础】记一次mysql语句的优化过程

    1. [事件起因] 今天在做项目的时候,发现提供给客户端的接口时间很慢,达到了2秒多,我第一时间,抓了接口,看了运行的sql,发现就是 2个sql慢,分别占了1秒多. 一个sql是 链接了5个表同时使 ...

  9. MySQL基础(非常全)

    MySQL基础 一.MySQL概述 1.什么是数据库 ? 答:数据的仓库,如:在ATM的示例中我们创建了一个 db 目录,称其为数据库 2.什么是 MySQL.Oracle.SQLite.Access ...

随机推荐

  1. Android 中 MessageQueue 的 nativePollOnce

    Android SDK 中的事件循环已经是一个老生常谈的问题了, 像 Handler Looper MessageQueue 这几个类也是被大家研究透彻了. 但是再回头看以前自己的分析, 总感觉差点什 ...

  2. Java面试题_第二阶段(Servlet、HTTP、Session、JSP、 Ajax、Filter、JDBC、Mysql、Spring)

    1.1. 描述Servlet调用过程? 答案: (1)在浏览器输入地址,浏览器先去查找hosts文件,将主机名翻译为ip地址,如果找不到就再去查询dns服务器将主机名翻译成ip地址. (2)浏览器根据 ...

  3. .NET机器学习 ML.NET 1.4预览版和模型生成器更新

    ML.NET 是面向.NET开发人员的开源和跨平台机器学习框架. ML.NET  还包括Model Builder  (一个简单的UI工具)和  CLI  ,使用自动机器学习(AutoML)构建自定义 ...

  4. C#开发微信小程序(五)

    导航:C#开发微信小程序系列 关于小程序项目结构,框架介绍,组件说明等,请查看微信小程序官方文档,关于以下贴出来的代码部分我只是截取了一些片段,方便说明问题,如果需要查看完整源代码,可以在我的项目库中 ...

  5. 系统 (一) Windows10安装Ubuntu子系统

    前言 本文将基于 Windows10专业版 安装 Ubuntu子系统 1.控制面板 -> 程序 -> 选择启用或关闭Windows功能 -> 勾上 适用Linux的Windwos子系 ...

  6. Linux - CentOS 7 通过Yum源安装 Nginx

    添加源 sudo rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.no ...

  7. 设计模式之单例模式(Java)

    单例模式 问题 多线程操作同一对象保证对象的一致性 解决思路 只有一次实例化过程,产生一个实例化对象,并提供返回该对象的方法. 单例模式的分类 1 饿汉式 在加载类的时候就产生实例对象 public ...

  8. Angular--AOT和JIT两种编译方式带来的改变

    Angular 应用主要由组件及其 HTML 模板组成.由于浏览器无法直接理解 Angular 所提供的组件和模板,因此 Angular 应用程序需要先进行编译才能在浏览器中运行.Angular 提供 ...

  9. 嵌入Canvas App到Dynamics 365 Customer Engagement(Model-Driven App)中,创造更多可能!

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  10. Custom Diagrams

    Custom Diagrams https://github.com/dbeaver/dbeaver/wiki/Custom-Diagrams You can create custom ER dia ...