Scenario:
I have a string property in my model that holds the IDs from a MultiSelectList @Html.ListBox
. If I select two list items, my property value will look like this 0100,0500
.
The problem:
Dapper where clause will only work with a single value:
CODE IN (@SomeCode) // for example, 0100 or 0500 returns results
CODE IN (@SomeCode) // 0100,0500 does not return results.
That's because you don't need to tell Dapper to use parenthesis ()
. It will do fine by its own. Try this:
var codes = new List<string> { "0100","0500"};
var sql = "select * from SomeTable where CODE IN @codes";
var items = connection.Query(sql, new { codes });
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With