dream-land.by  
Вход
  Поиск  
English
русский
Программирование, разработка, тестирование
Entity Framework (работа с базой данных на C#)
Соглашения по преобразование типов, наименованию таблиц в Entity Framework
  Посмотрели 3284 раз(а)    
скрыть панель >>...
 Соглашения в Entity Framework 
последнее обновление: 16 января 2019
В Entity Framework действуют соглашения по именованию таблиц, столбцов, преобразование типов.
Соглашение по преобразованию типов Базы данных в → C#. И преобразование типов C# в → Базу данных
Тип в базе данных SQL Server
преобра
зуется в
C# тип
преобра
зуется в
Тип в базе данных SQL Server
bit
bool
bit
tinyint
byte
tinyint
smallint
short
smallint
int
int
int
real
float
real
float
double
float
numeric
decimal
money
decimal
decimal
date
datetime
datetime2
DateTime
datetime
nchar
ntext
char
nvarchar
text
varchar
string
nvarchar(MAX)
byte[]
varbinary(MAX)
int
На заметку!
Чтобы создалась в базе данных был тип только date
нужно описать C# класс так:
  C#  
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Entity;
using System.ComponentModel.DataAnnotations.Schema; // подключаем распознование [...]

namespace Plan.Models
{
     public class Book
     {
          public int Id { get; set; }

          [Column(TypeName="date")]
          public DateTime StartDate { get; set; }

          public string Name { get; set; }
     }
}
Может ли колонка в Базе данных содержать NULL значение ?
Первичный ключ
(колонка ID или id или ID)
по умолчанию в Базе данных имеет NOT NULL.
Колонки в базе данных, созданные по C# классу из числовых типов и времени: DateTime, bool, char, decimal, int, double, float
по умолчанию в Базе данных имеет NOT NULL.
Колонки в базе данных, созданные по C# классу из ссылочных типов (string, array, ...)
по умолчанию в Базе данных имеет NULL.
Колонки в базе данных, созданные по C# классу из свойств с типом Nullable или тип?
по умолчанию в Базе данных имеет NULL.
Как сделать чтобы тип int мог иметь null в базе данных
Когда мы пишем int колонка не может содержать NULL значение
  C#  
public class Task
{
     public int Id { get; set; }
     public int Price { get; set; }
}

Таблица в базе данных:
---------------------------------------
Когда мы пишем int? колонка может содержать NULL значение
  C#  
public class Task
{
     public int Id { get; set; }
     public int? Price { get; set; }
}

Таблица в базе данных:
---------------------------------------
Это правило относится ко все простым типам: bool, char, decimal, int, double, float
 Внешний ключ (Foreign Key) и каскадное удаление 
Внешний ключ (Foreign Key) это связь с другой таблицей.

Чтобы образовать внешний ключ нужно чтобы
Имя_свойства_в_нашем_классе
=
Имя_класса_связанной_таблицы + Имя_ключа_из_связанной_таблицы

Каскадное удаление
• Если внешний ключ определяется как int? то внешний ключ может иметь null значения и нет каскадного удаления.
• Если внешний ключ определяется как int то внешний ключ не может иметь null значения и будет каскадное удаление.
Пример1 (foreign key может быть null)
  C#  
public class UserContext : DbContext
{
     // MyConnection1 это соединение с базой данных описанное в файле web.config
     public UserContext() : base("MyConnection1")
     {
     }

     public DbSet<User> Users {get; set;}
     public DbSet<Task> Tasks { get; set; }
}

public class User
{
     public int Id {get;set;}
     public string Email {get; set;}
     public string Password{get; set;}
}

public class Task
{
     public int Id { get; set; }
     public int Price { get; set; }

     public int? UserId { get; set; } // определяем внешний ключ (int? значит может иметь null значение)
     public User User { get; set; } // это тоже необходимо для внешнего ключа
}
На заметку!
Если внешний ключ определяется как int? то внешний ключ может иметь null значения и нет каскадного удаления.
В MS Sql Server база данных выглядит так:
Пример2 (foreign key не может быть null)
  C#  
public class UserContext : DbContext
{
     // MyConnection1 это соединение с базой данных описанное в файле web.config
     public UserContext() : base("MyConnection1")
     {
     }

     public DbSet<User> Users {get; set;}
     public DbSet<Task> Tasks { get; set; }
}

public class User
{
     public int Id {get;set;}
     public string Email {get; set;}
     public string Password{get; set;}
}

public class Task
{
     public int Id { get; set; }
     public int Price { get; set; }

     public int UserId { get; set; } // определяем внешний ключ (int значит НЕ может иметь null значение)
     public User User { get; set; } // это тоже необходимо для внешнего ключа
}
На заметку!
Если внешний ключ определяется как int то внешний ключ НЕ может иметь null значения и будет каскадное удаление.
В MS Sql Server база данных выглядит так:
Выбор названий для таблиц и столбцов
С помощью специального класса PluralizationService Entity Framework проводит сопоставление между именами классов моделей и именами таблиц. При этом таблицы получают по умолчанию в качестве названия множественное число в соответствии с правилами английского языка, например, класс User - таблица Users, класс Person - таблица People (но не Persons!).

Названия столбцов получают названия свойств модели.

Если нас не устраивают названия таблиц и столбцов по умолчанию, то мы можем переопределить данный механизм с помощью:
Дата аннотаций в [...]
Fluent API.
 
← Предыдущая тема
Что такое Entity Framework?
 
Следующая тема →
Внешний ключ (Foreign Key) и каскадное удаление
 
Ваши Отзывы ... комментарии...
   
Ваш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