dream-land.by  
Вход
  Поиск  
English
русский
Программирование, разработка, тестирование
Entity Framework (работа с базой данных на C#)
Что такое Entity Framework?
  Посмотрели 3353 раз(а)    
скрыть панель >>...
 Что такое Entity Framework? 
последнее обновление: 20 июня 2018
Entity Framework это объектно-ориентированная технология для работы с базой данных через C# классы.
C# класс в Entity Framework сопоставляется таблице в базе данных.

Технология ADO.NET позволяет создавать подключения, SQL команды для взаимодействия с базами данных.
То есть в ADO.NET мы оперируем таблицами, индексами, первичными и внешними ключами.

Entity Framework представляет собой более высокий уровень абстракции, который позволяет абстрагироваться от самой базы данных и работать с базой данных в виде C# классов (объектов)

Entity Framework предоставляет преимущества:
• вам не нужно знать деталей работы Базы данных SQL Server
• вам не нужно знать деталей синтаксиса языка SQL
Entity Framework берет на себя обязанности по преобразованию C# кода в SQL-инструкции.

Концепция Entity Framework
Главным в концепции Entity Framework является понятие сущности (entity).
Сущность (entity) в Entity Framework это C# класс
Шаг 1 Сущность в Entity Framework.
Сущность (entity) это C# класс
В C# классе обязательно должно быть поле id или ID или Id (это primary key в Базе данных)

Пример
public class Book
{
    public int Id { get; set; } // обязательное поле
    public string Name { get; set; }
    public int Price { get; set; }
}
сопоставляется таблице в Базе данных

Название таблицы в Базе данных образуется от названия C# класса Book с добавлением буквы s

Таблица Books в Базе Данных
Колонка Id
Колонка Name
Колонка Price
Шаг 2 Подключение Entity Framework к Базе данных.
Для подключения к Базе данных нам нужен контекст данных. Пишем свой класс отнаследованный от класса DbContext

Пример
class MyContext : DbContext
{
    // MyConnection1 строка соединения к базе данных
    // MyConnection1 строка соединения описана в .config файле
    public MyContext() : base("MyConnection1")
    { }

    // DbSet это массив данных
    public DbSet<Book> Books { get; set; }
}
Шаг 3 Добавляем соединение к базе данных в файле App.config или Web.config
Файл зависит от типа Вашего приложения.
Читать подробнее <connectionStrings> в .config файле...
Шаг 4 Добавление данных в Entity Framework.

Пример
using (UserContext db = new UserContext())
{
      // создаем объект Book
      Book book1 = new Book { Name = "Граф Монтекристо", Price = 123 };

      // добавляем объект Book в контекст данных
      db.Books.Add(book1);

      // сохраняем контекст данных в базу данных
      db.SaveChanges();
}
Выборка данных в Entity Framework
Важным моментом в Entity Framework является использование запросов LINQ для выборки данных из Базы данных.
С помощью LINQ мы можем получать объекты из Базы данных, связанные различными ассоциативными связями.
Подходы в Entity Framework
Database-First. Подходит для проектировщиков баз данных.
Сначала вы создаете базу данных с помощью различных инструментов (например в SQL Server Management Studio), а затем генерируете EDMX-модель базы данных (предоставляет удобный графический интерфейс для взаимодействия с базой данных в виде диаграмм и объектную модель в виде классов C#). В данном случае вам нужно работать с SQL Server и хорошо знать синтаксис T-SQL, но при этом не нужно разбираться в C#.
Model-First. Подходит для архитекторов.
Сначала вы создаете графическую модель EDMX в Visual Studio (в фоновом режиме создаются классы C# модели), а затем генерируете на основе диаграммы EDMX базу данных. При данном подходе не нужно знать ни деталей T-SQL ни синтаксиса C#.
 
 
Следующая тема →
Соглашения по преобразование типов, наименованию таблиц в Entity Framework
 
Ваши Отзывы ... комментарии...
   
Вашe имя:
Ваш комментарий (www ссылки может добавлять только залогиненный пользователь)

Картинки

Объявления
  Языки программирования и другое  
Программы для разработки (интегрированные среды для разработки IDE)
Microsoft Visual Studio (среда разработки для написания программ на C#, С++, Javascript, ASP.NET приложений)
Visual Studio Code (редактор кода для написания программ на JavaScript, Perl, Python, Java, C#)

HTML
Html & CSS
SCSS файл (с помощью компилятора SASS получаем CSS файл)
LESS файл (с помощью компилятора получаем CSS файл)

Интерактивная реклама в HTML (animate banner)
Google Web Designer - редактор для создания рекламы, animate banner и т.д. в виде HTML страницы, и в виде HTML AMP страниц (ускоренные мобильные страницы)

WEB сайт
Создание Web сайта и управление (регистрация сайта, копирование файлов на сайт, сохранение базы данных)
Комания Google. Google сервисы для Web сайта (счетчик посещений, карта улиц, переводчик языков, контекстная реклама, ...)
Комания Google. Google сервисы для Web сайта (проверить скорость загрузки страницы web сайта)

Javascript, TypeScript
JavaScript - язык программирования для HTML
Underscore.js
jQuery - JavaScript библиотека для удобной работы с HTML
Knockout.js - JavaScript библиотека для свзяывания HTML элемента с js переменной
TypeScript - язык программирования похожий на JavaScript. TypeScript использует типы, классы, наследование. TypeScript преобразуется в JavaScript

Кнопки, текстовые поля и другие элементы на WEB странице
Bootstrap - кнопки, меню, диалог, slider ... Контейнеры для размещения элементов
jQuery UI - кнопки, меню, диалог, slider, spinner и так далее. Эфекты: растягивание, перетаскивание и так далее
jq Plot - диаграммы, графические линии
PivotTable - таблицы, графики
Telerik, Kendo UI - это элементы: DropDownList, ComboBox, AutoComplete, Calendar, редактор текста, excell, chart и так далее

JavaScript технологии
Node.js (это web сервер исполняющий js файлы)
React
AngularJS (это Angular версии 1.0)
Angular версии 8
Angular версии 9
RxJs (это реактивное программирование и в основном используется в Angular)

JavaScript графика, анимация для игр
PixiJS - JavaScript библиотека для быстрого рисования графики 2D (это самый быстрый, самый гибкий рендер графики 2D, WebGL)
p5.js - JavaScript библиотека для рисования графики 2D (рисование картинок, линий, движений), 3D графики (рисования материалы, свет, текстуры)
Three.js - JavaScript библиотека для рисования графики 3D на страницах HTML

JavaScript менеджер пакетов (добавление JavaScript библиотек в ваш Web проект)
npm - это менеджер пакетов для Node.js. npm добавляет JavaScript библиотеки в папку node_modules
Webpack - это САМЫЙ ПОПУЛЯРНЫЙ менеджер пакетов. Webpack добавляет JavaScript библиотеки в ваш проект
Yarn - это менеджер пакетов. Yarn добавляет JavaScript библиотеки в ваш проект
Parcel - это менеджер пакетов. Parcel добавляет JavaScript библиотеки в ваш проект
Bower - это менеджер пакетов. Bower добавляет JavaScript библиотеки в ваш проект. Bower сейчас НЕ ПОДДЕРЖИВАЕТСЯ (не добавляет новых JavaScript библиотек)

Автоматическое выполнение задач в вашем Web проекте
Gulp - это JavaScript программа для автоматического выполнения задач (объединения файлов, уменьшение размера картинок) в вашем Web проекте
Grunt - это JavaScript программа для автоматического выполнения задач (объединения файлов, уменьшение размера картинок) в вашем Web проекте

База данных (My SQL)
MySQL (база данных, server) и Workbench (программа для работы с my sql). Работает на разных платформах: Unix, Windows

База данных (SQL Server)
Microsoft SQL Server (база данных). Работает только в Windows
Microsoft SQL Server Management Studio (программа для работы с базой данных sql server)
SQL (язык запросов в базе данных)

База данных (PostgreSQL)
PostgreSQL сервер (база данных) и pgAdmin (программа для работы с PostgreSQL сервер). Работает на разных платформах: Unix, Windows

Работа с базой данных на C#
ADO.NET (работа с базой данных на C#)
Entity Framework (работа с базой данных на C#)
LINQ to SQL (работа с базой данных на C#)

Работа с Redis
Redis

Интернет, HTTP, TCP, UDP, FTP протоколы
HTTP протокол для загрузки web страницы, TCP протокол для соединения между компьютерами, IP-адрес ...

RabbitMQ
RabbitMQ

Microsoft C# и .NET
C# (язык программирования)
ReSharper (JetBrains). Улучшение кода в Visual Studio 2017 для C# приложений
Managed C++ (переходный код между C++ и C#)
Windows Forms (отдельное приложение exe файл)
WPF. Windows Presentation Foundation (отдельное приложение exe файл)
ASP.NET Web Forms (web сайт на aspx страницах). Это устаревшая технология!
ASP.NET MVC (web сайт на архитектуре Model-View-Controller)
.NET Core
Web API (веб-служба работающая по протоколу HTTP)
Windows Communication Foundation (веб-служба работающая через интерфейсы)
Silverlight
Microsoft XNA
Xamarin (приложение на C# для iOS, Android, Windows Phone)
Юнит тестирование (MSTest, NUnit, xUnit, Moq)
Собеседование (вопросы и задания C# и платформа .NET)

Microsoft Office 365 E3 (Web services)
Microsoft Office 365 E3 (Teams plug-in, SharePoint web api)

Python
Python

Java программирование (приложения для windows, андроид телефонов)
IntelliJ IDEA среда разработки для Java
Android Studio среда разработки для написания программ для Android телефонов на языке Java
Java

Mobile Development with C++ (Android, iOS)
Mobile Development with C++ (iOS, Android, Windows Phone)

Flutter & Dart
Flutter - фрэймворк для создания мобильных приложений от компании Google

Облачные технологии
Microsoft Azure & Azure DevOps (облачные технологии)
Amazon Web Services (облачные технологии)
Google Cloud Platform (облачные технологии)
Heroku (облачные технологии)

Резюме (как найти работу)
Как написать резюме, причины перехода на другую работу

Автоматизированное тестирование
Selenium WebDriver (для автоматизированного тестирования веб-приложений)

Рефакторинг & Паттерны
Паттерны, шаблоны проектирования | принципы ООП | рефакторинг кода

Методологии управления проектами
Agile, scrum, kanban. Методологии в управлении IT-проектам. В чем разница?
Правила разработки web приложений в Яндекс

Управление версиями проекта, история измененных файлов
Git (управление версиями проекта, история измененных файлов) | Git Extensions | GitHub.com | git in Team Explorer for Visual Studio 2017
Svn (управление версиями проекта, история измененных файлов) | TortoiseSVN (работаем с SVN под Windows)

Математические алгоритмы
Массивы, графы (математические алгоритмы)

CI/CD
Непрерывная интеграция (автоматическая сборка проекта, развертывание проекта на удаленный компьютер) | CI/CD

Docker
Docker (упаковка web приложения в контейнер)

Kubernetes
Kubernetes (запуск контейнеров на виртуальных машинах и балансировка нагрузки виртуальных машин)

Микрослужбы
Микрослужбы (Microservices)

Разработка игр
Моя игра "Animal Go". Технологии: C#, Android, Windows
Моя разработка игр на HTML, Javascript, Typescript

Создания 2D графики для игры
2D графика для игры: картинки растровые по точкам | картинки векторные по линиям, фигурам
2D анимация для игры

Технологии для написания игр
MonoGame - разработка 2D игр на C# для Android, iOS, Windows
Unity - разработка 3D игр на C# для Android, iOS, Windows
LibGDX - разработка игр на Java для Android
SmartFoxServer - библиотека multiplayer на Java, C#, JavaScript, Unity, для Android, iOS

Еще языки программирования
PHP (язык программирования для быстрого написания Web сайта)
C++

Интернет браузеры
Интернет браузер "Google Chrome"
Error in Google Chrome: "Access to ... blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'null' is therefore not allowed access"

Telegram (месенджер)
Telegram (месенджер)

WEB сервер
Что такое WEB сервер ?

bat файлы
.bat файл (командная строка)

.htaccess файлы
.htaccess файл (команды)

Viber
Viber. Устанавливаем. Переносим Viber сообщения и Viber фото.

Операционная система LINUX
Ubuntu (linux) Virtual Machine on Windows 10
Ubuntu (in console as WSL) on Windows 10

Операционная система Mac OS
Mac OS Virtual Machine on Windows 10

Операционная система WINDOWS и программы
Windows 10 (операционная система для персональных компьютеров)
Скачиваем Windows 10 и создание загрузочной флешки
Скачиваем и устанавливаем Ofiice 365 для Windows 10
Скачиваем и устанавливаем Microsoft Teams для Windows 10

Операционная система ANDRIOD
Android (операционная система для телефонов, планшетов)

Операционная система iOS
iOS (операционная система для iPhone телефонов, iPad планшетов, MacBook ноутбуков)

Компьютерная платформа (процессор)
x86 процессоры
ARM процессоры

Ноутбук (BIOS)
В ноутбуке не работают клавиши F1 ... F2 как надо. Проблема: я открываю браузер Google Chrome и нажимаю кнопку F5 чтобы перезагрузить страницу, а у меня включается подсветка клавиатуры.

Быстродействие компьютера (процессора)
Сравниваем быстродействие компьютера (процессора) на сайте http://userbenchmark.com

Графика и видео

2D графические редакторы
Adobe Master Collection - графические редакторы (Photoshop растровая графика, Illustrator векторная графика)
Corel - графические редакторы (растровая и векторная графика)

3D графические редакторы
Maya (autodesk) - редактор 3D графики

Видео
Видео (редактирование, создание)

Online: просмотр Word файлов, конвертация PDF файлов, распознование картинки в текст
Просмотр и редактирование Word файлов (doc, docx) Онлайн

PDF to word, images
Convert PDF to Word (online)
Convert FB2 to PDF (online)

Распознавание картинки в текст
Распознать (перевести) картинку в текст (ONLINE)

Регулярные выражения
Регулярные выражения (проверить онлайн)

Поставить HD Video Box в Windows
Поставить HD Video Box в Windows

Открыть ИП в Минске (через интернет)
Открыть ИП (Индивидуальный Предприниматель) в Минске (через интернет)
Entity Framework (работа с базой данных на C#)  
Что такое Entity Framework?
Типы в Entity Framework
Соглашения по преобразование типов, наименованию таблиц в Entity Framework
Внешний ключ (Foreign Key) и каскадное удаление
DateTime & только Date & только Time в Entity Framework
Code First
Code First. Мы пишем C# класс. Entity Framework по нашему C# классу → создает и заполняет таблицу в базе данных
Auto Code First. Entity Framework из существующей таблицы в базе данных → создает C# класс
Database First
Database First. Entity Framework из существующей таблицы в базе данных → создает C# класс
Model First
Model First. Мы создаем модель в Visual Studio. По модели Entity Framework → создает C# классы и Базу данных
Работа с данными
Перебор данных в Entity Framework
Добавление данных в Entity Framework
Изменение (редактирование) данных в Entity Framework
Удаление данных в Entity Framework
Инициализация и миграция базы данных
Инициализация базы данных в Entity Framework. DropCreateDatabaseAlways позволяет при каждом новом запуске заполнять базу данных заново
Выполнение миграции Базы Данных в Entity Framework (если уже кто-то раньше сделал cs файл миграции, а мне хочется обновить у себя на компютере базу данных я выполняю миграцию то есть вызываю EntityFramework\Update-Database)
Создание и выполнение миграции Базы Данных в Entity Framework (я поменял c# класс, потом вызываю EntityFramework\add-migration т.е. автоматически добавляется в проект cs файл с кодом миграции, потом вызываю EntityFramework\Update-Database т.е. выполняется файл миграции и меняется база данных)
SQL в Entity Framework
SQL команды в Entity Framework
Транзакции в Entity Framework
Управление транзакциями в Entity Framework
Дополнительные темы, вопросы
Что такое <connectionStrings> в .config файле
При вызове EntityFramework\Update-Database появляется ошибка "System.Data.SqlClient.SqlException (0x80131904). A network-related or instance-specific error occurred while establishing a connection to SQL Server."
При вызове EntityFramework\Update-Database появляется ошибка "Your startup project '...' doesn't reference Microsoft.EntityFrameworkCore.Design"
WWW сайты для изучения Entity Framework
Сайты для изучения Entity Framework
Анонс! Цирк -Шапито "Цирк Юрского периода" впервые в Беларуси!!! Витебск с 7 по 23 мая 2021  
Комментариев 106
Цирк Sirius : 13 мая 2021 Доброго времени суток. Для начала скажу, вы перепутали программы «Космическое шоу» и «Цирк...
Объявления

Концерты, выставки
Рассказы (отдых в парке, на концерте)
Спортивные занятия
Детские центры
Кино
Книги
Бесплатные объявления
Праздники
Скидки в магазинах Минска
Домашние животные
Программирование и технологии
Игра
Путешествия
Рассказы о путешествиях
Форум (обсуждение)
vsedetkam.by для детей
Архив Евровидений

  Ваши вопросы присылайте по почте: info@dream-land.by