我该如何更改:
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/