栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何获得始终为n的倍数的sql查询?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何获得始终为n的倍数的sql查询?

另一种选择是使用a

recursive CTE
获取预定的行数,然后使用
nestedCTE
构造将来自递归CTE的行与原始表合并,最后使用
TOP
子句获取所需的行数。

DECLARE @n INT = 10;WITH Nulls AS (    SELECt 1 AS i    UNIOn ALL    SELECT i + 1 AS i    FROM Nulls    WHERe i < @n),itemsWithNulls AS(   SELECt * FROM itens    UNIOn ALL    SELECt NULL, NULL, NULL, NULL FROM Nulls    )SELECt TOP (@n) *FROM itemsWithNulls

编辑:

通过更仔细地阅读需求,OP实际上希望返回的总行数 是10的倍数
。例如,如果表

itens
有4行,则应返回10行,如果表
itens
有12行,则应返回20行,依此类推。

在这种情况下,

@n
应设置为:

DECLARE @n INT = ((SELECt COUNT(*) FROM itens) / 10 + 1) * 10

实际上,我们可以使用嵌套的CTE将所有内容放入 单个sql语句中

;WITH NumberOfRows AS (   SELECt n = ((SELECT COUNT(*) FROM itens) / 10 + 1) * 10), Nulls AS (    SELECt 1 AS i    UNIOn ALL    SELECT i + 1 AS i    FROM Nulls    WHERe i < (SELECt n FROM NumberOfRows)),itemsWithNulls AS(   SELECt * FROM itens    UNIOn ALL    SELECt NULL, NULL, NULL, NULL FROM Nulls    )SELECt TOP (SELECT n FROM NumberOfRows) *FROM itemsWithNulls

sqlfiddle



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/415811.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号