sql语法做题第十天

简介: sql语法练习

第二十二例:链接查询,统计每个学校的答过题的用户的平均答题数

droptable if exists `user_profile`;

droptable if  exists `question_practice_detail`;

CREATETABLE `user_profile` (

`device_id` intNOTNULL,

`gender` varchar(14) NOTNULL,

`age` int ,

`university` varchar(32) NOTNULL,

`gpa` float,

`active_days_within_30` int

);

CREATETABLE `question_practice_detail` (

`device_id` intNOTNULL,

`question_id`int NOTNULL,

`result` varchar(32) NOTNULL

);

INSERTINTO user_profile VALUES(2138,'male',21,'北京大学',3.4,7);

INSERTINTO user_profile VALUES(3214,'male',null,'复旦大学',4.0,15);

INSERTINTO user_profile VALUES(6543,'female',20,'北京大学',3.2,12);

INSERTINTO user_profile VALUES(2315,'female',23,'浙江大学',3.6,5);

INSERTINTO user_profile VALUES(5432,'male',25,'山东大学',3.8,20);

INSERTINTO user_profile VALUES(2131,'male',28,'山东大学',3.3,15);

INSERTINTO user_profile VALUES(4321,'male',28,'复旦大学',3.6,9);

INSERTINTO question_practice_detail VALUES(2138,111,'wrong');

INSERTINTO question_practice_detail VALUES(3214,112,'wrong');

INSERTINTO question_practice_detail VALUES(3214,113,'wrong');

INSERTINTO question_practice_detail VALUES(6543,111,'right');

INSERTINTO question_practice_detail VALUES(2315,115,'right');

INSERTINTO question_practice_detail VALUES(2315,116,'right');

INSERTINTO question_practice_detail VALUES(2315,117,'wrong');

INSERTINTO question_practice_detail VALUES(5432,118,'wrong');

INSERTINTO question_practice_detail VALUES(5432,112,'wrong');

INSERTINTO question_practice_detail VALUES(2131,114,'right');

INSERTINTO question_practice_detail VALUES(5432,113,'wrong');

  • 题目:请你写sql查找每个学校用户的平均答题数目你的查询应返回以下结果(结果保留4位小数),注意:结果按照university升序排序!!!
  • 分析1:先查找每个学校用户:select u.university from user_profile u group by u.university;
  • 分析2:求学校用户平均答题数量,注意这里需要将user_profile表和quesiton_practice_detail进行链接使用inner join on:select u.university count(q.question_id)/count(DISTINC u.device_id) as avg_answer_cnt from user_ profile u inner join  question_practice_detail q on u.device_id=q.device_id group by u.university;
  • 示例代码

select

u.university,

round(count(q.question_id)/count(DISTINCT u.device_id),4) as avg_anser_cnt

from

user_profile u

inner join

question_practice_detail q

on

q.device_id=u.device_id

groupby

u.university

orderby

u.university

第二十三例:链接查询,统计每个学校各难度的用户平均刷题数

droptable if exists `user_profile`;

droptable if  exists `question_practice_detail`;

droptable if  exists `question_detail`;

CREATETABLE `user_profile` (

`id` intNOTNULL,

`device_id` intNOTNULL,

`gender` varchar(14) NOTNULL,

`age` int ,

`university` varchar(32) NOTNULL,

`gpa` float,

`active_days_within_30` int ,

`question_cnt` int ,

`answer_cnt` int

);

CREATETABLE `question_practice_detail` (

`id` intNOTNULL,

`device_id` intNOTNULL,

`question_id`int NOTNULL,

`result` varchar(32) NOTNULL

);

CREATETABLE `question_detail` (

`id` intNOTNULL,

`question_id`int NOTNULL,

`difficult_level` varchar(32) NOTNULL

);

INSERTINTO user_profile VALUES(1,2138,'male',21,'北京大学',3.4,7,2,12);

INSERTINTO user_profile VALUES(2,3214,'male',null,'复旦大学',4.0,15,5,25);

INSERTINTO user_profile VALUES(3,6543,'female',20,'北京大学',3.2,12,3,30);

INSERTINTO user_profile VALUES(4,2315,'female',23,'浙江大学',3.6,5,1,2);

INSERTINTO user_profile VALUES(5,5432,'male',25,'山东大学',3.8,20,15,70);

INSERTINTO user_profile VALUES(6,2131,'male',28,'山东大学',3.3,15,7,13);

INSERTINTO user_profile VALUES(7,4321,'male',28,'复旦大学',3.6,9,6,52);

INSERTINTO question_practice_detail VALUES(1,2138,111,'wrong');

INSERTINTO question_practice_detail VALUES(2,3214,112,'wrong');

INSERTINTO question_practice_detail VALUES(3,3214,113,'wrong');

INSERTINTO question_practice_detail VALUES(4,6543,111,'right');

INSERTINTO question_practice_detail VALUES(5,2315,115,'right');

INSERTINTO question_practice_detail VALUES(6,2315,116,'right');

INSERTINTO question_practice_detail VALUES(7,2315,117,'wrong');

INSERTINTO question_practice_detail VALUES(8,5432,117,'wrong');

INSERTINTO question_practice_detail VALUES(9,5432,112,'wrong');

INSERTINTO question_practice_detail VALUES(10,2131,113,'right');

INSERTINTO question_practice_detail VALUES(11,5432,113,'wrong');

INSERTINTO question_practice_detail VALUES(12,2315,115,'right');

INSERTINTO question_practice_detail VALUES(13,2315,116,'right');

INSERTINTO question_practice_detail VALUES(14,2315,117,'wrong');

INSERTINTO question_practice_detail VALUES(15,5432,117,'wrong');

INSERTINTO question_practice_detail VALUES(16,5432,112,'wrong');

INSERTINTO question_practice_detail VALUES(17,2131,113,'right');

INSERTINTO question_practice_detail VALUES(18,5432,113,'wrong');

INSERTINTO question_practice_detail VALUES(19,2315,117,'wrong');

INSERTINTO question_practice_detail VALUES(20,5432,117,'wrong');

INSERTINTO question_practice_detail VALUES(21,5432,112,'wrong');

INSERTINTO question_practice_detail VALUES(22,2131,113,'right');

INSERTINTO question_practice_detail VALUES(23,5432,113,'wrong');

INSERTINTO question_detail VALUES(1,111,'hard');

INSERTINTO question_detail VALUES(2,112,'medium');

INSERTINTO question_detail VALUES(3,113,'easy');

INSERTINTO question_detail VALUES(4,115,'easy');

INSERTINTO question_detail VALUES(5,116,'medium');

INSERTINTO question_detail VALUES(6,117,'easy');

  • 题目:请你写一个SQL查询,计算不同学校、不同难度的用户平均答题量,根据示例,你的查询应返回以下结果(结果在小数点位数保留4位,4位之后四舍五入)
  • 分析1:计算不同学校,不同难度的用户平均答题量:select u.university qd.difficult_level, avg_answer_cnt from question_practive_detail qp left join user_profile u on qp.device_id = u.device_id left join question_detail qd on qp.question_id = qd.question_id;
  • 示例代码

select

u.university,

qd.difficult_level,

round(count(qpd.question_id)/count(distinct qpd.device_id),4) as avg_answer_cnt

from

question_practice_detail qpd

left join

user_profile u

on

qpd.device_id=u.device_id

left join

question_detail qd

on

qpd.question_id=qd.question_id

groupby

u.university,

qd.difficult_level;


相关文章
|
2月前
|
SQL 关系型数据库 MySQL
MySQL数据库基础第一篇(SQL通用语法与分类)
MySQL数据库基础第一篇(SQL通用语法与分类)
|
2月前
|
SQL PHP
thinkphp之进阶sql语法,持续更新
thinkphp之进阶sql语法,持续更新
19 0
|
12天前
|
SQL 关系型数据库 MySQL
INSERT INTO t_a.tableName SELECT * FROM t_b.tableName 如何通过定义一个list对象,包含多个tableName,循环执行前面的sql,用MySQL的语法写
【8月更文挑战第7天】INSERT INTO t_a.tableName SELECT * FROM t_b.tableName 如何通过定义一个list对象,包含多个tableName,循环执行前面的sql,用MySQL的语法写
16 5
|
21天前
|
SQL 关系型数据库 数据库
sql语法
【7月更文挑战第30天】sql语法
27 12
|
1月前
|
SQL Java 数据库连接
mybatis动态SQL常用语法总结
MyBatis 使用 OGNL 表达式语言处理动态SQL,如 `if` 标签进行条件判断,`choose`、`when`、`otherwise` 实现多条件选择,`where`、`set` 管理SQL关键字,`trim` 提供通用修剪功能,`foreach` 遍历集合数据。`sql` 和 `include` 用于代码重用,`selectKey` 处理插入后的返回值。参数传递支持匿名、具名、列表、Map、Java Bean和JSON方式。注意SQL转义及使用合适的jdbcType映射Java类型。
50 7
|
20天前
|
SQL 关系型数据库 分布式数据库
PolarDB产品使用问题之遇到SQL语法错误,该如何排查
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
1月前
|
SQL 数据库 索引
SQL SELECT语句的语法与查询优化技巧
SQL SELECT语句的语法与查询优化技巧
|
2月前
|
SQL 机器学习/深度学习 分布式计算
MaxCompute产品使用合集之sql代码中支持插入jinja语法语句吗
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
1月前
|
SQL 数据库 索引
SQL SELECT语句的语法与查询优化技巧
SQL SELECT语句的语法与查询优化技巧
|
3月前
|
SQL 关系型数据库 数据库
SQL Server语法基础:入门到精通
SQL Server语法基础:入门到精通
100 9
SQL Server语法基础:入门到精通