sql
SQLServer中汇总功能的使用GROUPING,ROLLUP和CUBE?
一、SQLServer中汇总功能的使用GROUPING,ROLLUP和CUBE?
第一次看到这样的SQL语句,看不懂,其中用到了下面的不常用的
聚集函数:GROUPING
用于汇总数据用的运算符: ROLLUP
SELECT
CASE GROUPING(o.customerid) WHEN 0 THEN o.customerid ELSE '(Total)' END
AS AllCustomersSummary,
CASE GROUPING(od.orderid) WHEN 0 THEN od.orderid ELSE -1 END
AS IndividualCustomerSummary,
SUM(od.quantity*od.unitprice) AS price
FROM Orders o, [Order Details] od
WHERE Year(o.orderdate) = 1998 AND od.orderid=o.orderid
GROUP BY o.customerid, od.orderid WITH ROLLUP
ORDER BY AllCustomersSummary
查看SQL Server的帮助才发现,厉害啊,原来还有这么厉害的东西,不由的想起以前做水晶报表的时候,原来在SQL Server中就可以实现这样的功能.
1.用 CUBE 汇总数据
CUBE 运算符生成的结果集是多维数据集。多维数据集是事实数据的扩展,事实数据即记录个别事件的数据。扩展建立在用户打算分析的列上。这些列被称为维。多维数据集是一个结果集,其中包含了各维度的所有可能组合的交叉表格。
CUBE 运算符在 SELECT 语句的 GROUP BY 子句中指定。该语句的选择列表应包含维度列和聚合函数表达式。GROUP BY 应指定维度列和关键字 WITH CUBE。结果集将包含维度列中各值的所有可能组合,以及与这些维度值组合相匹配的基础行中的聚合值。
例如,一个简单的表 Inventory 中包含:
Item Color Quantity
-------------------- -------------------- --------------------------
Table Blue 124
Table Red 223
Chair Blue 101
Chair Red 210
下列查询返回的结果集中,将包含 Item 和 Color 的所有可能组合的 Quantity 小计:
SELECT Item, Color, SUM(Quantity) AS QtySum
FROM Inventory
GROUP BY Item, Color WITH CUBE
下面是结果集:
Item Color QtySum
-------------------- -------------------- --------------------------
Chair Blue 101.00
Chair Red 210.00
Chair (null) 311.00
Table Blue 124.00
Table Red 223.00
Table (null) 347.00
(null) (null) 658.00
(null) Blue 225.00
(null) Red 433.00
我们着重考查下列各行:
Chair (null) 311.00
这一行报告了 Item 维度中值为 Chair 的所有行的小计。对 Color 维度返回了 NULL 值,表示该行所报告的聚合包括 Color 维度为任意值的行。
Table (null) 347.00
这一行类似,但报告的是 Item 维度中值为 Table 的所有行的小计。
(null) (null) 658.00
这一行报告了多维数据集的总计。Item 和 Color 维度的值都是 NULL,表示两个维度中的所有值都汇总在该行中。
(null) Blue 225.00
(null) Red 433.00
这两行报告了 Color 维度的小计。两行中的 Item 维度值都是 NULL,表示聚合数据来自 Item 维度为任意值的行。
使用 GROUPING 区分空值
CUBE 操作所生成的空值带来一个问题:如何区分 CUBE 操作所生成的 NULL 值和从实际数据中返回的 NULL 值?这个问题可用 GROUPING 函数解决。如果列中的值来自事实数据,则 GROUPING 函数返回 0;如果列中的值是 CUBE 操作所生成的 NULL,则返回 1。在 CUBE 操作中,所生成的 NULL 代表全体值。可将 SELECT 语句写成使用 GROUPING 函数将所生成的 NULL 替换为字符串 ALL。因为事实数据中的 NULL 表明数据值未知,所以 SELECT 语句还可译码为返回字符串 UNKNOWN 替代来自事实数据的 NULL。例如:
SELECT CASE WHEN (GROUPING(Item) = 1) THEN 'ALL'
ELSE ISNULL(Item, 'UNKNOWN')
END AS Item,
CASE WHEN (GROUPING(Color) = 1) THEN 'ALL'
ELSE ISNULL(Color, 'UNKNOWN')
END AS Color,
SUM(Quantity) AS QtySum
FROM Inventory
GROUP BY Item, Color WITH CUBE
多维数据集
CUBE 运算符可用于生成 n 维的多维数据集,即具有任意数目维度的多维数据集。只有一个维度的多维数据集可用于生成合计,例如:
SELECT CASE WHEN (GROUPING(Item) = 1) THEN 'ALL'
ELSE ISNULL(Item, 'UNKNOWN')
END AS Item,
SUM(Quantity) AS QtySum
FROM Inventory
GROUP BY Item WITH CUBE
GO
此 SELECT 语句返回的结果集既显示了 Item 中每个值的小计,也显示了 Item 中所有值的总计:
Item QtySum
-------------------- --------------------------
Chair 311.00
Table 347.00
ALL 658.00
包含带有许多维度的 CUBE 的 SELECT 语句可能生成很大的结果集,因为这些语句会为所有维度中值的所有组合生成行。这些大结果集包含的数据可能过多而不易于阅读和理解。这个问题有一种解决办法是将 SELECT 语句放在视图中:
CREATE VIEW InvCube AS
SELECT CASE WHEN (GROUPING(Item) = 1) THEN 'ALL'
ELSE ISNULL(Item, 'UNKNOWN')
END AS Item,
CASE WHEN (GROUPING(Color) = 1) THEN 'ALL'
ELSE ISNULL(Color, 'UNKNOWN')
END AS Color,
SUM(Quantity) AS QtySum
FROM Inventory
GROUP BY Item, Color WITH CUBE
然后即可用该视图来只查询您感兴趣的维度值:
SELECT *
FROM InvCube
WHERE Item = 'Chair'
AND Color = 'ALL'
Item Color QtySum
-------------------- -------------------- --------------------------
Chair ALL 311.00
(1 row(s) affected)
2.用 ROLLUP 汇总数据
在生成包含小计和合计的报表时,ROLLUP 运算符很有用。ROLLUP 运算符生成的结果集类似于 CUBE 运算符所生成的结果集。有关更多信息.
CUBE 和 ROLLUP 之间的区别在于:
CUBE 生成的结果集显示了所选列中值的所有组合的聚合。
ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合。
例如,简单表 Inventory 中包含:
Item Color Quantity
-------------------- -------------------- --------------------------
Table Blue 124
Table Red 223
Chair Blue 101
Chair Red 210
下列查询将生成小计报表:
SELECT CASE WHEN (GROUPING(Item) = 1) THEN 'ALL'
ELSE ISNULL(Item, 'UNKNOWN')
END AS Item,
CASE WHEN (GROUPING(Color) = 1) THEN 'ALL'
ELSE ISNULL(Color, 'UNKNOWN')
END AS Color,
SUM(Quantity) AS QtySum
FROM Inventory
GROUP BY Item, Color WITH ROLLUP
Item Color QtySum
-------------------- -------------------- --------------------------
Chair Blue 101.00
Chair Red 210.00
Chair ALL 311.00
Table Blue 124.00
Table Red 223.00
Table ALL 347.00
ALL ALL 658.00
(7 row(s) affected)
如果查询中的 ROLLUP 关键字更改为 CUBE,那么 CUBE 结果集与上述结果相同,只是在结果集的末尾还会返回下列两行:
ALL Blue 225.00
ALL Red 433.00
CUBE 操作为 Item 和 Color 中值的可能组合生成行。例如,CUBE 不仅报告与 Item 值 Chair 相组合的 Color 值的所有可能组合(Red、Blue 和 Red + Blue),而且报告与 Color 值 Red 相组合的 Item 值的所有可能组合(Chair、Table 和 Chair + Table)。
对于 GROUP BY 子句中右边的列中的每个值,ROLLUP 操作并不报告左边一列(或左边各列)中值的所有可能组合。例如,ROLLUP 并不对每个 Color 值报告 Item 值的所有可能组合。
ROLLUP 操作的结果集具有类似于 COMPUTE BY 所返回结果集的功能;然而,ROLLUP 具有下列优点:
ROLLUP 返回单个结果集;COMPUTE BY 返回多个结果集,而多个结果集会增加应用程序代码的复杂性。
ROLLUP 可以在服务器游标中使用;COMPUTE BY 不可以。
有时,查询优化器为 ROLLUP 生成的执行计划比为 COMPUTE BY 生成的更为高效。
3.GROUPING
是一个聚合函数,它产生一个附加的列,当用 CUBE 或 ROLLUP 运算符添加行时,附加的列输出值为1,当所添加的行不是由 CUBE 或 ROLLUP 产生时,附加列值为0。
仅在与包含 CUBE 或 ROLLUP 运算符的 GROUP BY 子句相联系的选择列表中才允许分组。
语法
GROUPING ( column_name )
参数
column_name
是 GROUP BY 子句中用于检查 CUBE 或 ROLLUP 空值的列。
返回类型
int
注释
分组用于区分由 CUBE 和 ROLLUP 返回的空值和标准的空值。作为CUBE 或 ROLLUP 操作结果返回的 NULL 是 NULL 的特殊应用。它在结果集内作为列的占位符,意思是"全体"。
示例
下面的示例将 royalty 的数值分组,并聚合 advance 的数值。GROUPING 函数应用于 royalty 列。
USE pubs
SELECT royalty, SUM(advance) 'total advance',
GROUPING(royalty) 'grp'FROM titles
GROUP BY royalty WITH ROLLUP
结果集在 royalty 下显示两个空值。第一个 NULL 代表从表中这一列得到的空值组。第二个 NULL 在 ROLLUP 操作所添加的汇总行中。汇总行显示的是所有 royalty组的 advance 合计数值,并且在 grp 列中用 1 标识。
下面是结果集:
royalty total advance grp
--------- --------------------- ---
NULL NULL 0
10 57000.0000 0
12 2275.0000 0
14 4000.0000 0
16 7000.0000 0
24 25125.0000 0
NULL 95400.0000 1
3.GROUPING
是一个聚合函数,它产生一个附加的列,当用 CUBE 或 ROLLUP 运算符添加行时,附加的列输出值为1,当所添加的行不是由 CUBE 或 ROLLUP 产生时,附加列值为0。
仅在与包含 CUBE 或 ROLLUP 运算符的 GROUP BY 子句相联系的选择列表中才允许分组。
语法
GROUPING ( column_name )
参数
column_name
是 GROUP BY 子句中用于检查 CUBE 或 ROLLUP 空值的列。
返回类型
int
注释
分组用于区分由 CUBE 和 ROLLUP 返回的空值和标准的空值。作为CUBE 或 ROLLUP 操作结果返回的 NULL 是 NULL 的特殊应用。它在结果集内作为列的占位符,意思是"全体"。
示例
下面的示例将 royalty 的数值分组,并聚合 advance 的数值。GROUPING 函数应用于 royalty 列。
USE pubs
SELECT royalty, SUM(advance) 'total advance',
GROUPING(royalty) 'grp'FROM titles
GROUP BY royalty WITH ROLLUP
结果集在 royalty 下显示两个空值。第一个 NULL 代表从表中这一列得到的空值组。第二个 NULL 在 ROLLUP 操作所添加的汇总行中。汇总行显示的是所有 royalty组的 advance 合计数值,并且在 grp 列中用 1 标识。
下面是结果集:
royalty total advance grp
--------- --------------------- ---
NULL NULL 0
10 57000.0000 0
12 2275.0000 0
14 4000.0000 0
16 7000.0000 0
24 25125.0000 0
NULL 95400.0000 1
3.GROUPING
是一个聚合函数,它产生一个附加的列,当用 CUBE 或 ROLLUP 运算符添加行时,附加的列输出值为1,当所添加的行不是由 CUBE 或 ROLLUP 产生时,附加列值为0。
仅在与包含 CUBE 或 ROLLUP 运算符的 GROUP BY 子句相联系的选择列表中才允许分组。
语法
GROUPING ( column_name )
参数
column_name
是 GROUP BY 子句中用于检查 CUBE 或 ROLLUP 空值的列。
返回类型
int
注释
分组用于区分由 CUBE 和 ROLLUP 返回的空值和标准的空值。作为CUBE 或 ROLLUP 操作结果返回的 NULL 是 NULL 的特殊应用。它在结果集内作为列的占位符,意思是"全体"。
示例
下面的示例将 royalty 的数值分组,并聚合 advance 的数值。GROUPING 函数应用于 royalty 列。
USE pubs
SELECT royalty, SUM(advance) 'total advance',
GROUPING(royalty) 'grp'FROM titles
GROUP BY royalty WITH ROLLUP
结果集在 royalty 下显示两个空值。第一个 NULL 代表从表中这一列得到的空值组。第二个 NULL 在 ROLLUP 操作所添加的汇总行中。汇总行显示的是所有 royalty组的 advance 合计数值,并且在 grp 列中用 1 标识。
下面是结果集:
royalty total advance grp
--------- --------------------- ---
NULL NULL 0
10 57000.0000 0
12 2275.0000 0
14 4000.0000 0
16 7000.0000 0
24 25125.0000 0
NULL 95400.0000 1
二、rollup是代币吗?
本身并不是
Rollup是以太坊Layer2的一个重要概念。作为一种提高区块链吞吐量的技术,Rollup可以在有效提高网络吞吐量的同时,避免对协议层进行大量的更改,部署Rollup也不需要对网络发起硬分叉升级。目前已有许多以太坊上的项目(如Celer,ANON等)采用了Rollup协议来替提高Dapp的吞吐量和用户体验。虽然Wisdom Chain本身已有数倍于以太坊的交易吞吐量,但对于更高频率的交易需求(如链上合约交易平台),目前的交易吞吐量还无法满足,或许Rollup协议会是一个不错的解决方案。
三、rollup单个字段
使用rollup单个字段进行优化您的代码
在当今的 Web 开发领域中,前端工程师们经常需要面对大量的 JavaScript 代码,其中包括不必要的冗余代码、未使用的变量和函数等问题。为了解决这些问题,并提高代码的性能和可维护性,rollup 单个字段是一个强大的工具。
使用 rollup单个字段 进行代码优化,可以帮助开发者消除不必要的代码,减小代码体积,并提高代码的加载速度。Rollup 是一个 JavaScript 模块打包工具,通过对代码进行静态分析和模块去重,帮助开发者构建出更加精简和高效的代码。
在本篇文章中,我们将深入探讨如何利用 rollup单个字段 这个工具对 JavaScript 代码进行优化。
为什么选择 rollup 单个字段
相比其他 JavaScript 模块打包工具,如 webpack 或者 parcel,rollup 更专注于构建 ES6 模块,并提供了更强大的 Tree Shaking(摇树优化)功能。Tree Shaking 可以帮助开发者剔除没有被引用的代码,从而减小最终打包文件的体积。
而 rollup 的单个字段(single field)功能则是其最大的亮点之一。通过单个字段,开发者可以更精确地控制代码的输出,避免不必要的副作用和文件碎片,使得生成的代码更加干净和高效。
如何使用 rollup 单个字段
要使用 rollup 单个字段进行优化代码,首先需要安装 rollup 。通过 npm 或者 yarn 进行安装:
<code>npm install rollup --save-dev</code>一旦安装完成,创建一个 rollup 配置文件(通常是 rollup.config.js),并在文件中配置单个字段功能:
<code> import { rollup } from 'rollup'; import singleField from 'rollup-plugin-singlefield'; export default { input: 'src/index.js', output: { file: 'dist/bundle.js', format: 'iife' }, plugins: [ singleField({ field: 'myApp', exports: 'named' }) ] }; </code>
在上面的示例中,我们指定了输入文件为 src/index.js,输出文件为 dist/bundle.js,并配置了单个字段为 myApp。最后,运行 rollup 命令即可开始代码构建:
<code>npx rollup --config</code>
最佳实践
除了配置单个字段之外,还有一些最佳实践可以帮助您更好地利用 rollup 单个字段进行代码优化:
- 合理使用模块导出和导入,避免不必要的全局变量污染。
- 结合代码压缩工具(如 Terser)对生成的代码进行压缩,进一步减小文件体积。
- 及时更新 rollup 版本,并关注官方文档中的最新功能和优化。
通过遵循这些最佳实践,您可以更有效地利用 rollup 单个字段,优化您的 JavaScript 代码,提高代码的质量和性能。
结语
在现代 Web 开发中,代码优化是一个极其重要的环节,能够直接影响到网站的加载速度和用户体验。rollup 单个字段作为一款专业的代码优化工具,具有强大的功能和灵活的配置方式,可以帮助开发者构建出更加高效和精简的 JavaScript 代码。
希望本文能够对您理解 rollup 单个字段的作用和使用方式有所帮助,也期待您在实际项目中能够灵活运用这个强大的工具,优化您的 JavaScript 代码。谢谢阅读!
四、rollup和vite的区别?
rollup释义:
n. 归纳;卷曲;袅袅上升
例句:
Our plans need to skip to the rollup.
我们的计划需要进行汇总。释义:
n. 归纳;卷曲;袅袅上升
例句:
Our plans need to skip to the rollup.
我们的计划需要进行汇总。
vite释义:
adj. (音乐)快速演奏的
adv. 轻快地,急速地(演奏)
例句:
Come on. I said vite!
来啊,我说快点。
五、cube法则?
Cube运算符生成的结果集是多维数据集。多维数据集是事实数据的扩展,事实数据即记录个别事件的数据。扩展建立在用户打算分析的列上,这些列称为维。多维数据集是一个结果集,其中包含了各维度的所有可能组合的交叉表格。
Cube运算符的作用是自动对group by子句中列出的字段进行分组汇总运算[1]。
可以通过GROUP BY子句引入Cube运算符。引入待遇GROUP BY子句的Cube时,向结果集引入了聚合行。
六、rollup中文是什么意思?
rollupn. 几上归纳;卷曲;袅袅上升;[例句]Unable to run SQL queries against cubes that have custom rollup formulas.无法对具有自定义汇总公式的多维数据集执行sql查询
七、cube公司?
CUBE Entertainment,韩国CUBE娱乐公司,是由洪胜成(原JYP公司社长)于2008年4月在韩国创办的流行音乐及娱乐事业公司,是韩国顶尖娱乐公司之一。
2014年12月,CUBE娱乐通过上市预审,正式进入韩国创业板市场。2015年4月9日,CUBE娱乐(KRX:182360)于韩国交易所举行挂牌上市仪式
八、rollup是什么时候发布的?
2011年2月3日
Roll Up的发行时间
Roll Up是Wiz Khalifa的歌曲。
《Roll Up》是美国当红说唱歌手Wiz Khalifa的一首歌,于2011年2月3日发行,是他第一张主流录音室专辑《Rolling Papers》的第二首单曲,由StarGate制作。歌曲MV在洛杉矶的威尼斯海滩拍摄,邀请了美国模特/歌手Cassie客串。这首歌空降Billboard Hot100第48名,最高时位居第13名,是Wiz Khalifa排名第5高的打榜歌曲,位于《Black And Yellow》,《See You Again》《Young,Wild&Free》和《No Sleep》之后。在美国本土数字销量已超过100万。
九、monthly rollup和security only的区别?
monthly rollup:每月汇总。security only:仅在安全的条件下。
security only例句:
1.She said the Libyan government will ensure the team's security only in areas under its control.
她说,利比亚政府将仅在政府控制区域内确保这个小组的安全。
2.If the purpose of the transaction is to transfer property for security only, then the courts will hold the transaction a pledge.
如果交易的目的只是因为担保而转让财产,法院将裁定此种交易行为是一种质押行为。
3.Ehud Olmert, the prime minister who launched the Gaza assault, has himself argued repeatedly that the Jewish state will live in peace and security only once an independent Palestinian state is born.
发动了此番加沙攻势的以色列总理艾胡德奥尔默特(ehud olmert)本人就多次强调过,只有在独立的巴勒斯坦国诞生后,由犹太人组成的国家才能最终在和平、安全的环境中生活。
4.If the system is transformed through ( W, M), then the security only rests in part on a NP-completeness problem ( Matrix Cover problem).
同时指出通过(W,M)变换,新体制的安全性将主要依赖于矩阵复盖的NP&完全性问题。
5.One can put the security measures only after establishing the authenticity of the user who is sending the messages. 只有在确立了发送消息的用户的真实性之后,才能够实施安全措施。
十、cube娱乐公司?
CUBE Entertainment,韩国CUBE娱乐公司,是由洪胜成(原JYP公司社长)于2008年4月在韩国创办的流行音乐及娱乐事业公司,是韩国顶尖娱乐公司之一。
2014年12月,CUBE娱乐通过上市预审,正式进入韩国创业板市场。2015年4月9日,CUBE娱乐(KRX:182360)于韩国交易所举行挂牌上市仪式[2]。
热点信息
-
在Python中,要查看函数的用法,可以使用以下方法: 1. 使用内置函数help():在Python交互式环境中,可以直接输入help(函数名)来获取函数的帮助文档。例如,...
-
一、java 连接数据库 在当今信息时代,Java 是一种广泛应用的编程语言,尤其在与数据库进行交互的过程中发挥着重要作用。无论是在企业级应用开发还是...
-
一、idea连接mysql数据库 php connect_error) { die("连接失败: " . $conn->connect_error);}echo "成功连接到MySQL数据库!";// 关闭连接$conn->close();?> 二、idea连接mysql数据库连...
-
要在Python中安装modbus-tk库,您可以按照以下步骤进行操作: 1. 确保您已经安装了Python解释器。您可以从Python官方网站(https://www.python.org)下载和安装最新版本...