Difference between DbNull.Value and DbNull.Value.ToString()

后端 未结 3 1254
无人及你
无人及你 2021-01-26 19:42

I wanted to learn which usage is true?

if(!string.IsNullOrEmpty(parentID))
   cmd.Parameters.Add(new SqlParameter(\"@ParentSesID\", parentID));
else
   cmd.Param         


        
相关标签:
3条回答
  • 2021-01-26 20:20

    DBNull.Value.ToString() will return empty string, so I think

    cmd.Parameters.Add(new SqlParameter("@ParentSesID", DBNull.Value));
    

    is a good approach and here the only approach

    see here:

    http://ideone.com/iGo1Jh

    0 讨论(0)
  • 2021-01-26 20:26
    cmd.Parameters.Add(new SqlParameter("@ParentSesID", parentID));
    

    This is passing a parentID to parameter @ParentSesID.

    cmd.Parameters.Add(new SqlParameter("@ParentSesID", DBNull.Value));
    

    is passing a null value to parameter.

    cmd.Parameters.Add(new SqlParameter("@ParentSesID", DBNull.Value.ToString()));
    

    is passing equal to string.Empty, which is not allowed in numerical data types.

    cmd.Parameters.Add(new SqlParameter("@ParentSesID", null);
    

    is same as ignoring the parameter.

    So when you need to pass null to SP you've to pass DBNull.Value.

    0 讨论(0)
  • 2021-01-26 20:31

    This one: cmd.Parameters.Add(new SqlParameter("@ParentSesID", DBNull.Value)); is a correct, in case the field you are writing to can accept NULL value in database.

    This one: cmd.Parameters.Add(new SqlParameter("@ParentSesID", DBNull.Value.ToString())); if the field is a, say, VARCHAR, and does not accept NULL, but you want to indicate in some way an absence of value in that field, so you write inside your application specific "no value" value. So your application knows, if it founds that value in the field, that means: no value.

    0 讨论(0)
提交回复
热议问题