2

RowDataBoundイベントで、現在の編集行のdataTableから値を取得しようとしています。コードは次のとおりです。

string KK = (string)DataBinder.Eval(e.Row.DataItem, "Name");
if ( KK == "John" )
{
//execute code
}

エラー:タイプ「System.DBNull」のオブジェクトをタイプ「System.String」にキャストできません。最初の行(String KKの行...)

どうすれば修正できますか?

4

5 に答える 5

13

DataItemGridViewRow代わりに を使用DataBinder.Evalして、基になるデータソースを取得します。

protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
    if (e.Row.RowType == DataControlRowType.DataRow && e.Row.RowState == DataControlRowState.Edit))
    {
        DataRow row = ((DataRowView)e.Row.DataItem).Row;
        String name = row.Field<String>("Name");
        // String is a reference type, so you just need to compare with null
        if(name != null){/* do something */}
    }
}

Field拡張メソッドは、null 許容型もサポートしています。

于 2012-04-24T13:40:03.820 に答える
1

DBNull.Value を確認し、DBNull.Value でない場合はデータを取得します

于 2012-04-24T13:40:12.717 に答える
1

DBNull は、値が DB 内の null 値であることを示します。これは、値が存在しないことを示します。クエリが有効なデータを返していることを確認する必要がある場合があります。そうである場合は、リスト内の項目が null の場合に使用する値を見つける必要があります。

これを試して:

string KK = DataBinder.Eval(e.Row.DataItem, "Name").GetType() == typeof(System.DBNull) ? "" : (string)DataBinder.Eval(e.Row.DataItem, "Name")
于 2012-04-24T13:42:27.613 に答える
0

null 値を取得する前に、「IsNull」メソッドを使用して null 値を適切にチェックする必要があります。

于 2012-04-24T13:36:48.110 に答える
0

あなたはそれをつかんでそれDataRowから取り組むべきです:

var row = e.Row.DataItem as DataRow;
if (row != null)
{
    //for strings this will work fine
    var name = row.Field<string>("Name");

    //for other types use the IsNull function to check for DBNull
    if (!row.IsNull("SomeDecimalValue"))
        var value = row.Field<decimal>("SomeDecimalValue");
}

EDITnull別のオプションは、値がorである可能性がある場合に null 許容型を使用することですDBNull

var value = row.Field<decimal?>("SomeDecimalValue");
if (value.HasValue)
{

}
于 2012-04-24T13:52:48.550 に答える