Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Type of conditional expression cannot be determined because there is no implicit conversion between 'string' and 'System.DBNull'

Tags:

c#

asp.net

param7[1].Value = tbLastName.Text.Length > 0 ? tbLastName.Text : DBNull.Value; 

Why is this impossible, and any suggestion what else to try? If/else for 20 parameters is just not way.

like image 405
el ninho Avatar asked May 12 '13 01:05

el ninho


1 Answers

The issue is that (as the error message indicates) the conditional expression needs either identical types on both branches, or else there needs to be an implicit conversion from one of the types to the other. In your case, there isn't one, and so you get the error. One quick fix would be cast one of the values to (object) (which is fine, since DbParameter.Value is of type object anyway.)

So this should work for you:

param7[1].Value = tbLastName.Text.Length > 0 ? tbLastName.Text : (object)DBNull.Value; 
like image 140
dlev Avatar answered Oct 15 '22 10:10

dlev