Squeak.ru - шаблоны программирования

Ошибка LINQ to Entities не распознает метод System.String ToString(), и этот метод не может быть преобразован в выражение хранилища

Я работаю с MVC4, Entityframewor и Jqgrid, когда я извлекаю данные из базы данных, я застрял с этой ошибкой. Многие из вас говорили, что заполняют поле id другой переменной, но я не понимаю, где именно его писать, и мое поле id в База данных имеет целое число. поэтому, пожалуйста, помогите мне. u.Id - это поле идентификатора, к которому я обращаюсь из EF, оно показывает эту ошибку. каков альтернативный способ и куда поместить новый код. Мой контроллер выглядит так

public JsonResult GetUserDetails(string sidx="Id", string sord="asc", int page=1, int rows=5)
{

    int pageIndex = Convert.ToInt32(page) - 1;
    int pageSize = rows;
    int totalRecords = db.Users.Count();
    int totalPages = (int)Math.Ceiling((float)totalRecords / (float)pageSize);
    var userdata = db.Users.OrderBy(sidx + " " + sord).Skip(pageIndex * pageSize).Take(pageSize);

    var jsonData = new
    {
        total = totalPages,
        page,
        records = totalRecords,

        rows = (from u in userdata
                select new
                {
                    i = u.Id,
                    cell = new string[]{**u.Id.ToString()**, u.Name,u.Designation,u.City}
                    //cell = new string[] { "", "", "", "" }
                }).ToArray()
    };
    return Json(jsonData);
}

Я работаю над этим с прошлого дня и не получаю от этого облегчения.


Ответы:


1

Метод ToString() не может быть преобразован в SQL-запрос. Итак, у вас есть несколько вариантов:

  1. Вы можете получить полные пользовательские данные объекта из db и сопоставить их с массивом строк в коде .net:

    var userdata = db.Users.OrderBy(sidx + " " + sord).Skip(pageIndex * pageSize).Take(pageSize).AsEnumerable();
    
    var jsonData = new
    {
    
        total = totalPages,
        page,
        records = totalRecords,
    
        rows = (
            from u in userdata
            select new
            {
                i = u.Id,
                cell = new string[]{**u.Id.ToString()**, u.Name,u.Designation,u.City}
                //cell = new string[] { "", "", "", "" }
            }).ToArray()
    };
    

2. Вы можете использовать два Select(), сначала для получения данных из db, а затем для сопоставления их с массивом строк:

var userdata = db.Users.OrderBy(sidx + " " + sord).Skip(pageIndex * pageSize).Take(pageSize).Select(u=>new{u.Id, u.Name, u.Designation, u.City});

var jsonData = new
{

    total = totalPages,
    page,
    records = totalRecords,

    rows = (
        from u in userdata.AsEnumerable()
        select new
        {
            i = u.Id,
            cell = new string[]{u.Id.ToString(), u.Name,u.Designation,u.City}
        }).ToArray()
};
17.02.2014
  • Спасибо Кирилл, все получилось. и у меня есть еще одна проблема, если вы не возражаете, я спрошу, это касается Jqgrid, я возвращаю вышеуказанные данные в свой jqgrid, что, на мой взгляд. но его данные возвращаются в виде серии значений, но JQgrid вообще не отображается. если вы хотите, я могу отправить вам мой проект, это пример проекта. Пожалуйста, проверьте. 17.02.2014
  • Я не работал с jqgrid, но вы можете создать новый вопрос о новой проблеме, и кто-нибудь предложит вам решение. 17.02.2014
  • Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...