gpt4 book ai didi

c# - 从不可排序的表 SQL Server 中查询和导出

转载 作者:行者123 更新时间:2023-11-30 17:33:51 26 4
gpt4 key购买 nike

首先我很抱歉我的英语不好,不是我的语言。

我的问题是:我有一张表,其中包含大约 1000 万条银行交易记录。它没有 PK,也没有按任何列排序。

我的工作是创建一个页面来过滤并将其导出到 csv。但导出 Csv 的行数限制约为 20 万条记录。

我有一些想法:

  • 创建包含 800 个 ATM 的 800 个表(只是一个想法,我知道这很愚蠢)并且每天从主表向它发送数据 1 次 => 导出到 800 个 csv 文件

  • 每次使用 Linq 获取 100k 条记录,然后下次,我跳过这些。但是当 Skip 命令需要 OrderBy 时我卡住了,我得到了 OutOfMemoryException

    db.tblEJTransactions.OrderBy(u => u.Id).Take(100000).ToList()

任何人都可以帮助我,欢迎任何想法(我的老板说我可以使用任何东西包括创建数百个表,使用 Nosql ...)

最佳答案

如果您的表中没有主键,请添加一个。最简单也是最容易的是添加一个 int IDENTITY 列。

ALTER TABLE dbo.T 
ADD ID int NOT NULL IDENTITY (1, 1)

ALTER TABLE dbo.T
ADD CONSTRAINT PK_T PRIMARY KEY CLUSTERED (ID)

如果您无法更改原始表格,请创建一个副本。

一旦表格有了主键,您就可以按它排序并选择具有可预测结果的 20 万行的 block /页面。

关于c# - 从不可排序的表 SQL Server 中查询和导出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43220961/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com