繁体   English   中英

如何检查 OleDbDataReader 是否为空?

[英]How to check if OleDbDataReader is empty?

这是我用于 select 最大RollNo的代码,基于Class字段值。 但是当表中没有关于Class字段的数据时。 然后产生错误。

using (var conn = new OleDbConnection(DatabaseObjects.ConnectionString))
            {
                conn.Open();
                command = new OleDbCommand("select max(RollNo) as Roll from Students where Class = '"+cmbClass.Text+"'", conn);
                OleDbDataReader dr = command.ExecuteReader();
                if (!dr.IsDBNull(0))
                {
                    while (dr.Read())
                    {
                        i = Convert.ToInt32(dr["Roll"]);
                    }
                }

正在发生InvalidOperation 异常 如果表中有数据,我想获得 RollNo 的值。 如果表中没有数据,我该怎么办?

您正在反转步骤:

  • 打开连接;
  • 检查是否有即将到来的数据;
  • 检查该值是否不是 null;
  • 读取数据;

尝试这个:

while (dr.Read())
   {
       if (!dr.IsDBNull(0))
          {
            i = Convert.ToInt32(dr["Roll"]);
          }
   }

当您只参加单个值时,请使用 executeScalar 获取值;

  conn.Open();          
  command = new OleDbCommand("select isnull(max(RollNo),-1) as Roll from Students where Class = '"+cmbClass.Text+"'", conn);
  int rollNo = (int) command.ExecuteScallar();
  if(rollno !=-1)
  {
     // TODO :
  }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM