Форум программистов, компьютерный форум, киберфорум
Наши страницы
C#: ASP.NET MVC
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
kol
23 / 9 / 5
Регистрация: 30.01.2015
Сообщений: 175
1

Как обработать метод контроллера если не найдена запись в бд

16.06.2016, 14:52. Просмотров 873. Ответов 5
Метки нет (Все метки)

К примеру у нас есть метод в контроллере, который принимает номер страницы. Если метод сервиса не найдет такую запись в бд как обработать отсутствующую запись.
Создать отдельное view и метод в контроллере, и перенаправлять к нему?
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
        
        public ActionResult GetCustomerAndOrdersPrice(int id)
        {
            CustomerAndOrdersPriceInfo record = customerService.GetCustomerAndOrdersPrice(id);
            if (record != null)
            {
                CustomerAndOrdersPriceViewModel viewModel = new CustomerAndOrdersPriceViewModel();
                viewModel.FirstName = record.FirstName;
                viewModel.LastName = record.LastName;
                viewModel.Price = record.Price;
 
                return View(viewModel);
            }
            else
            {
                ViewBag.Message = "This page does not exist";
 
                return //??;
            }
        }
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.06.2016, 14:52
Ответы с готовыми решениями:

как вернуть ноль если запись не найдена
Вопрос заключается в следующем, как сделать, чтобы в результатах запроса стояли нули, если ни одной...

Как можно продолжить поиск записи в БД, если одна такая запись уже найдена?
Как можно продолжить поиск записи в БД, если одна такая запись уже найдена??? используя метод...

Если запись не найдена
Допустим у меня есть кнопка "поиск",DBGrid,Edit,DataSource,Query и в нем запрос SELECT * FROM...

Если запись найдена, сложить
Есть да грида, поля у них похожи (система ADO) каждый грид, связан с своим (table и datasourse) по...

Если запись в БД найдена - вывести содержимое определённого поля, иначе - соответствующее сообщение.
Имеется база данных mysql. В базе данных есть таблица с 3 колонками id, nik, silv. Есть php код...

5
Lutk
71 / 66 / 29
Регистрация: 28.10.2013
Сообщений: 248
Завершенные тесты: 2
16.06.2016, 19:30 2
Вариантов масса, все зависит от цели.. Один из вариантов, это в самом представлении генерить разметку в зависимости от условия:
C#
1
2
3
4
5
6
7
8
public ActionResult GetCustomerAndOrdersPrice(int id)
{
    var model = new CustomerAndOrdersPriceViewModel
    {
        Record = customerService.GetCustomerAndOrdersPrice(id)
    };
    return View(model);
}
HTML5
1
2
3
4
5
6
7
8
9
10
11
@model CustomerAndOrdersPriceViewModel
...
@if (Model.Record != null)
{
    <div>Запись с id = @Model.Record.Id реально существует, братцы!</div>
}
else
{
    <div>Упс, запись не найдена. Катастрофа, паника, суицид.</div>
}
...
1
kol
23 / 9 / 5
Регистрация: 30.01.2015
Сообщений: 175
16.06.2016, 20:04  [ТС] 3
Lutk, Создавать дополнительные данные в самом методе не целесообразно, так как это излишние данные. Генерировать исключение то же, так как мы заранее можем предвидеть данную ситуацию, а они не предназначены для этого. Есть более универсальные метод?
0
Lutk
71 / 66 / 29
Регистрация: 28.10.2013
Сообщений: 248
Завершенные тесты: 2
16.06.2016, 20:09 4
Лучший ответ Сообщение было отмечено kol как решение

Решение

Не совсем понимаю, что требуется)

Это Get действие? Если да, то логично, что пользователь не должен попасть по такой ссылке, а если таки попал - верните ему return HttpNotFound(). Естественно стандартную ошибку нужно сделать более приглядной, но это отдельная тема. На примере vk этот вариант: перейдите по несуществующему id пользователя - будет стандартная 404 ошибка.

Если Post, то зависит от того, откуда прилетает запрос)

P.S. Да и в общем-то не создаем мы лишние данные) класс это ссылочный тип) везде передается ссылка, а без самого объекта мы не узнаем, что он null)
0
kol
23 / 9 / 5
Регистрация: 30.01.2015
Сообщений: 175
16.06.2016, 20:25  [ТС] 5
Lutk, Я просто с головой ушёл в модели и сервисы, и такие казалось вроде бы простые вещи опускаю. Спасибо.

Добавлено через 10 минут
Lutk, Про данные я имел ввиду, что мы должны будем конечному пользователю с http запросом передавать лишние данные, я просто с с++ пришёл, и не люблю лишними данными разбрасываться, хоть это и не существенно в данном случае. К тому же если я не ошибаюсь Model.Record во вью работать не будет, поскольку мы передаём ему null. Должно вроде бы быть NullReferenceExeption, так как мы пытаемся достать поле из объекта который равен null. Правильным будет условие if(Model == null)
0
Lutk
71 / 66 / 29
Регистрация: 28.10.2013
Сообщений: 248
Завершенные тесты: 2
16.06.2016, 20:50 6
1) О каких лишних данных пользователю речь?
2) По поводу модели:
C#
1
2
3
4
5
6
7
8
9
public class CustomerAndOrdersPriceViewModel
{
    public CustomerAndOrdersPriceInfo Record { get; set; }
    /*
        ...
        прочие члены модели
        ...
    */
}
В представлении нет обращений к каким-либо членам @Model.Record без предварительной проверки на null. Никаких исключений не будет.
1
16.06.2016, 20:50
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.06.2016, 20:50

Вызвать метод контроллера из представления или другого контроллера
Мне нужно по кнопке вызвать метод LogOut в контроллере AccountController. Я пытаюсь сделать так:...

Если запись в столбце существует, то ничего не делать, если запись отсутствует, то записать нужное значение. Как реализовать?
Если запись в столбце существует, то ничего не делать, если запись отсутствует, то записать нужное...

Как редиректнуть страницу если картинка не найдена?
Редирект если файл не найден, например, страница ссылается на несуществующий файл - как сделать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru