gpt4 book ai didi

c# - C# 中 mysql 的最大可选择行数是多少?

转载 作者:行者123 更新时间:2023-11-29 14:53:58 25 4
gpt4 key购买 nike

你好我正在开发一个 C# 应用程序,用于选择和比较数据库上具有超过 500'000 条记录的表上的一些数据。我正在使用 mysql 连接器,我要做一个:

SELECT * FROM table 

来自该表。我的问题是:是否建议使用无限制的 select * ?如果我一次选择所有 500000 条记录,或者我应该限制用户在组中选择记录,此过程会出现问题吗?我问这个问题是因为在 VB 中我遇到了这种选择的问题,并且 make 停止了程序。

谢谢大家。

编辑:我的选择功能:

public Object[] QuerySelect(String query)
{
IDbCommand dbcmd = dbcon.CreateCommand();
dbcmd.CommandText = query;

IDataReader reader= dbcmd.ExecuteReader();
ArrayList result = new ArrayList();

while (reader.Read())
{
Hashtable ht = new Hashtable();
int fieldCount = reader.FieldCount;

for (int i = 0; i < fieldCount; i++)
ht.Add(reader.GetName(i), reader[i]);

result.Add(ht);
}
reader.Close();

return result.ToArray();
}

最佳答案

我想你使用SqlCommand.ExecuteReaderSqlDataReader读取数据。在这种情况下,它本身不是问题,因为您将循环请求每一行。但是,如果您执行类似读取所有行并将结果放入列表中的操作,是的,您将会遇到问题,因为您正尝试将这 500,000 个项目放入内存中。

如果您不将行放入列表中,而是以某种方式处理它们,以便之后可以对它们进行垃圾收集,那么就没有问题。

更新:
您更新了您的问题并展示了您正在使用的方法。这正是这种情况,这会给您带来麻烦,因为它将导致 ArrayList 实例包含 500,000 个 Hastable 实例。

顺便说一句:
现在你应该使用泛型,例如 List<T> Dictionary<TKey, TValue> 而不是 ArrayList 和 Hashtable。它使您的代码类型安全。

关于c# - C# 中 mysql 的最大可选择行数是多少?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5090222/

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