表之间的数据匹配(生成交叉表)--sql
2021/11/28 19:10:27
本文主要是介绍表之间的数据匹配(生成交叉表)--sql,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
表之间的数据匹配(生成交叉表)--sql
创建表、添加数据
CREATE TABLE CourseMaster ( course_id int not null primary key, coures_name varchar(20) ); CREATE TABLE OpenCourses ( month int, course_id int not null , CONSTRAINT fk_course_id FOREIGN KEY (course_id) REFERENCES CourseMaster(course_id) ); insert into CourseMaster(course_id,coures_name) values (1,'会计入门 '), (2,'财务知识 '), (3,'簿记考试 '), (4,'税务师 '); insert into OpenCourses(month,course_id) values (200706,1), (200706,3), (200706,1), (200706,4), (200707,4), (200708,2), (200708,4);
生成交叉表
我们要用这两张表来生成交叉表,以便于一目了然地知道每个月开设的课程。
使用 IN 谓词
-- 表的匹配 :使用 IN 谓词 SELECT coures_name AS 课程名, CASE WHEN course_id IN (SELECT course_id FROM opencourses WHERE month = 200706) THEN 'o' ELSE 'x' END AS "6月", CASE WHEN course_id IN (SELECT course_id FROM opencourses WHERE month = 200707) THEN 'o' ELSE 'x' END AS "7月", CASE WHEN course_id IN (SELECT course_id FROM opencourses WHERE month = 200708) THEN 'o' ELSE 'x' END AS "8月" FROM coursemaster;
使用 EXISTS 谓词
-- 表的匹配 :使用 EXISTS 谓词 SELECT CM.coures_name AS 课程名, CASE WHEN EXISTS (SELECT course_id FROM opencourses oc WHERE month = 200706 AND oc.course_id=cm.course_id) THEN 'o' ELSE 'x' END as "6月", CASE WHEN EXISTS (SELECT course_id FROM opencourses oc WHERE month = 200707 AND oc.course_id=cm.course_id) THEN 'o' ELSE 'x' END as "7月", CASE WHEN EXISTS (SELECT course_id FROM opencourses oc WHERE month = 200708 AND oc.course_id=cm.course_id) THEN 'o' ELSE 'x' END as "8月" FROM coursemaster CM;
图例
这篇关于表之间的数据匹配(生成交叉表)--sql的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-06-15matplotlib作图不显示3D图,怎么办?
- 2024-06-1503-Loki 日志监控
- 2024-06-1504-让LLM理解知识 -Prompt
- 2024-06-05做软件测试需要懂代码吗?
- 2024-06-0514-ShardingSphere的分布式主键实现
- 2024-06-03为什么以及如何要进行架构设计权衡?
- 2024-05-31全网首发第二弹!软考2024年5月《软件设计师》真题+解析+答案!(11-20题)
- 2024-05-31全网首发!软考2024年5月《软件设计师》真题+解析+答案!(21-30题)
- 2024-05-30【Java】百万数据excel导出功能如何实现
- 2024-05-30我们小公司,哪像华为一样,用得上IPD(集成产品开发)?