Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
 Аватар для skilllab
296 / 236 / 58
Регистрация: 03.02.2011
Сообщений: 2,045
Записей в блоге: 1
.NET 4.x

Entity Framework и абстракции

21.11.2015, 00:41. Показов 1761. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Можно сказать "новичковый" вопрос
Есть сущности, созданные из базы данных. Database First.
К примеру, код только как пример, в реальности всё сложнее:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
    [Table("Data")]
    public class Data
    {
        [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", "CA2214:DoNotCallOverridableMethodsInConstructors")]
        public Data()
        {
            Name = new HashSet<Name>();
        }
 
        [Required]
        [StringLength(49)]
        public string ProductName { get; set; }
 
        public int ID { get; set; }
 
 
        [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", "CA2227:CollectionPropertiesShouldBeReadOnly")]
        public virtual ICollection<Name> Name { get; set; }
 
    }
 
    [Table("Name")]
    public class Name
    {
        [StringLength(50)]
        public string UserName { get; set; }
 
        [StringLength(50)]
        public string UserEmail { get; set; }
 
 
        public int ID { get; set; }
 
        public virtual Data Data { get; set; }
    }
В процессе записи данных в базу нужно сделать много всяких манипуляций с данными. Например, проверка корректности eMail.

Сейчас я сделал обычную конвертацию, в лоб так сказать. Т.е.:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
    public class DataModel : INotifyPropertyChanged
    {
 
        public DataModel()
        {
        }
 
        public int ID { get; set; }
        public Data AsData()
        {
            Data pData = new Data();
            pData.ID = ID;
            pData.Name = new List<Name>();
            foreach (Name _name in Names)
            {
                pData.Name.Add(_name.AsName());
            }
            pData.ProductName = ProductName;
            return pData;
        }
        public string ProductName { get; set; }
 
        private ObservableCollection<Name> names = new ObservableCollection<Name>();
        public ObservableCollection<Name> Names
        {
            get { return names; }
            set
            {
                names = value;
                RaisePropertyChanged(nameof(Names));
            }
        }
 
        public event PropertyChangedEventHandler PropertyChanged;
 
        #region Event
        protected virtual void RaisePropertyChanged(PropertyChangedEventArgs e)
        {
            var handler = PropertyChanged;
            if (handler != null) handler(this, e);
        }
        protected void RaisePropertyChanged(string propertyName)
        {
            RaisePropertyChanged(new PropertyChangedEventArgs(propertyName));
        }
        #endregion
    }
И при загрузке контекста конвертирую его в мои "модели". Далее работаю с ними. Так вот, эта конвертация занимает тучу времени.
База маленькая. И будет оставаться такой. Есть и репозитории.
Пробовал быдлокод))) создавал partial классы - не то.

Вопрос: как правильно создать второй уровень абстракции, который бы манипулировал всеми свойствами классов таблиц + имел некие свои методы?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.11.2015, 00:41
Ответы с готовыми решениями:

В чем разница между Entity Framework и Entity Framework Core?
В чем разница (если она есть) между entity framework и entity framework core?

Entity Framework. Удаление entity без удаления связей
Вечер добрый. Есть модель Coder First. Каскадное удаление запрещено. Удаление произвожу так: try { ...

Entity framework One vs Zero-or-One
При настройке ассоциаций между двумя сущностями можно выбрать чтобы на конце связь была &quot;один&quot; и &quot;ноль или один&quot;-не...

14
Заблокирован
21.11.2015, 12:50
Не совсем понятно к чему это вообще? Ваша цель какова вообще, итоговый результат какой должен быть?
0
 Аватар для skilllab
296 / 236 / 58
Регистрация: 03.02.2011
Сообщений: 2,045
Записей в блоге: 1
21.11.2015, 12:52  [ТС]
Хозяин, что конкретно непонятно? Перефразируя самое последнее предложение: как создать уровень абстракции над уже существующими сущностями?
0
Заблокирован
21.11.2015, 13:12
skilllab, Я не понимаю для чего этот уровень абстракции, EF по сути и есть тот самый уровень абстракции, через который вы работаете с БД. У вас есть БД, есть ее обертка на C#, реализовать методы добавление, удаления и вывода данных не проблема, что еще нужно?

Добавлено через 1 минуту
skilllab, Теперь вижу, вы работаете с WPF, не со всем в тот раздел написали. Создавайте View модель и работайте с ней.
1
 Аватар для skilllab
296 / 236 / 58
Регистрация: 03.02.2011
Сообщений: 2,045
Записей в блоге: 1
21.11.2015, 13:21  [ТС]
Цитата Сообщение от Хозяин Посмотреть сообщение
Создавайте View модель
Есть ли какие либо примеры на русском для создания ViewModel при существующих сущностях? Я перелопатил гору гуглоссылок, все по ASP или какой-то уж очень замороченный паттерн.
0
Заблокирован
21.11.2015, 13:24
Лучший ответ Сообщение было отмечено skilllab как решение

Решение

skilllab, Ща скину, не влезает такое ко-во строчек

Добавлено через 1 минуту
Думаю разберетесь кто есть что
Вложения
Тип файла: rar Desktop.rar (5.6 Кб, 8 просмотров)
0
 Аватар для skilllab
296 / 236 / 58
Регистрация: 03.02.2011
Сообщений: 2,045
Записей в блоге: 1
21.11.2015, 13:26  [ТС]
CafeBalukEntities - это и есть сущности? Которые у вас подгружаются из базы данных или там...сайта
0
Заблокирован
21.11.2015, 13:35
skilllab, Смысл такой, у меня есть модель парсинга с сайта данных и модель моя (БД в SQL), которая хранит все заказы в БД используя обертку EF, при загрузке проги, она парсит с сайта данные и выводит в клиент, далее пользователь работает с этими данными используя View модель. Итого имеем: база SQL Serverб модель парсинга данных с сайта, view модель. Тут конечно сложно уловить как и что работает, показывать нужно на примере
0
 Аватар для skilllab
296 / 236 / 58
Регистрация: 03.02.2011
Сообщений: 2,045
Записей в блоге: 1
21.11.2015, 13:37  [ТС]
В целом - понятно. Только что даёт GalaSoft.MvvmLight? Весь код на ладони же))
0
Заблокирован
21.11.2015, 13:47
skilllab, Он создает мне ту самую View модель и нужные каталоги для работы и связывает в проекте модель, view модель и XAML для его корректной работы

Добавлено через 6 минут
skilllab, Посмотрите вот эти статьи, я с них начинал свое знакомство с WPF
http://megadarja.blogspot.com.... m-wpf.html
http://sonyks2007.blogspot.com... /mvvm.html
0
 Аватар для skilllab
296 / 236 / 58
Регистрация: 03.02.2011
Сообщений: 2,045
Записей в блоге: 1
22.11.2015, 12:14  [ТС]
Цитата Сообщение от Хозяин Посмотреть сообщение
Думаю разберетесь
Спасибо большое. Натолкнули на очень много нужных мыслей.

Добавлено через 11 часов 42 минуты
Хозяин, вопрос: правильно ли делать это во ViewModel
C#
1
using (var context = new CafeBalukEntities())
0
Заблокирован
22.11.2015, 12:59
skilllab, Смотря разные источники по WPF, везде твердо говорят, что вся логика программы должна быть во View модель и ни строчки кода в классе формы. Думаю что ДА
1
 Аватар для skilllab
296 / 236 / 58
Регистрация: 03.02.2011
Сообщений: 2,045
Записей в блоге: 1
22.11.2015, 13:01  [ТС]
Не ну мало-ли надо ещё какой класс для непосредственной работы с базой данных реализовывать, типа update, add, delete. Именно в рамках mvvm!!
0
Заблокирован
22.11.2015, 13:11
skilllab, В идеале, для каждой формы создается своя ViewModel, ну можно сделать и свою обертку для работы с EF, но думаю что у вас не получится сделать ее универсальной для любого проекта написанного на EF, она получится сугубо только для вашей текущей модели, не более
1
 Аватар для skilllab
296 / 236 / 58
Регистрация: 03.02.2011
Сообщений: 2,045
Записей в блоге: 1
23.11.2015, 17:50  [ТС]
Цитата Сообщение от Хозяин Посмотреть сообщение
для каждой формы создается своя ViewModel
Так и сделал.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.11.2015, 17:50
Помогаю со студенческими работами здесь

Entity Framework 6
Нарисовалась неожиданная проблемка. Штудирую Троелсена, там описание Framework 4, у меня 6-я версия. Один из примеров пришлось...

Использовать ли Entity Framework?
Здравствуйте! Для своей работы хочу разработать приложение, взаимодействующее с БД, которая должна содержать около 30 табличек. Поскольку...

Проблема с Entity Framework
Здравствуйте, возникла проблема с отображением связей между таблицами(визуальном) в студии используя Entity Framework, то есть они не...

Entity Framework и контексты
Если я получил объект и одного контекста, потом передаю его в метод, где открываю этот же контекст. Произвожу именения объекта и делаю...

Освоение entity framework
всем доброго времени, хочу освоить entity framework можете посоветовать литературу или сайты, в общем все, что может помочь


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru