|
1 / 1 / 2
Регистрация: 27.05.2022
Сообщений: 178
|
||||||
Как понять, какой столбец неверный10.12.2025, 23:27. Показов 1066. Ответов 16
У меня есть такой метод в слое "DataAccess":
Он нужен для регистрации пользователя. В классе User 2 поля уникальны - Email и UserName. Как понять, в какой из столбцов была введена неправильная информация?
0
|
||||||
| 10.12.2025, 23:27 | |
|
Ответы с готовыми решениями:
16
Поменять местами первый столбец и столбец и столбец, где находится максимальный элемент массива Математическое уравнение. Получается неверный результат, не могу понять в чем причина, ошибок не выдает Изучаю C#. Пишу программу. Не могу понять ошибку. Входная строка имела неверный формат |
|
14138 / 9367 / 1350
Регистрация: 21.01.2016
Сообщений: 35,243
|
|
| 17.12.2025, 17:36 | |
|
0
|
|
| 19.12.2025, 13:26 | |
|
Oleg Shamanikov,
DbUpdateException это обертка над исключением уровня ниже. Попробуйте в блоке catch проверить InnerException на наличие информации о нарушении уникальности. Тип InnerException будет зависеть от СУБД.
0
|
|
|
14138 / 9367 / 1350
Регистрация: 21.01.2016
Сообщений: 35,243
|
|
| 19.12.2025, 15:24 | |
|
NewOrdered, технически, совет верный) Но вредный)
0
|
|
| 22.12.2025, 17:26 | |
|
0
|
|
|
14138 / 9367 / 1350
Регистрация: 21.01.2016
Сообщений: 35,243
|
|
| 23.12.2025, 02:38 | |
|
NewOrdered, вреднее, да) Только почему нельзя сделать нормально и тут идёт выбор между вредно и ещё вреднее?)
0
|
|
| 23.12.2025, 10:24 | ||
|
0
|
||
|
|
|||
| 23.12.2025, 14:20 | |||
|
P.S. Если во вставляемой модели уникальные значения, то EF упадёт? Если там ключ/идентификатор заполнен, то вроде бы SaveChangesAsync просто обновит запись и всё. И даже если (другой вариант) если Id не введён, а (к примеру) ФИО и логин существуют, то опять же EF просто вставит такую же сущность с другим ID. Упасть вроде бы сложно.
0
|
|||
|
14138 / 9367 / 1350
Регистрация: 21.01.2016
Сообщений: 35,243
|
|||
| 23.12.2025, 16:31 | |||
|
0
|
|||
|
|
||
| 23.12.2025, 23:13 | ||
|
Но для этого написал свои рассуждения и вопросы. Упадёт если EF попытается выполнить вставку. Но раз метод используется SaveChangesAsync, значит всё будет зависеть от того, поймёт он что объект уже существует с данными ключами или нет. Как у него уникальность проверяется? это ключи или просто индекс?
0
|
||
|
14138 / 9367 / 1350
Регистрация: 21.01.2016
Сообщений: 35,243
|
||
| 24.12.2025, 02:18 | ||
INSERT (...) VALUES (...) ; SELECT SCOPE_IDENTITY() и скормить базе. Ну и если ошибка будет, то попробовать понять какая и в специфичное исключение завернуть.
0
|
||
| 25.12.2025, 15:39 | ||
|
0
|
||
|
14138 / 9367 / 1350
Регистрация: 21.01.2016
Сообщений: 35,243
|
|
| 25.12.2025, 17:02 | |
|
NewOrdered, это не дилетантский вопрос. EF такое атомарно не даёт сделать (из-за его дизайна), хотя СУБД такое поддерживают.
Тут либо сначала сделать проверку на наличие записи, а потом произвести вставку с обработкой исключения (после проверки нет гарантии, что запись не появится в другой транзакции), либо опускаться до голого SQL. Либо поменять ORM)
1
|
|
|
|
||
| 26.12.2025, 00:11 | ||
|
0
|
||
|
14138 / 9367 / 1350
Регистрация: 21.01.2016
Сообщений: 35,243
|
|||||||
| 26.12.2025, 03:24 | |||||||
|
Кликните здесь для просмотра всего текста
1
|
|||||||
|
|
|||
| 26.12.2025, 14:40 | |||
). Ну грубо говоря, везде присутствует предварительная проверка на наличие какого-то идентификатора/ключа. Тогда здесь получается решение на вставку. А чтобы проапдейдить, видимо условий больше нужно будет добавлять. Но я то всё про "race conditions". Если твоя вставка/обновление обёрнута в транзакцию с блокировкой и одновременно другой пытается вставить. Что произойдёт?
0
|
|||
|
14138 / 9367 / 1350
Регистрация: 21.01.2016
Сообщений: 35,243
|
|||
| 26.12.2025, 16:16 | |||
|
1
|
|||
| 26.12.2025, 16:16 | |
|
Помогаю со студенческими работами здесь
17
Поменять местами второй столбец и столбец, в котором находится последний элемент, больший 10 Что-то я не понял - Входная строка имела неверный формат Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога
Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
|
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога
Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|
|
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога
Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
|
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|