簡體   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