交叉连接(CROSS JOIN)的实际应用

一次偶然的机会,使用到了万年不用的交叉连接(CROSS JOIN)

业务场景如下:

1、存在多个运营商,每个运营商下面都有各种类型的设备,不同运营商的设备不完全相同;

2、任何设备有且仅有两种用途‘订购’、‘置换’

3、现在要统计发生了‘订购’、‘置换’操作运营商的订购数和置换数

思路:

先用交叉连接把所有存在订购和置换的运营商和设备组合查询出来(这里把运营商表和设备表交叉连接起来也是一样)

再过滤掉无数据的组合

各运营商各设备的订购数如图

各运营商各设备的置换数如图

统计结果如下

SQL如下(可直接运行)

WITH a AS(
SELECT 'o1' 运营商,'s1' 设备,'10' 订购数 FROM dual
UNION ALL
SELECT 'o1', 's2', '15' FROM dual
UNION ALL
SELECT 'o1', 's3', '20' FROM dual
UNION ALL
SELECT 'o2', 's1', '30' FROM dual
UNION ALL
SELECT 'o2', 's2', '35' FROM dual
),
b AS(
SELECT 'o1' 运营商,'s1' 设备,'10' 置换数 FROM dual
UNION ALL
SELECT 'o1', 's2', '15' FROM dual
UNION ALL
SELECT 'o2', 's4', '20' FROM dual
UNION ALL
SELECT 'o2', 's1', '30' FROM dual
UNION ALL
SELECT 'o4', 's2', '35' FROM dual
),
op AS(
SELECT a.运营商 FROM a
UNION
SELECT b.运营商 FROM b
),
sb AS(
SELECT a.设备 FROM a
UNION
SELECT b.设备 FROM b
),
opsb AS(
SELECT DISTINCT op.运营商,sb.设备 FROM op
CROSS JOIN sb)
SELECT opsb.运营商,opsb.设备,NVL(a.订购数,0) 订购数,NVL(b.置换数,0) 置换数 
FROM opsb
LEFT JOIN a ON a.运营商 = opsb.运营商 AND a.设备 = opsb.设备
LEFT JOIN b ON b.运营商 = opsb.运营商 AND b.设备 = opsb.设备
WHERE 订购数 IS NOT NULL 
OR 置换数 IS NOT NULL

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/273290.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Atitit.操作注册表 树形数据库 注册表的历史 java版本类库总结

Atitit.操作注册表 树形数据库 注册表的历史 java版本类库总结 1. 注册表是树形数据库 1 2. 注册表的由来 1 3. Java 操作注册表 2 3.1. 使用Preferences API (限定访问路径了) 2 3.2. 使用JNI 3 3.3. Jregistrykey 推荐 4 3.4. Jregistry 4 4. org.ope…

C# xml文件读取与修改

c#读写xml文件已知有一个XML文件&#xff08;bookstore.xml&#xff09;如下&#xff1a; Code<?xml version"1.0" encoding"gb2312"?><bookstore> <book genre"fantasy" ISBN"2-3631-4"> <title>Obero…

外连接从表过滤

1、使用left join时从表的过滤 WITH a AS( SELECT A aid FROM dual UNION ALL SELECT B FROM dual UNION ALL SELECT C FROM dual UNION ALL SELECT D FROM dual UNION ALL SELECT E FROM dual ), b AS( SELECT A aid,10 num,1 type FROM dual UNION ALL SELECT B,20,2 FROM d…

php pcntl 多进程学习

1、捕获子进程退出&#xff08;监听SIGCHLD信号&#xff0c;然后调用 pcntl_wait 函数&#xff09; declare(ticks1);pcntl_signal(SIGCHLD, "sig_handler"); function sig_handler($signo) {switch ($signo) {case SIGCHLD:$status 0;$child_id pcntl_wait($statu…

Oracle取最大/最小值函数

SELECT greatest(DATE2020-01-01,DATE2020-01-03,DATE2020-01-05,DATE2020-01-07,DATE2020-01-09) 最大值, least(1,3,5,7,9) 最小值 FROM dual; SELECT 1 FROM dual WHERE greatest(1,3,5,7,9) > 8;

ORACLE将查询字段指定为某种类型

SELECT CAST(张三 AS VARCHAR2(20)) name FROM dual; 一般来说在查询时很少有用到这种语句&#xff0c;但是使用CREATE TABLE ... AS SELECT ...语句的时候这个就很好用了 --建表 CREATE TABLE test01 AS SELECT 张三 name FROM dual; --正常插入数据 INSERT INTO test01 SEL…

Less Css 教程

http://www.w3cplus.com/css/less&#xff0c;这个东西太吊了&#xff01;转载于:https://www.cnblogs.com/wln3344/p/4479014.html

分组查询最晚一条数据(ORACLE)

现有客户表&#xff0c;交费表&#xff0c;需查询每个存在交费记录客户的最后一笔交费信息 这里提供两种方式 注&#xff1a;客户不会在同一时间有两条交费&#xff0c;SQL可直接执行 --查询客户名称&#xff0c;最后一笔交费时间&#xff0c;以及最后一笔交费金额 WITH --客…

ORACLE循环中使用序列

在批量生成数据时&#xff0c;经常会用到序列的Nextval&#xff0c;今天碰到了这样的情况&#xff0c;日常记录&#xff0c;下附解决方案。先看这段脚本 DECLARE i INTEGER; BEGINFOR cur IN 1..5 LOOPi : DomainObjectId.Nextval;dbms_output.put_line(i);END LOOP; END; 编…

常用的机器学习数据挖掘知识点【转】

转自&#xff1a; 【基础】常用的机器学习&数据挖掘知识点 Basis(基础)&#xff1a; MSE(Mean Square Error 均方误差)&#xff0c;LMS(LeastMean Square 最小均方)&#xff0c;LSM(Least Square Methods 最小二乘法)&#xff0c;MLE(MaximumLikelihood Estimation最大似然…

tomcat运行问题解决方法

早上过来遇到一个非常奇怪的问题&#xff0c;运行一个新的项目&#xff0c;运行环境都没问题&#xff0c;可是在调试的时候&#xff0c;总是出错。 错误代码&#xff1a; log4j:WARN No appenders could be found for logger log4j:WARN Please initialize the log4j system p…

团队开发——冲刺1.d

冲刺阶段一&#xff08;第四天&#xff09; 1、昨天做了什么&#xff1f; 完成部分界面设置&#xff0c;补充三层难度界面、游戏结束界面。 2、今天准备做什么&#xff1f; 优化界面细节。查看C#资料&#xff0c;再解决自己电脑的问题。 3、遇到什么困难&#xff1f; 已经固定好…

10. javacript高级程序设计-DOM

1. DOM DOM(文档对象模型)是针对HTML和XML文档的一个API&#xff08;应用程序接口&#xff09; 1.1 节点层次 DOM可以将任何HTML和XML文档描绘成一个由多层节点构成的结构。节点分为几种不同的类型&#xff0c;每种类型分别表示文档中不同的信息及标记。 1.1.1 Node类型 DOM1中…

hdu 5045 Contest(状态压缩DP)

题解&#xff1a;我们使用一个二位数组dp[i][j]记录进行到第i个任务时&#xff0c;人组合为j时的最大和&#xff08;这里的j我们用二进制的每位相应一个人&#xff09;。 详细见代码&#xff1a; #include <iostream> #include <cstdio> #include <cstring> …

mysql001创建数据库

-- 注释&#xff0c;ctrl/ -- 查询所有数据库&#xff1b; show DATABASES; -- 创建数据库; CREATE DATABASE studb; -- 切换数据库; USE studb; -- 删除数据库 DROP DATABASE studb;

mysql002创建表

-- 创建student表 DDL CREATE TABLE stdent( sno int(3), name VARCHAR(55), sex CHAR(2), age int, dtdate date, classname VARCHAR(55), email VARCHAR(55) ) -- 查询表中数据 DQL SELECT * FROM stdent;

oc基础-self关键字的使用

#import <Foundation/Foundation.h>interface Student : NSObject {int _age;char *_name; } - (void) study; - (void) run; (void) play;(void) run; endimplementation Student - (void) study {NSLog("%s在学习",self->_name);[self run];//若在此调用…

mysql003操作表DDL

-- 查询表中数据 DQL 注意在mydb数据库下面 SELECT * FROM stdent; -- 在表中添加一列 DDL -- 新增列 默认添加到最后 ALTER TABLE stdent add score DOUBLE(4,1); -- 新增一列 在表中开头添加 ALTER TABLE stdent add score2 double(5,1) first; -- 在指定列后面添…

Google Guava学习笔记——基础工具类Joiner的使用

Guava 中有一些基础的工具类&#xff0c;如下所列&#xff1a; 1&#xff0c;Joiner 类&#xff1a;根据给定的分隔符把字符串连接到一起。MapJoiner 执行相同的操作&#xff0c;但是针对 Map 的 key 和 value。 2&#xff0c;Splitter 类&#xff1a;与 Joiner 操作相反的类&a…

xampp 无法启动mysql

Error: could not open single-table tablespace file .\test\dr.ibd 在网上搜索到的解决方案都不管用。结果整合了两个解决方案&#xff1a; 删掉xampp/data/ib_logfile0 xampp/data/ib_logfile1 xampp/data/ibdata1 三个文件就好了转载于:https://www.cnblogs.com/fyydnz/p/4…