加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL:选择“直到”

发布时间:2020-12-12 06:01:42 所属栏目:MsSql教程 来源:网络整理
导读:我正在寻找一种方法来选择,直到达到一笔金额. 我的“文档”表有“tag_id”和“size”字段. 我想用tag_id = 26选择所有文档,但我知道我只能处理600个单位的大小.因此,当我知道前10个文件已经加入时,选择100个文件并丢弃其中的90个文件是没有意义的. 600个单位.
我正在寻找一种方法来选择,直到达到一笔金额.

我的“文档”表有“tag_id”和“size”字段.

我想用tag_id = 26选择所有文档,但我知道我只能处理600个单位的大小.因此,当我知道前10个文件已经加入>时,选择100个文件并丢弃其中的90个文件是没有意义的. 600个单位.

因此,目标是:当我要丢弃大部分数据时,不要带回大量数据来解析.

…但我也非常希望避免在此应用中使用游标.

我正在使用mysql.

解决方法

在添加到最大单位时,您需要某种方式来订购哪些记录优先于其他记录.否则,您如何知道哪些记录总计达到600?
SELECT d.id,d.size,d.date_created
FROM documents d
INNER JOIN documents d2 ON d2.tag_id=d.tag_id AND d2.date_created >= d.date_created
WHERE d.tag_id=26
GROUP BY d.id,d.date_created
HAVING sum(d2.size) <= 600
ORDER BY d.date_created DESC

这只是一个帮助您入门的基本查询,还有许多问题需要解决:

>它在< = 600处停止,因此在大多数情况下,您不会完全填写您的尺寸限制.这意味着您可能需要调整它以允许再记录一次.例如,如果第一条记录是> 600查询将不返回任何内容,这可能是一个问题.
>它不会做任何事情来检查以后可能仍然符合上限的其他较小记录.
>具有相同date_created值的记录可以在这里和那里进行“双重计算”.

编辑更新后,他添加了他按日期排序的信息.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读