什么叫做数据交叉?在怎样的场景下需要用到数据交叉?让我们来看两个应用场景:
1. 我们从数据库的原始数据表中经过连接得到这样一个结果集,该表共有三行三列,现在我们想得到部门的员工民族统计表,
图 3‑19
下图是我们想要得到的最终结果:
图 3‑20
我们知道这样的查询实际上是不能通过SQL语句来实现的,因为通过SQL语句查询出来的列中不可能存在像汉族,满族,蒙古族这样的列,这些数值是原始数据库表中某列中的值。但是这个功能我们可以通过投影交叉来实现。
2. 还是刚才那个例子,我们现在想要得到的结果需要按照民族列中的民族数动态扩展,也就是说,不能只有汉族,满族,蒙古族这些固定好的值,如果添加了一笔数据,民族的值为苗族,我们最终的报表能够动态的呈现出这样的变化,理想中的结果如下图所示:
图 3‑21
实际上这样的例子可以用旋转交叉来实现。下面我们要分别介绍这两种交叉功能。
1.1 投影交叉
· 投影交叉(第一类交叉):假定有一个查询SQL,其查询结果是单行单列的汇总值,另外还有两组WHERE条件的序列,分别为横向序列(WhereX1、WhereX2、……、WhereXn)和纵向序列(WhereY1、WhereY2、……、WhereYn),则数据矩阵A(aij)对应的结果集成为投影交叉,如果aij是WhereXi和WhereYj同时作用在上述SQL上获得的结果。
数据模型如图所示