Skip to content
Advertisement

DbContext.DbSet.FromSql() not accepting parameters

I have a database with two tables, and wrote a relatively simple select statement that combines the data and returns me the fields I want. In my SQL developer software it executes just fine.

Now to execute it in my C# .NET Core application, I created a “fake” DbSet in my DbContext that doesn’t have a proper table on the database. The Type of the DbSet is a Model that represents the resulting data structure of the select statement. I use the DbSet field to access the method FromSql() and execute the select like so:

The SQL does properly return data, I’ve tested that. But the result variable holds 0 entries after executing. In the documentation for FromSql() I found that with MS SQL Servers you have to use OFFSET 0 when using ORDER BY so that’s what I did.

I have no idea what I’m doing wrong.

Advertisement

Answer

As @ChrisPratt said, one of my mistakes was using the DbSet class instead of the DbQuery class. But also, what drove me crazy is that my parameters didn’t work. My mistake was putting them inside a string, which results in them not being recognized as parameters. So my SQL string should be

instead of

User contributions licensed under: CC BY-SA
4 People found this is helpful
Advertisement