EF Core 3.1 выполняет qlInterpolated, как добавить параметр в запрос - PullRequest
0 голосов
/ 19 января 2020

Я ожидаю, что приведенный ниже запрос EF получит общее количество строк через выходной параметр total, но в данный момент он не достигает этой цели. Как я могу переписать этот запрос, чтобы получить правильный вывод обратно?

        _dbContext
            .Database
            .ExecuteSqlInterpolated($@"select {total} = count(*) 
                                        from SomeDbSet
                                        where ( columnA like '%{searchedValue1}%' 
                                            or columnB like '%{searchedValue2}%')");

1 Ответ

0 голосов
/ 24 января 2020

Вам необходимо объявить итоговое значение как выходной SqlParameter, прежде чем использовать его в интерполированном запросе.

        SqlParameter total = new SqlParameter()
        {
            ParameterName = "@Total",
            SqlDbType = SqlDbType.Int,
            Direction = ParameterDirection.Output
        };
...