0

运行 foreach 循环后。我在第二项上收到 NullReferenceException,因为查询结果为空。但我有更多项目可用于同一查询并在richTextBox1 上获得结果。如果有任何空结果,我可以继续 foreach 循环。

foreach (string Items in listBox4.Items)
{
    using (OracleCommand crtCommand = new OracleCommand("select REGEXP_REPLACE(dbms_metadata.get_ddl('TABLE','" + Items + "'),('" + txtSrcUserID.Text + "...'),'', 1, 0, 'i') from dual", conn1))                           
    {
        richTextBox1.AppendText(Environment.NewLine);
        richTextBox1.AppendText(crtCommand.ExecuteScalar().ToString() + ";");
        richTextBox1.AppendText(Environment.NewLine);
    }                                                      
}
4

2 回答 2

0

更改crtCommand.ExecuteScalar().ToString()(crtCommand.ExecuteScalar() ?? string.Empty).ToString()。这在逻辑上等价于:

  object dbResult = crtCommand.ExecuteScalar();
  if(dbResult == null) 
  {
     richTextBox1.AppendText(";");
  }
  else
  {
     richTextBox1.AppendText(dbResult.ToString() + ";");
  }

如果您想完全忽略空结果而不是将其视为空字符串,请使用@SimonWhitehead 的代码

于 2013-07-18T02:41:00.683 回答
0

这是危险的编程。你真的应该检查null. 假设你的循环会变得更大..我会包括 acontinue并让它更明显你正在做什么以提高可读性。continue如果不需要,请省略。

var result = crtCommand.ExecuteScalar();

if (result != null) {
    richTextBox1.AppendText(Environment.NewLine);
    richTextBox1.AppendText(result.ToString() + ";");
    richTextBox1.AppendText(Environment.NewLine);
}
else {
    continue;
}

// any other code here.
于 2013-07-18T02:42:23.937 回答