多表查询 SQL21用户题目回答情况(三种写法)

简介: 多表查询 SQL21用户题目回答情况(三种写法)

一、多表查询

1、子查询

1.1、SQL21 浙江大学用户题目回答情况

描述

题目:现在运营想要查看所有来自浙江大学的用户题目回答明细情况,请你取出相应数据

35648d2421ee241edfc919fef6c7876.png

c86b40796641ce6319837e2769466e6.png

示例1

输入:
drop table if exists `user_profile`;
drop table if  exists `question_practice_detail`;
CREATE TABLE `user_profile` (
`id` int NOT NULL,
`device_id` int NOT NULL,
`gender` varchar(14) NOT NULL,
`age` int ,
`university` varchar(32) NOT NULL,
`gpa` float,
`active_days_within_30` int ,
`question_cnt` int ,
`answer_cnt` int 
);
CREATE TABLE `question_practice_detail` (
`id` int NOT NULL,
`device_id` int NOT NULL,
`question_id`int NOT NULL,
`result` varchar(32) NOT NULL
);
INSERT INTO user_profile VALUES(1,2138,'male',21,'北京大学',3.4,7,2,12);
INSERT INTO user_profile VALUES(2,3214,'male',null,'复旦大学',4.0,15,5,25);
INSERT INTO user_profile VALUES(3,6543,'female',20,'北京大学',3.2,12,3,30);
INSERT INTO user_profile VALUES(4,2315,'female',23,'浙江大学',3.6,5,1,2);
INSERT INTO user_profile VALUES(5,5432,'male',25,'山东大学',3.8,20,15,70);
INSERT INTO user_profile VALUES(6,2131,'male',28,'山东大学',3.3,15,7,13);
INSERT INTO user_profile VALUES(7,4321,'male',28,'复旦大学',3.6,9,6,52);
INSERT INTO question_practice_detail VALUES(1,2138,111,'wrong');
INSERT INTO question_practice_detail VALUES(2,3214,112,'wrong');
INSERT INTO question_practice_detail VALUES(3,3214,113,'wrong');
INSERT INTO question_practice_detail VALUES(4,6543,111,'right');
INSERT INTO question_practice_detail VALUES(5,2315,115,'right');
INSERT INTO question_practice_detail VALUES(6,2315,116,'right');
INSERT INTO question_practice_detail VALUES(7,2315,117,'wrong');
INSERT INTO question_practice_detail VALUES(8,5432,118,'wrong');
INSERT INTO question_practice_detail VALUES(9,5432,112,'wrong');
INSERT INTO question_practice_detail VALUES(10,2131,114,'right');
INSERT INTO question_practice_detail VALUES(11,5432,113,'wrong');
输出:
2315|115|right
2315|116|right
2315|117|wrong

570da3beaf048d0a58e3dcadc36f318.png

1.1.1、SQL语句(第一种写法)

select
  q.device_id,
  q.question_id,
  q.result
from
  question_practice_detail q,
  user_profile u
where
  q.device_id = u.device_id
  and university = '浙江大学'
order by
  q.question_id asc

eb086bfa415e2bdfd85bff3c4c0a10d.png

1.1.2、SQL语句(第二种写法)

select
  q.device_id,
  q.question_id,
  q.result
from
  question_practice_detail q
  join user_profile u on q.device_id = u.device_id
  and university = '浙江大学'
order by
  q.question_id asc

bbd897c78d6189f124604c64ea384d7.png

1.1.3、SQL语句(第三种写法)

select
  device_id,
  question_id,
  result
from
  question_practice_detail
where
  device_id in (
    select
      device_id
    from
      user_profile
    where
      university = '浙江大学'
  )
order by
  question_id asc

44ba43d1b7a2bbbfa1ecb2663a40e0d.png

相关文章
|
6月前
|
SQL 关系型数据库 MySQL
六、SQL多表查询
六、SQL多表查询
59 0
|
SQL XML Java
Mybatis:SQL注入问题 like模糊查询 多表查询 动态SQL
Mybatis:SQL注入问题 like模糊查询 多表查询 动态SQL
1128 0
|
5月前
|
SQL 关系型数据库 MySQL
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)一
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)一
45 5
|
5月前
|
SQL 存储 关系型数据库
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)二
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)二
45 0
|
SQL 关系型数据库 MySQL
SQL99语法实现多表查询
SQL99语法实现多表查询
61 0
|
6月前
|
SQL
SQL多表查询的几种连接方式
SQL多表查询时,主要使用以下几种连接方式
|
SQL
SQL 训练题目
解题思路:要查询的是两个课程的成绩,而且还要显示学生的信息。所以需要用到两张表,SC,Student 这两张表。
120 0
|
6月前
|
SQL
SQL语句多表查询练习
SQL语句多表查询练习
33 0
|
6月前
|
SQL 数据库
数据库Sql题目 : 不用id,每隔10行取一条数据
数据库Sql题目 : 不用id,每隔10行取一条数据