c# - MAX(id) 使用 SqlDataReader C#

标签 c# sql sqldatareader

我该如何更改:

        using (SqlCommand myCommand = myConnection.CreateCommand())
        {
            myConnection.Open();
            myCommand.CommandText = "SELECT FormID FROM tbl_Form";
            using (SqlDataReader reader = myCommand.ExecuteReader())
            {
                while (reader.Read())
                {
                    int FormID = reader.GetInt32(reader.GetOrdinal("FormID"));
                    MessageBox.Show(FormID.ToString());
                }
            }
        }

获取MAX(FormID) ?

我的自然倾向是在 FormID 周围抛出一个 MAX,但我得到了一个 IndexOutOfRange 异常。

最佳答案

当您选择最大 ID 时,您不应使用 SqlDataReader - 查询仅返回一项,默认情况下未命名,因此您现有的查询会中断,因为它需要一个名为“FormID”的结果- 尽管您可以使用 "SELECT MAX(FormID) as FormId FROM tbl_Form" 来“修复”您的查询。而是使用 ExecuteScalar() :

myCommand.CommandText = "SELECT MAX(FormID) FROM tbl_Form";
int maxId = Convert.ToInt32(myCommand.ExecuteScalar());

关于c# - MAX(id) 使用 SqlDataReader C#,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9245197/

相关文章:

SQL Server CTE 查找从一个 ID 到另一个 ID 的路径

c# - 从数据读取器中删除列

c# - 如何检查 SQLDataReader 是否没有行

mysql - 有没有比 "column NOT IN (1,2,3)"更好的替代方案?

c++ - 此代码是否易受 SQL 注入(inject)攻击?我怎样才能让它安全?

c# - 如何使用 C# 从 SQL 数据库获取值到文本框?

c# - 为什么包含异步 lambda 的方法本身不需要是异步的?

c# - 小数点四舍五入问题

c# - 使用 ASP.NET 核心 MVC/Razor 站点和 WebAPI 进行授权

c# - 如何制作支持泛型类型的 HTML Helpers?