SqlDataReader 是否具有与带有字符串键的 Get*(int index) 等效的功能?

发布于 2024-10-01 17:59:49 字数 810 浏览 7 评论 0原文

我正在尝试使用 SqlDataReader (我非常清楚 Linq 等的优点,但我正在构建的应用程序部分是 Sql 生成器,因此 Linq 不符合我的需求)。不幸的是,我不确定使用 SqlDataReader 时的最佳实践是什么。我在代码中的几个地方使用了如下代码:

using (SqlDataReader reader = ...)
{
    int ID = reader.GetInt32(0);
    int tableID = reader.GetInt32(1);
    string fieldName = reader[2] as string;
    ...//More, similar code
}

但感觉非常不稳定。如果数据库发生变化(在这种情况下实际上极不可能),代码就会中断。是否有与 SqlDataReader 的 GetInt32、GetString、GetDecimal 等效的函数,它采用列名而不是索引?在这种情况下,什么是最佳实践?什么最快?我的代码的这些部分是代码中最耗时的部分(我已经对其进行了几次分析),因此速度很重要。

[编辑]

我知道将索引器与字符串一起使用,我错误地表达了上面的内容。我遇到了运行缓慢的情况。我的代码工作正常,但我正在寻找任何可以在这些循环中偷回几秒钟的方法。通过字符串访问会减慢我的速度吗?我知道数据库访问是主要的时间密集型操作,对此我无能为力,因此我想减少每个访问元素的处理时间。

[编辑]

我决定只使用 GetOrdinal 运行,除非有人有更具体的例子。稍后我将进行效率测试。当我实际运行测试时,我会尽量记住发布它们。

I'm trying to use a SqlDataReader (I'm quite aware of the beauty of Linq, etc, but the application I'm building is partly a Sql Generator, so Linq doesn't fit my needs). Unfortunately, I'm not sure what the best practices are when using SqlDataReader. I use code like the following in several places in my code:

using (SqlDataReader reader = ...)
{
    int ID = reader.GetInt32(0);
    int tableID = reader.GetInt32(1);
    string fieldName = reader[2] as string;
    ...//More, similar code
}

But it feels very unstable. If the database changes (which is actually extremely unlikely in this case) the code breaks. Is there an equivalent to SqlDataReader's GetInt32, GetString, GetDecimal, that takes a column name instead of an index? What's considered best practice in this case? What's fastest? These parts of my code are the most time intensive portions of my code (I've profiled it a few times) and so speed is important.

[EDIT]

I'm aware of using the indexer with a string, I misworded the above. I'm running into slow runtime. My code works fine, but I am looking for any way I can steal back a few seconds inside these loops. Would accessing by string slow me down? I know that the db-access is the primary time intensive operation, there's nothing I can do about that, so I want to cut back the processing time for each element accessed.

[EDIT]

I've decided to just run with GetOrdinal unless someone has more concrete examples. I'll run efficiency test later. I'll try to remember to post them when I actually run the tests.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

相对绾红妆 2024-10-08 17:59:49

索引器属性采用字符串键,因此您可以执行以下操作。

reader["text_column"] as string;
Convert.ToInt32(reader["numeric_column"]);

其他建议

如果您担心字符串查找速度很慢,并且假设数字查找速度更快,您可以尝试使用GetOrdinal在循环遍历大数据之前查找列索引结果集。

int textColumnIndex = reader.GetOrdinal("text_column");
int numericColumnIndex = reader.GetOrdinal("numeric_column");
while (reader.Read())
{
    string text = reader[textColumnIndex] as string;
    int number = Convert.ToInt32(reader[numericColumnIndex]);
}

The indexer property takes a string key, so you can do the following.

reader["text_column"] as string;
Convert.ToInt32(reader["numeric_column"]);

Additional suggestion

If you're concerned about the string lookup being slow, and assuming numeric lookup is quicker, you could try using GetOrdinal to find the column indices before looping through a large result set.

int textColumnIndex = reader.GetOrdinal("text_column");
int numericColumnIndex = reader.GetOrdinal("numeric_column");
while (reader.Read())
{
    string text = reader[textColumnIndex] as string;
    int number = Convert.ToInt32(reader[numericColumnIndex]);
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文