MySQL入门,第八部分,多表查询(一)
一、数据库脚本
#--------------------------------------------------------------------------------
#------------------------------创建数据库及写入数据------------------------------
CREATE DATABASE SCDB;
#--创建学生选课数据库
USE SCDB;
#--创建学生表Student
CREATE TABLE Student
(
Sno CHAR(10) NOT NULL PRIMARY KEY,
Sname CHAR(10) NULL,
Age INT NULL,
Sex CHAR(1),
Place CHAR(10)
)ENGINE=INNODB DEFAULT CHARSET=utf8;
#--查看表Student详细定义
SHOW CREATE TABLE Student;
#--给学生表Student插入数据
INSERT INTO Student(Sno,Sname,Age,Sex,Place)
VALUES('02001','王明',21,'男','广东'),
('02005','黄小英',22,'女','湖北'),
('03035','张小倩',20,'女','江西'),
('03061','李刚',21,'男','湖北'),
('04009','张珊',18,'女','浙江'),
('04027','肖文',19,'男','福建');
#--创建课程表Course
CREATE TABLE Course
(
Cno CHAR(10) NOT NULL PRIMARY KEY,
Cname CHAR(10) NULL,
Credit INT NULL
)ENGINE=INNODB DEFAULT CHARSET=utf8;
#--给课程表Course插入数据
INSERT INTO Course
VALUES('C01','操作系统',3),
('C02','C语言',4),
('C03','数据结构',3),
('C04','数据库原理',2),
('C05','软件工程',2);
#--创建选修表Study
CREATE TABLE Study
(
Sno NCHAR(10) NOT NULL REFERENCES Student(Sno),
Cno NCHAR(10) NOT NULL REFERENCES Course(Cno),
Grade INT NULL,
PRIMARY KEY (Sno,Cno)
)ENGINE=INNODB DEFAULT CHARSET=utf8;
#--给选修表Study插入数据
INSERT INTO Study(Sno,Cno,Grade)
VALUES('02001','C01',86),
('02001','C05',78),
('02005','C01',81),
('02005','C03',66),
('03035','C02',78),
('03035','C04',92),
('03061','C04',52),
('03061','C01',84),
('04009','C02',78),
('04009','C03',82),
('04027','C01',80);
二、连接查询
查询每个学生的每门课的成绩
SELECT student.sno AS 学号, sname AS 学生, cname AS 课程, grade AS 考试成绩
FROM student, study, course
WHERE student.sno = study.sno AND study.cno = course.cno
注意:
有些属性不止在一个表中出现时,前面要加上所在的表
多表关联查询时,一定要检查好查询条件,即where后面的逻辑思维
三、并操作
注意:该操作可以直接使用 OR 关键字实现
union
注意:
1.如果两个结果集的列数相同,即使字段类型不相同,也可以使用此关键字进行连接,但是强烈不推荐这样做,这样并没有任何的实际意义,因为两个结果集的属性并不相同
2.进行union连接后,结果集的属性名称以第一条结果集的属性名称为准
3.进行union连接后,结果集默认是无重复值的,如果不想重复值被覆盖,则需要使用 union all
SELECT sname
FROM student
WHERE place = '广东'
UNION
SELECT sname
FROM student
WHERE place = '湖北'
四、交操作
注意:该操作可以直接使用AND关键字实现
查询籍贯为湖北的男生的信息
SELECT * FROM
(
(
SELECT *
FROM student
WHERE place = '湖北'
)
UNION ALL
(
SELECT *
FROM student
WHERE sex = '男'
)
)
AS temp
GROUP BY sno
HAVING COUNT(*) >= 2
注意:
因为mysql中不存在 交 的关键字,因此需要借助UNION ALL和分组查询实现
五、差操作
查询年龄大于等于20岁的男生的信息
SELECT *
FROM student
WHERE age >= 20 AND sno NOT IN
(
SELECT sno
FROM student
WHERE sex = '女'
)
SELECT *
FROM student
WHERE age >= 20 AND sex <> '女'
注意:
mysql中不存在关于 差 操作的关键字,所以需要利用其它(如本方法)方法实现
MySQL入门,第八部分,多表查询(一)的更多相关文章
- MySQL入门(4)——操作数据表
MySQL入门(4)--操作数据表 创建数据库 CREATE [TEMPORARY] TABLE [IF NOT EXISTS] 数据库名 [(create_definition,...)] [tab ...
- 数据库SQL语言从入门到精通--Part 6--单表查询(快来PICK)
数据库从入门到精通合集(超详细,学习数据库必看) 查询操作是SQL语言中很重要的操作,我们今天就来详细的学习一下. 一.数据查询的语句格式 SELECT [ALL|DISTINCT] <目标列表 ...
- mysql学习(十)多表查询
多表查询时,要给表名起别名,给字段名其别名(当两个表含有重复字段时) select p.name, c.name, pid from products p, cats c;//得到的结果为笛卡尔乘积 ...
- MySql语句常用命令整理---多表查询
首先第一张表还是我们单表查询之前用到t_employee,我们在另外新建一个表t_dept(部门表)建表命令如下: drop table if exists t_dept; CREATE TABLE ...
- MYSQL 外键 on语句 多表查询
外键约束 创建外键 --- 每一个班主任会对应多个学生 , 而每个学生只能对应一个班主任 ----主表 CREATE TABLE ClassCharger( id TINYINT PRIMARY KE ...
- mysql增删改查、连表查询、常用操作
一.建表 1.最简单的建表CREATE TABLE user(id int,name char(20),age int); 2.带主键带注释和默认值创建表CREATE TABLE user(id I ...
- MySQL数据库(4)- 多表查询、可视化工具Navicat的使用、设计模式MVC
一.多表查询 准备工作:创建两张表,部门表(department).员工表(employee),代码和表格如下: # 创建表 create table department( id int, name ...
- 黑马MySQL数据库学习day03 级联 多表查询 连接和子查询 表约束
/* 存在外键的表 删表限制: 1.先删除从表,再删除主表.(不能直接删除主表,主表被从表引用,尽管实际可能还没有记录引用) 建表限制: 1.必须先建主表,再建从表(没有主表,从表无法建立外键关系) ...
- MySQL基础(三)多表查询(各种join连接详解)
Mysql 多表查询详解 一.前言 二.示例 三.注意事项 一.前言 上篇讲到Mysql中关键字执行的顺序,只涉及了一张表:实际应用大部分情况下,查询语句都会涉及到多张表格 : 1.1 多表连接有哪些 ...
- MySQL优化:如何避免回表查询?什么是索引覆盖? (转)
数据库表结构: create table user ( id int primary key, name varchar(20), sex varchar(5), index(name) )engin ...
随机推荐
- D2T1服务器需求——毒?瘤题(并不是
这题我第一眼居然差点错了\(OTZ\) 然后写了线段树,还写挂了-- 写好了\(query\)操作,发现似乎不需要区间查询,然后又删掉-- 看着这熟悉的操作,似乎在哪里见过-- 然后我莫名其妙把一个\ ...
- 【SpringBoot基础系列-实战】如何指定 bean 最先加载(应用篇)
[基础系列-实战]如何指定 bean 最先加载(应用篇) 在日常的业务开发中,绝大多数我们都是不关注 bean 的加载顺序,然而如果在某些场景下,当我们希望某个 bean 优于其他的 bean 被实例 ...
- react 脚手架装后 运行eject报错 的 正确运行方式
git init git add . git commit -m 'init' npm run eject 或者 cnpm run eject
- docker系列详解<二>之常用命令
此篇我们以从docker运行一个tomcat为例,进行一下操作: 拉取镜像 查看镜像 创建容器 查看运行状态 进入退出容器 停止容器 重启容器 删除容器 删除镜像 1.拉取tomcat镜像: 1).查 ...
- HTML基本标签,表格标签,框架标签
1.html简介 1.1什么是html html全称:Hyper Text Markup Language(超文本标记语言) 备注: a.超文本:页面内可以包含图片.链接,甚至音乐 ...
- Spring Boot入门系列(九)如何实现异步执行任务
前面介绍了Spring Boot 如何整合定时任务,不清楚的朋友可以看看之前的文章:https://www.cnblogs.com/zhangweizhong/category/1657780.htm ...
- Android 引导页的代码
布局代码 <android.support.v4.view.ViewPager android:id="@+id/viewpage" android:layout_width ...
- JavaScript 模式》读书笔记(4)— 函数2
这篇,我们仍旧继续学习函数. 二.回调模式 函数都是对象,这表示它们可以作为参数传递给其它函数. function writeCode(callback) { // 执行一些事务... callbac ...
- OpenCV-Python 哈里斯角检测 | 三十七
目标 在本章中, 我们将了解"Harris Corner Detection"背后的概念. 我们将看到以下函数:cv.cornerHarris(),cv.cornerSubPix( ...
- 怎样设计最优的卷积神经网络架构?| NAS原理剖析
虽然,深度学习在近几年发展迅速.但是,关于如何才能设计出最优的卷积神经网络架构这个问题仍在处于探索阶段. 其中一大部分原因是因为当前那些取得成功的神经网络的架构设计原理仍然是一个黑盒.虽然我们有着关于 ...