{"id":364,"date":"2023-02-03T10:57:27","date_gmt":"2023-02-03T10:57:27","guid":{"rendered":"https:\/\/dijix.com.ua\/blog\/?p=364"},"modified":"2023-02-03T10:58:55","modified_gmt":"2023-02-03T10:58:55","slug":"magazin-na-asp-net-core-mvc-ef-chast-1","status":"publish","type":"post","link":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/","title":{"rendered":"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1"},"content":{"rendered":"<p>\u0423 \u0446\u044c\u043e\u043c\u0443 \u0443\u0440\u043e\u0446\u0456 \u0440\u043e\u0437\u0433\u043b\u044f\u043d\u0435\u043c\u043e \u043f\u0440\u043e\u0446\u0435\u0441 \u043f\u043e\u0431\u0443\u0434\u043e\u0432\u0438 \u0440\u0435\u0430\u043b\u0456\u0441\u0442\u0438\u0447\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0454\u043a\u0442\u0443, \u044f\u043a\u0438\u0439 \u043f\u0440\u043e\u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0443\u0454 \u0441\u043f\u0456\u043b\u044c\u043d\u0435 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f ASP.NET Core MVC \u0456 Entity Framework Core. \u041f\u0440\u043e\u0454\u043a\u0442 \u0431\u0443\u0434\u0435 \u043f\u0440\u043e\u0441\u0442\u0438\u043c, \u0430\u043b\u0435 \u0431\u043b\u0438\u0437\u044c\u043a\u0438\u043c \u0434\u043e \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0456, \u0456 \u0444\u043e\u043a\u0443\u0441\u0443\u0432\u0430\u0442\u0438\u043c\u0435\u0442\u044c\u0441\u044f \u043d\u0430 \u0447\u0430\u0441\u0442\u043e \u0432\u0436\u0438\u0432\u0430\u043d\u0438\u0445 \u0437\u0430\u0441\u043e\u0431\u0430\u0445 Entity Framework Core.<\/p>\n<p>\u042f \u043e\u0447\u0456\u043a\u0443\u044e \u0432\u0456\u0434 \u0432\u0430\u0441 \u043c\u0456\u043d\u0456\u043c\u0430\u043b\u044c\u043d\u0456 \u0437\u043d\u0430\u043d\u043d\u044f \u043a\u043e\u043d\u0446\u0435\u043f\u0446\u0456\u0439 Entity Framework Core, \u0442\u043e\u043c\u0443 \u0432 \u0434\u0435\u044f\u043a\u0438\u0445 \u043c\u0456\u0441\u0446\u044f\u0445, \u0432\u0434\u0430\u0432\u0430\u0442\u0438\u0441\u044f \u0432 \u043f\u043e\u0434\u0440\u043e\u0431\u0438\u0446\u0456 \u043d\u0435 \u0441\u0442\u0430\u043d\u0443.<\/p>\n<h2>\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF<\/h2>\n<p><a href=\"#createproject\">\u0421\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0442\u0430 \u043d\u0430\u043b\u0430\u0448\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0443<\/a><\/p>\n<p><a href=\"#model\">\u041c\u043e\u0434\u0435\u043b\u044c \u0456 \u0420\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0456\u0439<\/a><\/p>\n<p><a href=\"#controller\">\u0414\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u0430 \u0442\u0430 \u043f\u043e\u0434\u0430\u043d\u043d\u044f<\/a><\/p>\n<p><a href=\"#efcore\">\u0417\u0431\u0435\u0440\u0456\u0433\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0437 Entity Framework Core<\/a><\/p>\n<p><a href=\"#migration\">\u041f\u0456\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0430 \u043c\u043e\u0434\u0435\u043b\u0456 \u0434\u0430\u043d\u0438\u0445<\/a><\/p>\n<p><a href=\"#context\">\u0421\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043a\u043b\u0430\u0441\u0443 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443 \u0434\u0430\u043d\u0438\u0445<\/a><\/p>\n<p><a href=\"#dataupdate\">\u0417\u043c\u0456\u043d\u0430 \u0440\u0435\u0430\u043b\u0456\u0437\u0430\u0446\u0456\u0457 \u0441\u0445\u043e\u0432\u0438\u0449\u0430<\/a><\/p>\n<p><a href=\"#appsettings\">\u041a\u043e\u043d\u0444\u0456\u0433\u0443\u0440\u0443\u0432\u0430\u043d\u043d\u044f \u043f\u043e\u0441\u0442\u0430\u0447\u0430\u043b\u044c\u043d\u0438\u043a\u0430 \u0431\u0430\u0437\u0438 \u0434\u0430\u043d\u0438\u0445 \u0456 \u043a\u043b\u0430\u0441\u0443 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443<\/a><\/p>\n<p><a href=\"#databasecreate\">\u0421\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0431\u0430\u0437\u0438 \u0434\u0430\u043d\u0438\u0445<\/a><\/p>\n<p><a href=\"#apprun\">\u0412\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0438<\/a><\/p>\n<p><a href=\"#catcherros\">\u0423\u043d\u0438\u043a\u043d\u0435\u043d\u043d\u044f \u043f\u0430\u0441\u0442\u043e\u043a, \u043f\u043e\u0432&#8217;\u044f\u0437\u0430\u043d\u0438\u0445 \u0456\u0437 \u0437\u0430\u043f\u0438\u0442\u0430\u043c\u0438<\/a><\/p>\n<p><a href=\"#final\">\u041f\u0456\u0434\u0441\u0443\u043c\u043e\u043a<\/a><\/p>\n<p>\u0423 \u0446\u044c\u043e\u043c\u0443 \u0443\u0440\u043e\u0446\u0456 \u043c\u0438 \u0441\u0442\u0432\u043e\u0440\u0438\u043c\u043e \u043f\u0440\u043e\u0441\u0442\u0438\u0439 \u0441\u0430\u043c\u043e\u0434\u043e\u0441\u0442\u0430\u0442\u043d\u0456\u0439 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043e\u043a ASP.NET Core MVC, \u0434\u043e\u0434\u0430\u043c\u043e \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0443 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0438 Entity Framework Core \u0456 \u0437\u0431\u0435\u0440\u0435\u0436\u0435\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043a\u0443 \u0432 \u0411\u0414.<\/p>\n<p>\u0423 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u043e\u043c\u0443 \u0443\u0440\u043e\u0446\u0456, \u0434\u043e\u0434\u0430\u043c\u043e \u0434\u043e\u0434\u0430\u0442\u043a\u043e\u0432\u0456 \u043e\u043f\u0435\u0440\u0430\u0446\u0456\u0457 \u043d\u0430\u0434 \u0434\u0430\u043d\u0438\u043c\u0438, \u0440\u043e\u0437\u0448\u0438\u0440\u0435\u043d\u0443 \u043c\u043e\u0434\u0435\u043b\u044c \u0434\u0430\u043d\u0438\u0445, \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0435\u043d\u043d\u044f \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0438 \u0437\u0430\u0441\u043e\u0431\u0456\u0432 \u0434\u043b\u044f \u043f\u043e\u043a\u0443\u043f\u0446\u0456\u0432 \u0456 \u0440\u043e\u0437\u0433\u043b\u044f\u043d\u0435\u043c\u043e, \u044f\u043a \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0443\u0432\u0430\u0442\u0438 \u0434\u043e\u0434\u0430\u0442\u043e\u043a.<\/p>\n<h2 id=\"createproject\">\u0421\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0442\u0430 \u043d\u0430\u043b\u0430\u0448\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0443<\/h2>\n<p>\u0429\u043e\u0431 \u0441\u0442\u0432\u043e\u0440\u0438\u0442\u0438 \u043f\u0440\u043e\u0454\u043a\u0442 <strong>GameStore<\/strong>, \u0437\u0430\u043f\u0443\u0441\u0442\u0456\u0442\u044c Visual Studio \u0456 \u0432\u0438\u0431\u0435\u0440\u0456\u0442\u044c \u0443 \u043c\u0435\u043d\u044e File (\u0424\u0430\u0439\u043b) &#8211; New Project (\u0421\u0442\u0432\u043e\u0440\u0438\u0442\u0438 \u043f\u0440\u043e\u0454\u043a\u0442). \u0412\u043a\u0430\u0436\u0456\u0442\u044c \u0448\u0430\u0431\u043b\u043e\u043d \u043f\u0440\u043e\u0435\u043a\u0442\u0443 ASP.NET Core Web Application (\u0412\u0435\u0431-\u0434\u043e\u0434\u0430\u0442\u043e\u043a ASP.NET Core). \u0412\u0432\u0435\u0434\u0456\u0442\u044c <strong>GameStore<\/strong>, \u0443 \u043f\u043e\u043b\u0456 Name, \u043d\u0430 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u0456\u0439 \u0441\u0442\u043e\u0440\u0456\u043d\u0446\u0456 \u0432\u043a\u0430\u0436\u0456\u0442\u044c Framework .Net 6.0 \u0456 \u043d\u0430\u0442\u0438\u0441\u043d\u0456\u0442\u044c \u043a\u043d\u043e\u043f\u043a\u0443 <strong>Create<\/strong>:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-188 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1.png\" alt=\"\u0438\u043d\u0442\u0435\u0440\u043d\u0435\u0442 \u043c\u0430\u0433\u0430\u0437\u0438\u043d asp.net core\" width=\"913\" height=\"626\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1.png 913w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1-300x206.png 300w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1-768x527.png 768w\" sizes=\"auto, (max-width: 913px) 100vw, 913px\" \/><\/p>\n<h2>\u041c\u043e\u0434\u0435\u043b\u044c \u0456 \u0420\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0456\u0439<\/h2>\n<p>\u041c\u043e\u0434\u0435\u043b\u044c \u0434\u043b\u044f \u0434\u043e\u0434\u0430\u0442\u043a\u0430 <strong>GameStore<\/strong> \u0431\u0443\u0434\u0435 \u0437\u0430\u0441\u043d\u043e\u0432\u0430\u043d\u0430 \u043d\u0430 \u0441\u043f\u0438\u0441\u043a\u0443 \u0442\u043e\u0432\u0430\u0440\u0456\u0432. \u0421\u0442\u0432\u043e\u0440\u0456\u0442\u044c \u043f\u0430\u043f\u043a\u0443 Models \u0456 \u0434\u043e\u0434\u0430\u0439\u0442\u0435 \u0432 \u043d\u0435\u0457 \u0444\u0430\u0439\u043b \u043a\u043b\u0430\u0441\u0443 \u043d\u0430 \u0456\u043c&#8217;\u044f <strong>Product.cs<\/strong> \u0437 \u0442\u0430\u043a\u0438\u043c \u0432\u043c\u0456\u0441\u0442\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">public class Product\r\n    {\r\n        public string Name { get; set; }\r\n        public string Category { get; set; }\r\n        public decimal PurchasePrice { get; set; }\r\n        public decimal RetailPrice { get; set; }\r\n    }\r\n<\/pre>\n<p>\u041c\u0435\u043d\u0456 \u043f\u043e\u0434\u043e\u0431\u0430\u0454\u0442\u044c\u0441\u044f \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0443\u0432\u0430\u0442\u0438 \u0443\u0437\u0433\u043e\u0434\u0436\u0435\u043d\u0438\u0439 \u0434\u043e\u0441\u0442\u0443\u043f \u0434\u043e \u0434\u0430\u043d\u0438\u0445 \u0443 \u0434\u043e\u0434\u0430\u0442\u043a\u0443 \u0437 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f\u043c \u043f\u0430\u0442\u0435\u0440\u043d\u0443 &#8220;\u0421\u0445\u043e\u0432\u0438\u0449\u0435&#8221; (Repository), \u0443 \u044f\u043a\u043e\u043c\u0443 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u0432\u0438\u0437\u043d\u0430\u0447\u0430\u0454 \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0456 \u0442\u0430 \u043c\u0435\u0442\u043e\u0434\u0438, \u043f\u0440\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u0456 \u0434\u043b\u044f \u0434\u043e\u0441\u0442\u0443\u043f\u0443 \u0434\u043e \u0434\u0430\u043d\u0438\u0445, \u0430 \u0434\u043b\u044f \u0440\u043e\u0431\u043e\u0442\u0438 \u0437 \u043c\u0435\u0445\u0430\u043d\u0456\u0437\u043c\u043e\u043c \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u043a\u043b\u0430\u0441 \u0440\u0435\u0430\u043b\u0456\u0437\u0430\u0446\u0456\u0457. \u041f\u0435\u0440\u0435\u0432\u0430\u0433\u0430 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f \u043f\u0430\u0442\u0435\u0440\u043d\u0443 &#8220;\u0421\u0445\u043e\u0432\u0438\u0449\u0435&#8221; \u043f\u043e\u0432&#8217;\u044f\u0437\u0430\u043d\u0430 \u0437 \u043f\u043e\u043b\u0435\u0433\u0448\u0435\u043d\u043d\u044f\u043c \u043c\u043e\u0434\u0443\u043b\u044c\u043d\u043e\u0433\u043e \u0442\u0435\u0441\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u0447\u0430\u0441\u0442\u0438\u043d\u0438 MVC \u0434\u043e\u0434\u0430\u0442\u043a\u0430, \u0430 \u0442\u0430\u043a\u043e\u0436 \u0456\u0437 \u0442\u0438\u043c, \u0449\u043e \u0434\u0435\u0442\u0430\u043b\u0456, \u044f\u043a\u0456 \u0441\u0442\u043e\u0441\u0443\u044e\u0442\u044c\u0441\u044f \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445, \u043f\u0440\u0438\u0445\u043e\u0432\u0430\u043d\u0456 \u0432\u0456\u0434 \u0456\u043d\u0448\u0438\u0445 \u0447\u0430\u0441\u0442\u0438\u043d \u0434\u043e\u0434\u0430\u0442\u043a\u0430.<\/p>\n<p>\u0429\u043e\u0431 \u0441\u0442\u0432\u043e\u0440\u0438\u0442\u0438 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u0441\u0445\u043e\u0432\u0438\u0449\u0430, \u0441\u0442\u0432\u043e\u0440\u0456\u0442\u044c \u043f\u0430\u043f\u043a\u0443 <strong>Interfaces<\/strong> \u0456 \u0434\u043e\u0434\u0430\u0439\u0442\u0435 \u0432 \u043d\u0435\u0457 \u0444\u0430\u0439\u043b \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0443 \u043d\u0430 \u0456\u043c&#8217;\u044f <strong>IProduct.cs<\/strong> \u0437 \u0442\u0430\u043a\u0438\u043c \u0432\u043c\u0456\u0441\u0442\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true\">public interface IProduct\r\n    {\r\n        IEnumerable&lt;Product&gt; GetAllProducts();\r\n        void AddProduct(Product product);\r\n    } \r\n<\/pre>\n<p>\u041c\u0435\u0442\u043e\u0434 <strong>GetAllProducts()<\/strong> \u043d\u0430\u0434\u0430\u0432\u0430\u0442\u0438\u043c\u0435 \u0434\u043e\u0441\u0442\u0443\u043f \u0442\u0456\u043b\u044c\u043a\u0438 \u0434\u043b\u044f \u0447\u0438\u0442\u0430\u043d\u043d\u044f \u0434\u043e \u0432\u0441\u0456\u0445 \u0442\u043e\u0432\u0430\u0440\u0456\u0432, \u0432\u0456\u0434\u043e\u043c\u0438\u0445 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043a\u0443. \u041c\u0435\u0442\u043e\u0434 <strong>AddProduct()<\/strong> \u0431\u0443\u0434\u0435 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u0442\u0438\u0441\u044f \u0434\u043b\u044f \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043d\u043e\u0432\u0438\u0445 \u0442\u043e\u0432\u0430\u0440\u0456\u0432.<\/p>\n<p>\u041d\u0430 \u0446\u044c\u043e\u043c\u0443 \u0435\u0442\u0430\u043f\u0456 \u043c\u0438 \u0437\u0431\u0438\u0440\u0430\u0454\u043c\u043e\u0441\u044f \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u0442\u0438 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438 \u043c\u043e\u0434\u0435\u043b\u0456 \u0432 \u043f\u0430\u043c&#8217;\u044f\u0442\u0456, \u0430 \u0442\u0440\u043e\u0445\u0438 \u043f\u0456\u0437\u043d\u0456\u0448\u0435 \u0437\u0430\u043c\u0456\u043d\u0438\u043c\u043e \u0446\u0435 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043e\u044e Entity Framework Core. \u0421\u0442\u0432\u043e\u0440\u0456\u0442\u044c \u043f\u0430\u043f\u043a\u0443 <strong>Repository<\/strong> \u0456 \u0434\u043e\u0434\u0430\u0439\u0442\u0435 \u0432 \u043d\u0435\u0457 \u0444\u0430\u0439\u043b \u043a\u043b\u0430\u0441\u0443 \u043d\u0430 \u0456\u043c&#8217;\u044f <strong>ProductRepository.cs<\/strong> \u0437 \u0442\u0430\u043a\u0438\u043c \u0432\u043c\u0456\u0441\u0442\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">public class ProductRepository : IProduct\r\n    {\r\n        private List&lt;Product&gt; products;\r\n        public ProductRepository()\r\n        {\r\n            products = new List&lt;Product&gt;();\r\n        }\r\n\r\n        public void AddProduct(Product product)\r\n        {\r\n            products.Add(product);\r\n        }\r\n\r\n        public IEnumerable&lt;Product&gt; GetAllProducts()\r\n        {\r\n            return products;\r\n        }\r\n    }\r\n<\/pre>\n<p>\u041a\u043b\u0430\u0441 <strong>ProductRepository<\/strong> \u0440\u0435\u0430\u043b\u0456\u0437\u0443\u0454 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 <strong>IProduct<\/strong> \u0456 \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454 \u0435\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 List \u0434\u043b\u044f \u0432\u0456\u0434\u0441\u0442\u0435\u0436\u0435\u043d\u043d\u044f \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 <strong>Product<\/strong>, \u0442\u043e\u0431\u0442\u043e \u0432 \u0440\u0430\u0437\u0456 \u0437\u0443\u043f\u0438\u043d\u043a\u0438 \u0430\u0431\u043e \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0443\u0441\u043a\u0443 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043a\u0443 \u0434\u0430\u043d\u0456 \u0431\u0443\u0434\u0443\u0442\u044c \u0432\u0442\u0440\u0430\u0447\u0430\u0442\u0438\u0441\u044f. \u041f\u043e\u0441\u0442\u0456\u0439\u043d\u0435 \u0441\u0445\u043e\u0432\u0438\u0449\u0435 \u0431\u0443\u0434\u0435 \u0432\u0432\u0435\u0434\u0435\u043d\u043e \u0432 \u043f\u0456\u0437\u043d\u0456\u0448\u0435, \u0430 \u0441\u0445\u043e\u0432\u0438\u0449\u0430 \u0432 \u043f\u0430\u043c&#8217;\u044f\u0442\u0456 \u0446\u0456\u043b\u043a\u043e\u043c \u0434\u043e\u0441\u0442\u0430\u0442\u043d\u044c\u043e \u0434\u043b\u044f \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u043d\u043d\u044f \u0432 \u043f\u0440\u0430\u0446\u0435\u0437\u0434\u0430\u0442\u043d\u0438\u0439 \u0441\u0442\u0430\u043d \u0447\u0430\u0441\u0442\u0438\u043d\u0438 ASP.NET Core \u041cV\u0421 \u043f\u0440\u043e\u0435\u043a\u0442\u0443, \u043f\u0435\u0440\u0448 \u043d\u0456\u0436 \u0434\u043e\u0434\u0430\u0432\u0430\u0442\u0438 \u0447\u0430\u0441\u0442\u0438\u043d\u0443 EntityFramework Core.<\/p>\n<p>\u0414\u043e\u0434\u0430\u0439\u0442\u0435 \u0432 \u043a\u043b\u0430\u0441 Program \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u0438\u0439 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440, \u0449\u043e\u0431 \u0437\u0430\u0440\u0435\u0454\u0441\u0442\u0440\u0443\u0432\u0430\u0442\u0438 \u043a\u043b\u0430\u0441 <strong>ProductRepository<\/strong> \u044f\u043a \u0440\u0435\u0430\u043b\u0456\u0437\u0430\u0446\u0456\u044e \u0434\u043b\u044f \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f \u0432 \u044f\u043a\u043e\u0441\u0442\u0456 \u0437\u0430\u043b\u0435\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0443 <strong>IProduct<\/strong>:<\/p>\n<pre class=\"lang:default decode:true \">builder.Services.AddSingleton&lt;IProduct, ProductRepository&gt;();<\/pre>\n<p>\u0426\u0435\u0439 \u0440\u044f\u0434\u043e\u043a \u043a\u043e\u0434\u0443 \u0440\u0435\u0454\u0441\u0442\u0440\u0443\u0454 \u043a\u043b\u0430\u0441 <strong>ProductRepository<\/strong> \u0456\u0437 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f\u043c \u043c\u0435\u0442\u043e\u0434\u0443 AddSingleton. \u0423 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0456 \u043f\u0456\u0434 \u0447\u0430\u0441 \u0440\u043e\u0437\u043f\u0456\u0437\u043d\u0430\u0432\u0430\u043d\u043d\u044f \u0437\u0430\u043b\u0435\u0436\u043d\u043e\u0441\u0442\u0456 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0443 <strong>IProduct<\/strong> \u0443\u043f\u0435\u0440\u0448\u0435 \u0441\u0442\u0432\u043e\u0440\u044e\u0454\u0442\u044c\u0441\u044f \u043e\u0434\u0438\u043d\u043e\u0447\u043d\u0438\u0439 \u043e\u0431&#8217;\u0454\u043a\u0442, \u044f\u043a\u0438\u0439 \u0431\u0443\u0434\u0435 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u0442\u0438\u0441\u044f \u0434\u043b\u044f \u0432\u0441\u0456\u0445 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u0438\u0445 \u0437\u0430\u043b\u0435\u0436\u043d\u043e\u0441\u0442\u0435\u0439.<\/p>\n<p>\u0411\u0443\u0434\u044c-\u044f\u043a\u0438\u0439 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC, \u043d\u0435 \u0437\u043c\u043e\u0436\u0435 \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e \u0444\u0443\u043d\u043a\u0446\u0456\u043e\u043d\u0443\u0432\u0430\u0442\u0438 \u0431\u0435\u0437 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u0456\u0432 \u0456 \u0443\u044f\u0432\u043b\u0435\u043d\u044c. \u041f\u0435\u0440\u0435\u0439\u0434\u0435\u043c\u043e \u0434\u043e \u0457\u0445 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f.<\/p>\n<h2 id=\"controller\">\u0414\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u0430 \u0442\u0430 \u043f\u043e\u0434\u0430\u043d\u043d\u044f<\/h2>\n<p>\u041e\u0441\u043d\u043e\u0432\u043d\u0438\u0439 \u0430\u043a\u0446\u0435\u043d\u0442 \u0443 \u0440\u043e\u0437\u0433\u043b\u044f\u043d\u0443\u0442\u043e\u043c\u0443 \u043f\u0440\u0438\u043a\u043b\u0430\u0434\u0456 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0438 \u0437\u0440\u043e\u0431\u043b\u0435\u043d\u043e \u043d\u0430 \u0443\u043f\u0440\u0430\u0432\u043b\u0456\u043d\u043d\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0430\u043c\u0438 \u0442\u043e\u0432\u0430\u0440\u0456\u0432, \u0442\u043e\u043c\u0443 \u0449\u043e \u0446\u0435 \u0441\u0442\u0432\u043e\u0440\u044e\u0454 \u0447\u0443\u0434\u043e\u0432\u0443 \u043c\u043e\u0436\u043b\u0438\u0432\u0456\u0441\u0442\u044c \u0434\u043b\u044f \u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0430\u0446\u0456\u0457 \u0440\u0456\u0437\u043d\u0438\u0445 \u0437\u0430\u0441\u043e\u0431\u0456\u0432 \u0440\u043e\u0431\u043e\u0442\u0438 \u0437 \u0434\u0430\u043d\u0438\u043c\u0438. \u041d\u0430\u043c \u043f\u043e\u0442\u0440\u0456\u0431\u0435\u043d \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440, \u044f\u043a\u0438\u0439 \u043e\u0442\u0440\u0438\u043c\u0443\u0432\u0430\u0442\u0438\u043c\u0435 \u041d\u0422\u0422\u0420-\u0437\u0430\u043f\u0438\u0442\u0438 \u0456 \u0442\u0440\u0430\u043d\u0441\u043b\u044e\u0432\u0430\u0442\u0438\u043c\u0435 \u0457\u0445 \u0432 \u043e\u043f\u0435\u0440\u0430\u0446\u0456\u0457 \u043d\u0430\u0434 \u043e\u0431&#8217;\u0454\u043a\u0442\u0430\u043c\u0438 Product, \u0442\u043e\u0436 \u0441\u0442\u0432\u043e\u0440\u0456\u0442\u044c \u043f\u0430\u043f\u043a\u0443 <strong>Controllers<\/strong>, \u0434\u043e\u0434\u0430\u0439\u0442\u0435 \u0434\u043e \u043d\u0435\u0457 \u0444\u0430\u0439\u043b \u043d\u0430 \u0456\u043c&#8217;\u044f <strong>HomeController.cs<\/strong>, \u0437 \u0442\u0430\u043a\u0438\u043c \u0432\u043c\u0456\u0441\u0442\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">public class HomeController : Controller\r\n    {\r\n        private readonly IProduct _products;\r\n\r\n        public HomeController(IProduct products)\r\n        {\r\n            _products = products;\r\n        }\r\n        [HttpGet]\r\n        public IActionResult Index()\r\n        {\r\n            return View(_products.GetAllProducts());\r\n        }\r\n        [HttpPost]\r\n        public IActionResult AddProduct(Product product)\r\n        {\r\n            _products.AddProduct(product);\r\n            return RedirectToAction(nameof(Index));\r\n        }\r\n    }\r\n<\/pre>\n<p>\u041c\u0435\u0442\u043e\u0434 \u0434\u0456\u0457 <strong>Index()<\/strong> \u043f\u0435\u0440\u0435\u0434\u0430\u0454 \u043a\u043e\u043b\u0435\u043a\u0446\u0456\u044e \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 <strong>Product<\/strong> \u0437\u0456 \u0441\u0445\u043e\u0432\u0438\u0449\u0430 \u0441\u0432\u043e\u0454\u043c\u0443 \u043f\u043e\u0434\u0430\u043d\u043d\u044e, \u044f\u043a\u0435 \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0437\u0438\u0442\u044c \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456 \u0435\u043a\u0440\u0430\u043d\u043d\u0443 \u0442\u0430\u0431\u043b\u0438\u0446\u044e \u0437 \u0434\u0430\u043d\u0438\u043c\u0438. \u041c\u0435\u0442\u043e\u0434 <strong>AddProduct()<\/strong> \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u0454 \u043d\u043e\u0432\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438 Product, \u044f\u043a\u0456 \u0437\u0430\u0441\u043d\u043e\u0432\u0430\u043d\u0456 \u043d\u0430 \u0434\u0430\u043d\u0438\u0445, \u043e\u0442\u0440\u0438\u043c\u0430\u043d\u0438\u0445 \u0443 \u041d\u0422\u0422\u0420-\u0437\u0430\u043f\u0438\u0442\u0456 POST. \u0414\u0430\u043b\u0456 \u0441\u0442\u0432\u043e\u0440\u0456\u0442\u044c \u043f\u0430\u043f\u043a\u0443 <strong>Views\/Home<\/strong> \u0456 \u043f\u043e\u043c\u0456\u0441\u0442\u0456\u0442\u044c \u0443 \u043d\u0435\u0457 \u0444\u0430\u0439\u043b \u043d\u0430 \u0456\u043c&#8217;\u044f <strong>Index.cshtml<\/strong> \u0437 \u0442\u0430\u043a\u0438\u043c \u0432\u043c\u0456\u0441\u0442\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">@{\r\n    ViewData[\"Title\"] = \"\u0412\u0441\u0435 \u0442\u043e\u0432\u0430\u0440\u044b\";\r\n}\r\n@model IEnumerable&lt;Product&gt;\r\n\r\n&lt;h3 class=\"p-2 bg-bg-primary text-white text-center\"&gt;\u0422\u043e\u0432\u0430\u0440\u044b&lt;\/h3&gt;\r\n&lt;div class=\"container\"&gt;\r\n    &lt;div class=\"row\"&gt;\r\n        &lt;div class=\"col font-weight-bold\"&gt;\u041d\u0430\u0437\u0432\u0430\u043d\u0438\u0435&lt;\/div&gt;\r\n        &lt;div class=\"col font-weight-bold\"&gt;\u041a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u044f&lt;\/div&gt;\r\n        &lt;div class=\"col font-weight-bold\"&gt;\u0417\u0430\u043a\u0443\u043f\u043e\u0447\u043d\u0430\u044f \u0446\u0435\u043d\u0430&lt;\/div&gt;\r\n        &lt;div class=\"col font-weight-bold\"&gt;\u0420\u043e\u0437\u043d\u0438\u0447\u043d\u0430\u044f \u0446\u0435\u043d\u0430&lt;\/div&gt;\r\n        &lt;div class=\"col\"&gt;&lt;\/div&gt;\r\n    &lt;\/div&gt;\r\n    &lt;form asp-action=\"AddProduct\" asp-controller=\"Home\" method=\"post\"&gt;\r\n        &lt;div class=\"row\"&gt;\r\n            &lt;div class=\"col\"&gt;\r\n                &lt;input name=\"Name\" class=\"form-control\" required \/&gt;\r\n            &lt;\/div&gt;\r\n            &lt;div class=\"col\"&gt;\r\n                &lt;input name=\"Category\" class=\"form-control\" required \/&gt;\r\n            &lt;\/div&gt;\r\n            &lt;div class=\"col\"&gt;\r\n                &lt;input name=\"PurchasePrice\" class=\"form-control\" required \/&gt;\r\n            &lt;\/div&gt;\r\n            &lt;div class=\"col\"&gt;\r\n                &lt;input name=\"RetailPrice\" class=\"form-control\" required \/&gt;\r\n            &lt;\/div&gt;\r\n            &lt;div class=\"col\"&gt;\r\n                &lt;button type=\"submit\" class=\"btn btn-primary\"&gt;\u0414\u043e\u0431\u0430\u0432\u0438\u0442\u044c&lt;\/button&gt;\r\n            &lt;\/div&gt;\r\n        &lt;\/div&gt;\r\n    &lt;\/form&gt;\r\n    @if (Model.Count() == 0)\r\n    {\r\n        &lt;div class=\"row\"&gt;\r\n            &lt;div class=\"col text-center p-2\"&gt;\u041d\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0445&lt;\/div&gt;\r\n        &lt;\/div&gt;\r\n    }\r\n    else\r\n    {\r\n        @foreach (Product product in Model)\r\n        {\r\n            &lt;div class=\"row \u0440-2\"&gt;\r\n                &lt;div class=\"col\"&gt;@product.Name&lt;\/div&gt;\r\n                &lt;div class=\"col\"&gt;@product.Category&lt;\/div&gt;\r\n                &lt;div class=\"col text-right\"&gt;@product.PurchasePrice&lt;\/div&gt;\r\n                &lt;div class=\"col text-right\"&gt;@product.RetailPrice&lt;\/div&gt;\r\n                &lt;div class=\"col\"&gt;&lt;\/div&gt;\r\n            &lt;\/div&gt;\r\n        }\r\n    }\r\n&lt;\/div&gt;\r\n<\/pre>\n<p>\u0424\u0430\u0439\u043b <strong>Index.cshtml<\/strong> \u0454 \u043f\u043e\u0434\u0430\u043d\u043d\u044f\u043c, \u044f\u043a\u0435 \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0430\u0442\u0438\u043c\u0435 \u0434\u0430\u043d\u0456 <strong>Product<\/strong> \u0434\u043e\u0434\u0430\u0442\u043a\u0430 \u0456 \u0434\u043e\u0437\u0432\u043e\u043b\u044f\u0442\u0438\u043c\u0435 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456 \u0441\u0442\u0432\u043e\u0440\u044e\u0432\u0430\u0442\u0438 \u043d\u043e\u0432\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438.<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-189 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/2.png\" alt=\"\u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u0442\u043e\u0432\u0430\u0440\u0430 asp.net core mvc \" width=\"1015\" height=\"785\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/2.png 1015w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/2-300x232.png 300w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/2-768x594.png 768w\" sizes=\"auto, (max-width: 1015px) 100vw, 1015px\" \/><\/p>\n<p>\u0421\u0456\u0442\u043a\u043e\u0432\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0443\u0432\u0430\u043d\u043d\u044f \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u0434\u043b\u044f \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u043d\u044f \u0432\u0431\u0443\u0434\u043e\u0432\u0430\u043d\u043e\u0457 \u0444\u043e\u0440\u043c\u0438, \u0437\u0430 \u0434\u043e\u043f\u043e\u043c\u043e\u0433\u043e\u044e \u044f\u043a\u043e\u0457 \u0441\u0442\u0432\u043e\u0440\u044e\u044e\u0442\u044c\u0441\u044f \u043d\u043e\u0432\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438, \u043f\u043e\u0440\u044f\u0434 \u0456\u0437 \u0434\u0435\u0442\u0430\u043b\u044f\u043c\u0438 \u0432\u0441\u0456\u0445 \u0432\u0456\u0434\u043e\u043c\u0438\u0445 \u0434\u043e\u0434\u0430\u0442\u043a\u0443 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 Product \u0430\u0431\u043e \u0437\u0430\u043f\u043e\u0432\u043d\u044e\u0432\u0430\u0447\u0435\u043c, \u044f\u043a\u0449\u043e \u043e\u0431&#8217;\u0454\u043a\u0442\u0438 \u0432\u0456\u0434\u0441\u0443\u0442\u043d\u0456.<\/p>\n<p>\u0417\u0430\u043f\u0443\u0441\u0442\u0438\u043c\u043e \u0434\u043e\u0434\u0430\u0442\u043e\u043a \u0456 \u0432\u0438\u043a\u043e\u043d\u0430\u0454\u043c\u043e \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u0442\u043e\u0432\u0430\u0440\u0443:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-190\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3.png\" alt=\"add products asp.net core mvc\" width=\"1000\" height=\"782\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3.png 1000w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3-300x235.png 300w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3-768x601.png 768w\" sizes=\"auto, (max-width: 1000px) 100vw, 1000px\" \/><\/p>\n<p>\u0417\u0430\u0440\u0430\u0437 \u0434\u0430\u043d\u0456 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0438 \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u044e\u0442\u044c\u0441\u044f \u0432 \u043f\u0430\u043c&#8217;\u044f\u0442\u0456, \u0442\u043e\u0431\u0442\u043e \u0432 \u0440\u0430\u0437\u0456 \u0437\u0443\u043f\u0438\u043d\u043a\u0438 \u0430\u0431\u043e \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0443\u0441\u043a\u0443 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0438 \u0432\u0456\u0434\u043e\u043c\u043e\u0441\u0442\u0456 \u043f\u0440\u043e \u0432\u0441\u0456 \u0442\u043e\u0432\u0430\u0440\u0438 \u0432\u0442\u0440\u0430\u0447\u0430\u044e\u0442\u044c\u0441\u044f. \u0423 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u043e\u043c\u0443 \u0440\u043e\u0437\u0434\u0456\u043b\u0456 \u0432 \u043f\u0440\u043e\u0454\u043a\u0442 \u0431\u0443\u0434\u0435 \u0434\u043e\u0434\u0430\u043d\u043e \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0443 Entity Framework \u0421ore \u0434\u043b\u044f \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0435\u043d\u043d\u044f \u043f\u043e\u0441\u0442\u0456\u0439\u043d\u043e\u0433\u043e \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0443 \u0411\u0414.<\/p>\n<h2 id=\"efcore\" style=\"text-align: left;\">\u0417\u0431\u0435\u0440\u0456\u0433\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0437 Entity Framework Core<\/h2>\n<p>&nbsp;<\/p>\n<h3>\u041a\u043e\u043d\u0444\u0456\u0433\u0443\u0440\u0430\u0446\u0456\u044f \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044f<\/h3>\n<p>\u0423 \u0446\u044c\u043e\u043c\u0443 \u0440\u043e\u0437\u0434\u0456\u043b\u0456 \u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0443\u0454\u0442\u044c\u0441\u044f \u0437\u0431\u0435\u0440\u0435\u0436\u0435\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0434\u043e\u0434\u0430\u0442\u043a\u0430 <strong>GameStore<\/strong> \u0443 \u0411\u0414. \u0411\u0443\u0434\u0435 \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u043e, \u044f\u043a \u0434\u043e\u0434\u0430\u0442\u0438 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 Entity Framework Core \u0434\u043e \u043f\u0440\u043e\u0454\u043a\u0442\u0443, \u044f\u043a \u043f\u0456\u0434\u0433\u043e\u0442\u0443\u0432\u0430\u0442\u0438 \u043c\u043e\u0434\u0435\u043b\u044c \u0434\u0430\u043d\u0438\u0445, \u044f\u043a \u0441\u0442\u0432\u043e\u0440\u0438\u0442\u0438 \u0442\u0430 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u0442\u0438 \u0411\u0414 \u0456 \u044f\u043a \u0437\u043c\u0443\u0441\u0438\u0442\u0438 \u0434\u043e\u0434\u0430\u0442\u043e\u043a \u0440\u043e\u0431\u0438\u0442\u0438 \u0435\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u0456 SQL-\u0437\u0430\u043f\u0438\u0442\u0438.<\/p>\n<p>\u0414\u043b\u044f \u043f\u043e\u0447\u0430\u0442\u043a\u0443 \u0437\u0430\u0432\u0430\u043d\u0442\u0430\u0436\u0438\u043c\u043e \u0431\u0456\u0431\u043b\u0456\u043e\u0442\u0435\u043a\u0443 Entity Framework Core Sql Server:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-191 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/4.png\" alt=\"ef sql server\" width=\"1163\" height=\"659\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/4.png 1163w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/4-300x170.png 300w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/4-1024x580.png 1024w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/4-768x435.png 768w\" sizes=\"auto, (max-width: 1163px) 100vw, 1163px\" \/><\/p>\n<p>\u0410\u0431\u043e \u0447\u0435\u0440\u0435\u0437 Package Manager Console:<\/p>\n<pre class=\"lang:default decode:true \">Install-Package Microsoft.EntityFrameworkCore.SqlServer<\/pre>\n<p>\u041f\u0435\u0440\u0435\u0439\u0434\u0435\u043c\u043e \u0443 \u0444\u0430\u0439\u043b <strong>appsettings.json<\/strong> \u0456 \u043f\u0440\u043e\u043f\u0438\u0448\u0435\u043c\u043e \u043a\u043e\u043d\u0444\u0456\u0433\u0443\u0440\u0430\u0446\u0456\u044e \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044f \u0442\u0430 \u043b\u043e\u0433\u0443\u0432\u0430\u043d\u043d\u044f:<\/p>\n<pre class=\"lang:default decode:true\">{\r\n  \"ConnectionStrings\": {\r\n    \"DefaultConnection\": \"Server=(localdb)\\mssqllocaldb;Database=gamestore;Trusted_Connection=True;\"\r\n  },\r\n  \"Logging\": {\r\n    \"LogLevel\": {\r\n      \"Default\": \"Information\",\r\n      \"Microsoft.AspNetCore\": \"Information\"\r\n    }\r\n  },\r\n  \"AllowedHosts\": \"*\"\r\n}\r\n<\/pre>\n<p>\u0420\u044f\u0434\u043a\u0438 \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044f \u0432\u0438\u0437\u043d\u0430\u0447\u0430\u044e\u0442\u044c\u0441\u044f \u0443 \u0444\u0430\u0439\u043b\u0456 <strong>appsettings.json<\/strong>, \u0443 \u043a\u043e\u0434\u0456 \u0432\u0438\u0449\u0435 \u043d\u0430\u0432\u0435\u0434\u0435\u043d\u043e \u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u043d\u044f \u0440\u044f\u0434\u043a\u0430 \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044f \u0434\u043b\u044f \u0411\u0414 \u0434\u043e\u0434\u0430\u0442\u043a\u0430 GameStore. \u0423 \u043f\u0440\u043e\u0454\u043a\u0442\u0456 \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u0432\u0435\u0440\u0441\u0456\u044f <strong>LocalDB<\/strong> \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0443 SQL Server, \u044f\u043a\u0430 \u0441\u043f\u0440\u043e\u0454\u043a\u0442\u043e\u0432\u0430\u043d\u0430 \u0441\u043f\u0435\u0446\u0456\u0430\u043b\u044c\u043d\u043e \u0434\u043b\u044f \u0440\u043e\u0437\u0440\u043e\u0431\u043d\u0438\u043a\u0456\u0432 \u0456 \u043d\u0435 \u0432\u0438\u043c\u0430\u0433\u0430\u0454 \u043a\u043e\u043d\u0444\u0456\u0433\u0443\u0440\u0430\u0446\u0456\u0457 \u0430\u0431\u043e \u043e\u0431\u043b\u0456\u043a\u043e\u0432\u0438\u0445 \u0434\u0430\u043d\u0438\u0445.<\/p>\n<p>\u0412\u0438 \u0437\u043e\u0431\u043e\u0432&#8217;\u044f\u0437\u0430\u043d\u0456 \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0438\u0442\u0438, \u0449\u043e\u0431 \u0440\u044f\u0434\u043e\u043a \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044f \u0431\u0443\u0432 \u0454\u0434\u0438\u043d\u0438\u043c \u043d\u0435\u0440\u043e\u0437\u0440\u0438\u0432\u043d\u0438\u043c \u0440\u044f\u0434\u043a\u043e\u043c. \u0424\u043e\u0440\u043c\u0430\u0442 \u0440\u044f\u0434\u043a\u0430 \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044f \u0441\u043f\u0435\u0446\u0438\u0444\u0456\u0447\u043d\u0438\u0439 \u0434\u043b\u044f \u043a\u043e\u0436\u043d\u043e\u0433\u043e \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445.<\/p>\n<p>\u041d\u0430\u0432\u0456\u0442\u044c \u0443 \u043f\u0440\u043e\u0454\u043a\u0442\u0456, \u0449\u043e \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u0454 \u043b\u0438\u0448\u0435 \u043d\u0435\u0432\u0435\u043b\u0438\u043a\u0438\u0439 \u043e\u0431\u0441\u044f\u0433 \u0434\u0430\u043d\u0438\u0445, \u0432\u0430\u0436\u043b\u0438\u0432\u043e \u0440\u043e\u0437\u0443\u043c\u0456\u0442\u0438 \u0437\u0430\u043f\u0438\u0442\u0438 \u0456 \u043a\u043e\u043c\u0430\u043d\u0434\u0438 SQL, \u044f\u043a\u0456 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity Framework Core \u043f\u043e\u0441\u0438\u043b\u0430\u0454 \u0441\u0435\u0440\u0432\u0435\u0440\u0443 \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445.<\/p>\n<h2 id=\"migration\">\u041f\u0456\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0430 \u043c\u043e\u0434\u0435\u043b\u0456 \u0434\u0430\u043d\u0438\u0445<\/h2>\n<p>\u0414\u043b\u044f \u0437\u0431\u0435\u0440\u0435\u0436\u0435\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0443 \u0411\u0414 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0415ntity Framework Core \u043f\u043e\u0432\u0438\u043d\u043d\u0430 \u0432\u043c\u0456\u0442\u0438 \u0443\u043d\u0456\u043a\u0430\u043b\u044c\u043d\u0438\u043c \u0447\u0438\u043d\u043e\u043c \u0456\u0434\u0435\u043d\u0442\u0438\u0444\u0456\u043a\u0443\u0432\u0430\u0442\u0438 \u043a\u043e\u0436\u0435\u043d \u043e\u0431&#8217;\u0454\u043a\u0442, \u0449\u043e \u0432\u0438\u043c\u0430\u0433\u0430\u0454 \u0432\u0438\u0431\u043e\u0440\u0443 \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0456, \u044f\u043a\u0430 \u0431\u0443\u0434\u0435 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u0442\u0438\u0441\u044f \u044f\u043a \u043f\u0435\u0440\u0432\u0438\u043d\u043d\u0438\u0439 \u043a\u043b\u044e\u0447. \u0423 \u0431\u0456\u043b\u044c\u0448\u043e\u0441\u0442\u0456 \u043f\u0440\u043e\u0435\u043a\u0442\u0456\u0432 \u043d\u0430\u0439\u043f\u0440\u043e\u0441\u0442\u0456\u0448\u0438\u0439 \u0441\u043f\u043e\u0441\u0456\u0431 \u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u043d\u044f \u043f\u0435\u0440\u0432\u0438\u043d\u043d\u043e\u0433\u043e \u043a\u043b\u044e\u0447\u0430 \u043f\u0435\u0440\u0435\u0434\u0431\u0430\u0447\u0430\u0454 \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u0432 \u043a\u043b\u0430\u0441 \u043c\u043e\u0434\u0435\u043b\u0456 \u0434\u0430\u043d\u0438\u0445 \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0456 \u0442\u0438\u043f\u0443 int \u043d\u0430 \u0456\u043c&#8217;\u044f Id.<\/p>\n<p>\u0417\u043c\u0456\u043d\u0438\u043c\u043e \u043a\u043b\u0430\u0441 <strong>Product<\/strong>, \u0442\u0430\u043a\u0438\u043c \u0447\u0438\u043d\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">public class Product\r\n    {\r\n        public int Id { get; set; }\r\n\r\n        public string Name { get; set; }\r\n        public string Category { get; set; }\r\n        public decimal PurchasePrice { get; set; }\r\n        public decimal RetailPrice { get; set; }\r\n    }\r\n<\/pre>\n<p>\u0426\u0435\u0439 \u043f\u0456\u0434\u0445\u0456\u0434 \u043e\u0437\u043d\u0430\u0447\u0430\u0454, \u0449\u043e \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity Framework Core \u043a\u043e\u043d\u0444\u0456\u0433\u0443\u0440\u0443\u0432\u0430\u0442\u0438\u043c\u0435 \u0411\u0414 \u0442\u0430\u043a, \u0449\u043e\u0431 \u0441\u0435\u0440\u0432\u0435\u0440 \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445 \u0433\u0435\u043d\u0435\u0440\u0443\u0432\u0430\u0432 \u0437\u043d\u0430\u0447\u0435\u043d\u043d\u044f \u043f\u0435\u0440\u0432\u0438\u043d\u043d\u043e\u0433\u043e \u043a\u043b\u044e\u0447\u0430, \u0456 \u0432\u0430\u043c \u043d\u0435 \u0434\u043e\u0432\u0435\u043b\u043e\u0441\u044f \u0442\u0443\u0440\u0431\u0443\u0432\u0430\u0442\u0438\u0441\u044f \u043f\u0440\u043e \u0443\u043d\u0438\u043a\u043d\u0435\u043d\u043d\u044f \u0434\u0443\u0431\u043b\u0456\u043a\u0430\u0442\u0456\u0432. \u0417\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u043d\u044f int \u0433\u0430\u0440\u0430\u043d\u0442\u0443\u0454 \u043d\u0430\u044f\u0432\u043d\u0456\u0441\u0442\u044c \u0432\u0435\u043b\u0438\u043a\u043e\u0433\u043e \u0434\u0456\u0430\u043f\u0430\u0437\u043e\u043d\u0443 \u0437\u043d\u0430\u0447\u0435\u043d\u044c \u043f\u0435\u0440\u0432\u0438\u043d\u043d\u043e\u0433\u043e \u043a\u043b\u044e\u0447\u0430, \u0456 \u0431\u0456\u043b\u044c\u0448\u0456\u0441\u0442\u044c \u043f\u0440\u043e\u0454\u043a\u0442\u0456\u0432 \u0431\u0443\u0434\u0443\u0442\u044c \u0443 \u0437\u043c\u043e\u0437\u0456 \u043d\u0435\u043e\u0431\u043c\u0435\u0436\u0435\u043d\u043e \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u0442\u0438 \u0434\u0430\u043d\u0456, \u043d\u0435 \u0442\u0443\u0440\u0431\u0443\u044e\u0447\u0438\u0441\u044c \u043f\u0440\u043e \u0442\u0435, \u0449\u043e \u043a\u043b\u044e\u0447\u0456 \u0437\u0430\u043a\u0456\u043d\u0447\u0430\u0442\u044c\u0441\u044f.<\/p>\n<h2 id=\"context\">\u0421\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043a\u043b\u0430\u0441\u0443 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443 \u0434\u0430\u043d\u0438\u0445<\/h2>\n<p>\u0423 \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0435\u043d\u043d\u0456 \u0434\u043e\u0441\u0442\u0443\u043f\u0443 \u0434\u043e \u0434\u0430\u043d\u0438\u0445 \u0443 \u0411\u0414 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity Framework Core \u043f\u043e\u043a\u043b\u0430\u0434\u0430\u0454\u0442\u044c\u0441\u044f \u043d\u0430 \u043a\u043b\u0430\u0441 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443 \u0411\u0414. \u0429\u043e\u0431 \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0438\u0442\u0438 \u043f\u0440\u0438\u043a\u043b\u0430\u0434 \u0434\u043e\u0434\u0430\u0442\u043a\u0430 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u043e\u043c, \u0434\u043e\u0434\u0430\u0439\u0442\u0435 \u0432 \u043f\u0430\u043f\u043a\u0443 Models \u0444\u0430\u0439\u043b \u043a\u043b\u0430\u0441\u0443 \u043d\u0430 \u0456\u043c&#8217;\u044f <strong>ApplicationContext.cs<\/strong> \u0456\u0437 \u0442\u0430\u043a\u0438\u043c \u043a\u043e\u0434\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">public class ApplicationContext:DbContext\r\n    {\r\n        public ApplicationContext(DbContextOptions&lt;ApplicationContext&gt; context):base(context)\r\n        {\r\n\r\n        }\r\n        public DbSet&lt;Product&gt; Products { get; set; }\r\n    }\r\n<\/pre>\n<p>\u041a\u043e\u043b\u0438 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity Framework Core \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u0434\u043b\u044f \u0437\u0431\u0435\u0440\u0435\u0436\u0435\u043d\u043d\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0457 \u043c\u043e\u0434\u0435\u043b\u0456 \u0434\u0430\u043d\u0438\u0445 \u043d\u0430 \u043a\u0448\u0442\u0430\u043b\u0442 \u0442\u0456\u0454\u0457, \u0449\u043e \u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u0430 \u0432 \u0434\u043e\u0434\u0430\u0442\u043a\u0443 GameStore. \u041a\u043b\u0430\u0441 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443 \u0411\u0414 \u0432\u0456\u0434\u043f\u043e\u0432\u0456\u0434\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u0438\u0439 &#8211; \u0445\u043e\u0447\u0430 \u0441\u0438\u0442\u0443\u0430\u0446\u0456\u044f \u0437\u043c\u0456\u043d\u0438\u0442\u044c\u0441\u044f \u0437\u0456 \u0437\u0440\u043e\u0441\u0442\u0430\u043d\u043d\u044f\u043c \u0441\u043a\u043b\u0430\u0434\u043d\u043e\u0441\u0442\u0456 \u043c\u043e\u0434\u0435\u043b\u0456 \u0434\u0430\u043d\u0438\u0445 \u0443 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u0438\u0445 \u0440\u043e\u0437\u0434\u0456\u043b\u0430\u0445.<\/p>\n<p>\u041f\u043e\u0442\u043e\u0447\u043d\u0430 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043f\u0440\u043e\u0454\u043a\u0442\u0443 \u043c\u0430\u0454 \u0442\u0430\u043a\u0438\u0439 \u0432\u0438\u0433\u043b\u044f\u0434:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-192 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/5.png\" alt=\"\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 asp.net core\" width=\"277\" height=\"477\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/5.png 277w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/5-174x300.png 174w\" sizes=\"auto, (max-width: 277px) 100vw, 277px\" \/><\/p>\n<h2 id=\"dataupdate\">\u0417\u043c\u0456\u043d\u0430 \u0440\u0435\u0430\u043b\u0456\u0437\u0430\u0446\u0456\u0457 \u0441\u0445\u043e\u0432\u0438\u0449\u0430<\/h2>\n<p>\u0422\u0435\u043f\u0435\u0440 \u043d\u0430\u0441\u0442\u0430\u0432 \u0447\u0430\u0441 \u043e\u043d\u043e\u0432\u0438\u0442\u0438 \u043a\u043b\u0430\u0441 \u0440\u0435\u0430\u043b\u0456\u0437\u0430\u0446\u0456\u0457 \u0441\u0445\u043e\u0432\u0438\u0449\u0430, \u0449\u043e\u0431 \u0437\u0432\u0435\u0440\u0442\u0430\u0442\u0438\u0441\u044f \u0434\u043e \u0434\u0430\u043d\u0438\u0445 \u0447\u0435\u0440\u0435\u0437 \u043a\u043b\u0430\u0441 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443, \u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u0440\u0430\u043d\u0456\u0448\u0435. \u0417\u043c\u0456\u043d\u0438\u043c\u043e \u043a\u043e\u0434 \u043a\u043b\u0430\u0441\u0443 <strong>ProductRepository.cs<\/strong>, \u0442\u0430\u043a\u0438\u043c \u0447\u0438\u043d\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">public class ProductRepository : IProduct\r\n    {\r\n        private ApplicationContext _context;\r\n\r\n        public ProductRepository(ApplicationContext context)\r\n        {\r\n            _context = context;\r\n        }\r\n\r\n        public void AddProduct(Product product)\r\n        {\r\n            _context.Products.Add(product);\r\n            _context.SaveChanges();\r\n        }\r\n\r\n        public IEnumerable&lt;Product&gt; GetAllProducts()\r\n        {\r\n            return _context.Products;\r\n        }\r\n    }\r\n<\/pre>\n<p>\u0423 \u0434\u043e\u0434\u0430\u0442\u043a\u0443 ASP.NET Core MVC, \u0434\u043e\u0441\u0442\u0443\u043f \u0434\u043e \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443 \u0434\u0430\u043d\u0438\u0445 \u043a\u0435\u0440\u0443\u0454\u0442\u044c\u0441\u044f \u0437 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f\u043c \u0432\u043f\u0440\u043e\u0432\u0430\u0434\u0436\u0435\u043d\u043d\u044f \u0437\u0430\u043b\u0435\u0436\u043d\u043e\u0441\u0442\u0435\u0439, \u0456 \u0442\u043e\u043c\u0443 \u0434\u043e \u043a\u043b\u0430\u0441\u0443 <strong>ProductRepository<\/strong> \u0431\u0443\u043b\u043e \u0434\u043e\u0434\u0430\u043d\u043e \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440, \u044f\u043a\u0438\u0439 \u043f\u0440\u0438\u0439\u043c\u0430\u0454 \u043e\u0431&#8217;\u0454\u043a\u0442 <strong>ApplicationContext<\/strong>, \u044f\u043a\u0438\u0439 \u0431\u0443\u0434\u0435 \u043d\u0430\u0434\u0430\u043d\u043e \u0437\u0430\u0441\u043e\u0431\u043e\u043c \u0432\u043f\u0440\u043e\u0432\u0430\u0434\u0436\u0435\u043d\u043d\u044f \u0437\u0430\u043b\u0435\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u043f\u0456\u0434 \u0447\u0430\u0441 \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f.<\/p>\n<p>\u0412\u043b\u0430\u0441\u0442\u0438\u0432\u0456\u0441\u0442\u044c <strong>Products<\/strong>, \u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u0443 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u043c \u0441\u0445\u043e\u0432\u0438\u0449\u0430, \u043c\u043e\u0436\u043d\u0430 \u0440\u0435\u0430\u043b\u0456\u0437\u0443\u0432\u0430\u0442\u0438 \u0448\u043b\u044f\u0445\u043e\u043c \u043f\u043e\u0432\u0435\u0440\u043d\u0435\u043d\u043d\u044f \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0456 <strong>DbSet&lt;Product&gt;<\/strong>, \u044f\u043a\u0430 \u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u0430 \u0432 \u043a\u043b\u0430\u0441\u0456 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443. \u0410\u043d\u0430\u043b\u043e\u0433\u0456\u0447\u043d\u043e \u043c\u0435\u0442\u043e\u0434 <strong>AddProduct()<\/strong> \u0440\u0435\u0430\u043b\u0456\u0437\u0443\u0432\u0430\u0442\u0438 \u043b\u0435\u0433\u043a\u043e, \u0442\u043e\u043c\u0443 \u0449\u043e \u043e\u0431&#8217;\u0454\u043a\u0442 DbSet&lt;Product&gt; \u0432\u0438\u0437\u043d\u0430\u0447\u0430\u0454 \u043c\u0435\u0442\u043e\u0434 <strong>Add()<\/strong>, \u044f\u043a\u0438\u0439 \u043f\u0440\u0438\u0439\u043c\u0430\u0454 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438 Product \u0456 \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u0454 \u0457\u0445 \u043d\u0430 \u043f\u043e\u0441\u0442\u0456\u0439\u043d\u0456\u0439 \u043e\u0441\u043d\u043e\u0432\u0456.<\/p>\n<h2 id=\"appsettings\">\u041a\u043e\u043d\u0444\u0456\u0433\u0443\u0440\u0443\u0432\u0430\u043d\u043d\u044f \u043f\u043e\u0441\u0442\u0430\u0447\u0430\u043b\u044c\u043d\u0438\u043a\u0430 \u0431\u0430\u0437\u0438 \u0434\u0430\u043d\u0438\u0445 \u0456 \u043a\u043b\u0430\u0441\u0443 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443<\/h2>\n<p>\u0414\u043e\u0434\u0430\u0439\u0442\u0435 \u0432 \u043a\u043b\u0430\u0441<strong> Program.cs<\/strong> \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0438 \u043a\u043e\u043d\u0444\u0456\u0433\u0443\u0440\u0430\u0446\u0456\u0457, \u0449\u043e\u0431 \u043f\u043e\u0432\u0456\u0434\u043e\u043c\u0438\u0442\u0438 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 Entity Framework Core \u043f\u0440\u043e \u0442\u0435, \u044f\u043a\u0438\u043c \u0447\u0438\u043d\u043e\u043c \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u0442\u0438 \u0440\u044f\u0434\u043e\u043a \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044f, \u044f\u043a\u0438\u0439 \u043c\u0430\u0454 \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0432\u0430\u0442\u0438 \u043f\u043e\u0441\u0442\u0430\u0447\u0430\u043b\u044c\u043d\u0438\u043a \u0411\u0414, \u0456 \u044f\u043a \u043a\u0435\u0440\u0443\u0432\u0430\u0442\u0438 \u043a\u043b\u0430\u0441\u043e\u043c \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443:<\/p>\n<pre class=\"lang:default decode:true \">builder.Services.AddTransient&lt;IProduct, ProductRepository&gt;();\r\n\r\nIConfigurationRoot _confString = new ConfigurationBuilder().\r\n    SetBasePath(AppDomain.CurrentDomain.BaseDirectory).AddJsonFile(\"appsettings.json\").Build();\r\n\r\nbuilder.Services.AddDbContext&lt;ApplicationContext&gt;(options =&gt;\r\n               options.UseSqlServer(_confString.GetConnectionString(\"DefaultConnection\")));\r\n<\/pre>\n<p>\u0412\u0435\u0441\u044c \u043a\u043e\u0434 \u0444\u0430\u0439\u043b\u0430 <strong>Program.cs<\/strong>:<\/p>\n<pre class=\"lang:default decode:true \">using GameStore.Interfaces;\r\nusing GameStore.Models;\r\nusing GameStore.Repository;\r\nusing Microsoft.EntityFrameworkCore;\r\n\r\nvar builder = WebApplication.CreateBuilder(args);\r\n\r\n\/\/ Add services to the container.\r\nbuilder.Services.AddControllersWithViews();\r\n\r\n\/\/\u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\r\n\/\/builder.Services.AddSingleton&lt;IProduct, ProductRepository&gt;();\r\n\r\nbuilder.Services.AddTransient&lt;IProduct, ProductRepository&gt;();\r\n\r\nIConfigurationRoot _confString = new ConfigurationBuilder().\r\n    SetBasePath(AppDomain.CurrentDomain.BaseDirectory).AddJsonFile(\"appsettings.json\").Build();\r\n\r\nbuilder.Services.AddDbContext&lt;ApplicationContext&gt;(options =&gt;\r\n               options.UseSqlServer(_confString.GetConnectionString(\"DefaultConnection\")));\r\n\r\nvar app = builder.Build();\r\n\r\n\/\/ Configure the HTTP request pipeline.\r\nif (!app.Environment.IsDevelopment())\r\n{\r\n    app.UseExceptionHandler(\"\/Home\/Error\");\r\n    \/\/ The default HSTS value is 30 days. You may want to change this for production scenarios, see https:\/\/aka.ms\/aspnetcore-hsts.\r\n    app.UseHsts();\r\n}\r\n\r\napp.UseHttpsRedirection();\r\napp.UseStaticFiles();\r\n\r\napp.UseRouting();\r\n\r\napp.UseAuthorization();\r\n\r\napp.MapControllerRoute(\r\n    name: \"default\",\r\n    pattern: \"{controller=Home}\/{action=Index}\/{id?}\");\r\n\r\napp.Run();\r\n<\/pre>\n<p>\u041c\u0435\u0442\u043e\u0434 <strong>AddDbContext&lt;T&gt;()<\/strong>, \u0449\u043e \u0440\u043e\u0437\u0448\u0438\u0440\u044e\u0454, \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u0434\u043b\u044f \u043d\u0430\u043b\u0430\u0448\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u043a\u043b\u0430\u0441\u0443 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443, \u0432\u043a\u0430\u0437\u0443\u0454 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0456 Entity Framework Core, \u044f\u043a\u0438\u0439 \u043f\u043e\u0441\u0442\u0430\u0447\u0430\u043b\u044c\u043d\u0438\u043a \u0411\u0414 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u0442\u0438 (\u0443 \u0446\u044c\u043e\u043c\u0443 \u0440\u0430\u0437\u0456 \u0437\u0430 \u0434\u043e\u043f\u043e\u043c\u043e\u0433\u043e\u044e \u043c\u0435\u0442\u043e\u0434\u0443 UseSqlServer(), \u0430\u043b\u0435 \u0434\u043b\u044f \u043a\u043e\u0436\u043d\u043e\u0433\u043e \u043f\u043e\u0441\u0442\u0430\u0447\u0430\u043b\u044c\u043d\u0438\u043a\u0430 \u0411\u0414 \u043f\u0435\u0440\u0435\u0434\u0431\u0430\u0447\u0435\u043d\u043e \u0441\u0432\u0456\u0439 \u043c\u0435\u0442\u043e\u0434), \u0456 \u043d\u0430\u0434\u0430\u0454 \u0440\u044f\u0434\u043e\u043a \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044f.<\/p>\n<p>\u0417\u0432\u0435\u0440\u043d\u0456\u0442\u044c \u0443\u0432\u0430\u0433\u0443, \u0449\u043e \u0437\u043c\u0456\u043d\u0435\u043d\u043e \u0442\u0430\u043a\u043e\u0436 \u0456 \u043c\u0435\u0442\u043e\u0434, \u044f\u043a\u0438\u0439 \u043a\u043e\u043d\u0444\u0456\u0433\u0443\u0440\u0443\u0454 \u0432\u043f\u0440\u043e\u0432\u0430\u0434\u0436\u0435\u043d\u043d\u044f \u0437\u0430\u043b\u0435\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u0434\u043b\u044f \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0443 <strong>IRepository<\/strong>:<\/p>\n<pre class=\"lang:default decode:true \">builder.Services.AddTransient&lt;IProduct, ProductRepository&gt;();<\/pre>\n<p>\u0423 \u0440\u043e\u0437\u0434\u0456\u043b\u0456 &#8220;\u041c\u043e\u0434\u0435\u043b\u044c \u0456 \u0420\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0456\u0439&#8221; \u0437\u0430 \u0434\u043e\u043f\u043e\u043c\u043e\u0433\u043e\u044e \u043c\u0435\u0442\u043e\u0434\u0443<strong> AddSingleton()<\/strong> \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0443\u0432\u0430\u043b\u043e\u0441\u044f \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f \u043e\u0434\u0438\u043d\u043e\u0447\u043d\u043e\u0433\u043e \u043e\u0431&#8217;\u0454\u043a\u0442\u0430 <strong>ProductRepository<\/strong> \u0434\u043b\u044f \u0440\u043e\u0437\u043f\u0456\u0437\u043d\u0430\u0432\u0430\u043d\u043d\u044f \u0432\u0441\u0456\u0445 \u0437\u0430\u043b\u0435\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0443 <strong>IProduct<\/strong>, \u0449\u043e \u0431\u0443\u043b\u043e \u0432\u0430\u0436\u043b\u0438\u0432\u043e, \u043e\u0441\u043a\u0456\u043b\u044c\u043a\u0438 \u0434\u0430\u043d\u0456 \u0434\u043e\u0434\u0430\u0442\u043a\u0430 \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u043b\u0438\u0441\u044f \u0432 \u0435\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0456 List, \u0456 \u0431\u0430\u0436\u0430\u043d\u043e \u0431\u0443\u043b\u043e \u0437\u0430\u0432\u0436\u0434\u0438 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u0442\u0438 \u0442\u043e\u0439 \u0441\u0430\u043c\u0438\u0439 \u043e\u0431&#8217;\u0454\u043a\u0442. \u0422\u0435\u043f\u0435\u0440, \u043a\u043e\u043b\u0438 \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity Framework Core, \u0437\u0430\u0434\u0456\u044f\u043d\u043e \u043c\u0435\u0442\u043e\u0434 AddTransient(), \u044f\u043a\u0438\u0439 \u0433\u0430\u0440\u0430\u043d\u0442\u0443\u0454 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043d\u043e\u0432\u043e\u0433\u043e \u043e\u0431&#8217;\u0454\u043a\u0442\u0430 ProductRepository \u043f\u0440\u0438 \u043a\u043e\u0436\u043d\u043e\u043c\u0443 \u0440\u043e\u0437\u043f\u0456\u0437\u043d\u0430\u0432\u0430\u043d\u043d\u0456 \u0437\u0430\u043b\u0435\u0436\u043d\u043e\u0441\u0442\u0456 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0443 IProduct. \u0422\u0430\u043a\u0438\u0439 \u043f\u0456\u0434\u0445\u0456\u0434 \u0432\u0430\u0436\u043b\u0438\u0432\u0438\u0439, \u0442\u043e\u043c\u0443 \u0449\u043e \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity Framework Core \u0440\u043e\u0437\u0440\u0430\u0445\u043e\u0432\u0443\u0454 \u043d\u0430 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043d\u043e\u0432\u043e\u0433\u043e \u043e\u0431&#8217;\u0454\u043a\u0442\u0430 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443 \u0434\u043b\u044f \u043a\u043e\u0436\u043d\u043e\u0433\u043e \u041d\u0422\u0422\u0420-\u0437\u0430\u043f\u0438\u0442\u0443 \u0432 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043a\u0443 ASP.NET Core \u041cV\u0421.<\/p>\n<h2 id=\"databasecreate\">\u0421\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0431\u0430\u0437\u0438 \u0434\u0430\u043d\u0438\u0445<\/h2>\n<p>\u0423 \u043f\u043e\u043f\u0435\u0440\u0435\u0434\u043d\u044c\u043e\u043c\u0443 \u0440\u043e\u0437\u0434\u0456\u043b\u0456 \u0434\u043b\u044f \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0438 Entity Framework Core \u0431\u0443\u043b\u043e \u0432\u043a\u0430\u0437\u0430\u043d\u043e \u0432\u0438\u0434 \u0434\u0430\u043d\u0438\u0445, \u0449\u043e \u043f\u0456\u0434\u043b\u044f\u0433\u0430\u044e\u0442\u044c \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u043d\u043d\u044e, \u0456 \u0441\u043f\u043e\u0441\u0456\u0431 \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044f \u0434\u043e \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445. \u0414\u0430\u043b\u0456 \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u043e \u0441\u0442\u0432\u043e\u0440\u0438\u0442\u0438 \u0411\u0414.<\/p>\n<p>\u0406\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity Framework Core \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0454 \u0431\u0430\u0437\u0430\u043c\u0438 \u0434\u0430\u043d\u0438\u0445 \u0447\u0435\u0440\u0435\u0437 \u0437\u0430\u0441\u0456\u0431, \u0437\u0432\u0430\u043d\u0438\u0439 \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u044f\u043c\u0438, \u044f\u043a\u0456 \u044f\u0432\u043b\u044f\u044e\u0442\u044c \u0441\u043e\u0431\u043e\u044e \u043d\u0430\u0431\u043e\u0440\u0438 \u0437\u043c\u0456\u043d, \u0449\u043e \u0441\u0442\u0432\u043e\u0440\u044e\u044e\u0442\u044c \u0430\u0431\u043e \u043c\u043e\u0434\u0438\u0444\u0456\u043a\u0443\u044e\u0442\u044c \u0411\u0414 \u0437 \u043c\u0435\u0442\u043e\u044e \u0457\u0457 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0456\u0437\u0430\u0446\u0456\u0457 \u0437 \u043c\u043e\u0434\u0435\u043b\u043b\u044e \u0434\u0430\u043d\u0438\u0445.<\/p>\n<p>\u0414\u043b\u044f \u0440\u043e\u0431\u043e\u0442\u0438 \u0437 \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u0454\u044e, \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u043e \u0437\u0430\u0432\u0430\u043d\u0442\u0430\u0436\u0438\u0442\u0438 \u0442\u0430\u043a\u0443 \u0431\u0456\u0431\u043b\u0456\u043e\u0442\u0435\u043a\u0443:<\/p>\n<pre class=\"lang:default decode:true \">Microsoft.EntityFrameworkCore.Tools<\/pre>\n<p>\u0410\u0431\u043e \u0447\u0435\u0440\u0435\u0437 Package Manager Console:<\/p>\n<pre class=\"lang:default decode:true \">Install-Package Microsoft.EntityFrameworkCore.Tools<\/pre>\n<p>\u0414\u043b\u044f \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u0457 \u0443 \u0432\u0456\u043a\u043d\u0456 <strong>Package Manager Console<\/strong> \u0432\u0432\u0435\u0434\u0456\u0442\u044c \u0442\u0430\u043a\u0443 \u043a\u043e\u043c\u0430\u043d\u0434\u0443:<\/p>\n<pre class=\"lang:default decode:true \">Add-Migration Init<\/pre>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-193 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/6.png\" alt=\"asp.net core mvc migration\" width=\"521\" height=\"205\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/6.png 521w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/6-300x118.png 300w\" sizes=\"auto, (max-width: 521px) 100vw, 521px\" \/><\/p>\n<p><strong>Init<\/strong> \u0430\u0431\u043e <strong>Initial<\/strong> &#8211; \u0437\u0430\u0433\u0430\u043b\u044c\u043d\u043e\u043f\u0440\u0438\u0439\u043d\u044f\u0442\u0435 \u0456\u043c&#8217;\u044f, \u044f\u043a\u0435 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u0434\u043b\u044f \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u0457, \u0449\u043e \u0437\u0434\u0456\u0439\u0441\u043d\u044e\u0454 \u043f\u043e\u0447\u0430\u0442\u043a\u043e\u0432\u0443 \u043f\u0456\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0443 \u0411\u0414.<\/p>\n<p>\u041f\u0456\u0434 \u0447\u0430\u0441 \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u043a\u043e\u043c\u0430\u043d\u0434\u0438 \u0437 \u043b\u0456\u0441\u0442\u0438\u043d\u0433\u0443 5.8 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity Framework \u0421are \u0456\u043d\u0441\u043f\u0435\u043a\u0442\u0443\u0454 \u043f\u0440\u043e\u0454\u043a\u0442, \u0437\u043d\u0430\u0445\u043e\u0434\u0438\u0442\u044c \u043a\u043b\u0430\u0441 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443 \u0456 \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454 \u0439\u043e\u0433\u043e \u0434\u043b\u044f \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u0457. \u0423 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0456 \u0443 \u0432\u0456\u043a\u043d\u0456 Solution Explorer \u0437&#8217;\u044f\u0432\u0438\u0442\u044c\u0441\u044f \u043f\u0430\u043f\u043a\u0430 Migrations, \u0449\u043e \u043c\u0456\u0441\u0442\u0438\u0442\u044c \u0444\u0430\u0439\u043b\u0438 \u043a\u043b\u0430\u0441\u0456\u0432, \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0438 \u044f\u043a\u0438\u0445 \u043f\u0456\u0434\u0433\u043e\u0442\u0443\u044e\u0442\u044c \u0411\u0414.<\/p>\n<p>\u041f\u0440\u043e\u0441\u0442\u043e \u0441\u0442\u0432\u043e\u0440\u0438\u0442\u0438 \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u044e, \u044f\u043a\u0430 \u044f\u0432\u043b\u044f\u0454 \u0441\u043e\u0431\u043e\u044e \u0432\u0441\u044c\u043e\u0433\u043e \u043b\u0438\u0448\u0435 \u043d\u0430\u0431\u0456\u0440 \u0456\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0456\u0439, \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043d\u044c\u043e. \u0406\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0456\u0457 \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u0457 \u043c\u0430\u044e\u0442\u044c \u0431\u0443\u0442\u0438 \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u0456, \u0449\u043e\u0431 \u0441\u0442\u0432\u043e\u0440\u0438\u0442\u0438 \u0411\u0414, \u044f\u043a\u0430 \u0437\u043c\u043e\u0436\u0435 \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u0442\u0438 \u0434\u0430\u043d\u0456 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0438. \u0414\u043b\u044f \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u0456\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0456\u0439 \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u0457, \u0443 \u0432\u0456\u043a\u043d\u0456 <strong>Package Manager Console<\/strong> \u0432\u0438\u043a\u043e\u043d\u0430\u0439\u0442\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u0443:<\/p>\n<pre class=\"lang:default decode:true \">Update-Database<\/pre>\n<p>\u0406\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity F\u0433amework Core \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c\u0441\u044f \u0434\u043e \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445, \u0437\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u043e\u0433\u043e \u0432 \u0440\u044f\u0434\u043a\u0443 \u043f\u0456\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044f, \u0456 \u0432\u0438\u043a\u043e\u043d\u0430\u0454 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0438 \u0432 \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u0457. \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u043c \u0431\u0443\u0434\u0435 \u0411\u0414, \u044f\u043a\u0443 \u043c\u043e\u0436\u043d\u0430 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u0442\u0438 \u0434\u043b\u044f \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u043d\u043d\u044f \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 Product.<\/p>\n<h2 id=\"apprun\">\u0412\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0438<\/h2>\n<p>\u041e\u0441\u043d\u043e\u0432\u043d\u0430 \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0430 \u0434\u043b\u044f \u043f\u043e\u0441\u0442\u0456\u0439\u043d\u043e\u0433\u043e \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u043d\u043d\u044f \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 Product \u043d\u0430 \u043c\u0456\u0441\u0446\u0456, \u0456 \u0434\u043e\u0434\u0430\u0442\u043e\u043a \u0433\u043e\u0442\u043e\u0432\u0438\u0439 \u0434\u043e \u0442\u0435\u0441\u0442\u0443\u0432\u0430\u043d\u043d\u044f, \u043d\u0435\u0437\u0432\u0430\u0436\u0430\u044e\u0447\u0438 \u043d\u0430 \u0442\u0435, \u0449\u043e \u0440\u043e\u0431\u043e\u0442\u0430 \u043d\u0430\u0434 \u043d\u0438\u043c \u0449\u0435 \u043d\u0435 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0430. \u0417\u0430\u043f\u0443\u0441\u0442\u0456\u0442\u044c \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043e\u043a, \u0441\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 \u0434\u043e\u0434\u0430\u0442\u0438 \u0434\u0430\u043d\u0456, \u043f\u0440\u043e\u0442\u0435\u0441\u0442\u0443\u0432\u0430\u0442\u0438 \u0439\u043e\u0433\u043e \u0440\u043e\u0431\u043e\u0442\u0443.<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-194 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/7.png\" alt=\"\u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 asp.net core mvc\" width=\"1000\" height=\"690\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/7.png 1000w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/7-300x207.png 300w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/7-768x530.png 768w\" sizes=\"auto, (max-width: 1000px) 100vw, 1000px\" \/><\/p>\n<p>\u0406\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0430 \u0437\u0430\u043b\u0438\u0448\u0438\u0432\u0441\u044f \u043d\u0435\u0437\u043c\u0456\u043d\u043d\u0438\u043c, \u0430\u043b\u0435 \u0432\u043d\u0443\u0442\u0440\u0456\u0448\u043d\u044c\u043e \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity Framework \u0421ore \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u0454 \u0434\u0430\u043d\u0456 \u0432 \u0411\u0414. \u0417\u0443\u043f\u0438\u043d\u0456\u0442\u044c \u0456 \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0443\u0441\u0442\u0456\u0442\u044c \u0434\u043e\u0434\u0430\u0442\u043e\u043a, \u0432\u0438 \u043f\u043e\u0431\u0430\u0447\u0438\u0442\u0435, \u0449\u043e \u0432\u0432\u0435\u0434\u0435\u043d\u0456 \u0440\u0430\u043d\u0456\u0448\u0435 \u0434\u0430\u043d\u0456, \u044f\u043a \u0456 \u0440\u0430\u043d\u0456\u0448\u0435, \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u0456.<\/p>\n<h2 id=\"catcherros\">\u0423\u043d\u0438\u043a\u043d\u0435\u043d\u043d\u044f \u043f\u0430\u0441\u0442\u043e\u043a, \u043f\u043e\u0432&#8217;\u044f\u0437\u0430\u043d\u0438\u0445 \u0456\u0437 \u0437\u0430\u043f\u0438\u0442\u0430\u043c\u0438<\/h2>\n<p>\u0414\u043e\u0434\u0430\u0442\u043e\u043a \u0444\u0443\u043d\u043a\u0446\u0456\u043e\u043d\u0443\u0454, \u0434\u0430\u043d\u0456 \u0437\u0431\u0435\u0440\u0456\u0433\u0430\u044e\u0442\u044c\u0441\u044f \u0432 \u0411\u0414, \u0430\u043b\u0435 \u0432\u0441\u0435 \u0449\u0435 \u0454 \u0440\u043e\u0431\u043e\u0442\u0430, \u044f\u043a\u0443 \u043f\u043e\u0442\u0440\u0456\u0431\u043d\u043e \u0437\u0440\u043e\u0431\u0438\u0442\u0438, \u0449\u043e\u0431 \u0432\u0438\u0442\u044f\u0433\u0442\u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0443\u043c \u0437 Entity Framework Core. \u0417\u043e\u043a\u0440\u0435\u043c\u0430, \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u043e \u0443\u043d\u0438\u043a\u043d\u0443\u0442\u0438 \u0434\u0432\u043e\u0445 \u043f\u043e\u0448\u0438\u0440\u0435\u043d\u0438\u0445 \u043f\u0430\u0441\u0442\u043e\u043a. \u0422\u0430\u043a\u0456 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0438 \u043c\u043e\u0436\u043d\u0430 \u0456\u0434\u0435\u043d\u0442\u0438\u0444\u0456\u043a\u0443\u0432\u0430\u0442\u0438, \u0434\u043e\u0441\u043b\u0456\u0434\u0436\u0443\u044e\u0447\u0438 SQL-\u0437\u0430\u043f\u0438\u0442\u0438, \u044f\u043a\u0456 Entity Framework Core \u043f\u043e\u0441\u0438\u043b\u0430\u0454 \u0411\u0414. \u0417 \u0446\u0456\u0454\u044e \u043c\u0435\u0442\u043e\u044e \u0434\u043e\u0434\u0430\u0439\u0442\u0435 \u0432 \u043c\u0435\u0442\u043e\u0434 \u0434\u0456\u0457 Index() \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u0430 Home \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440, \u0449\u043e \u043f\u043e\u043b\u0435\u0433\u0448\u0443\u0454 \u043f\u0435\u0440\u0435\u0433\u043b\u044f\u0434 \u0437\u0430\u043f\u0438\u0442\u0456\u0432 \u0434\u043e \u0411\u0414, \u044f\u043a\u0456 \u0456\u043d\u0456\u0446\u0456\u044e\u044e\u0442\u044c\u0441\u044f \u041d\u0422\u0422\u0420-\u0437\u0430\u043f\u0438\u0442\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">[HttpGet]\r\n        public IActionResult Index()\r\n        {\r\n            System.Console.Clear();\r\n            return View(_products.GetAllProducts());\r\n        }\r\n<\/pre>\n<p>\u041c\u0435\u0442\u043e\u0434 <strong>Console.Clear()<\/strong> \u043e\u0447\u0438\u0449\u0430\u0454 \u043a\u043e\u043d\u0441\u043e\u043b\u044c, \u043a\u043e\u043b\u0438 \u0432\u0438\u043a\u043b\u0438\u043a\u0430\u0454\u0442\u044c\u0441\u044f \u0434\u0456\u044f Index, \u0442\u043e\u0436 \u0437\u0430\u043f\u0438\u0442\u0438 \u0434\u043e \u0411\u0414 \u0456\u0437 \u043f\u043e\u043f\u0435\u0440\u0435\u0434\u043d\u0456\u0445 \u041d\u0422\u0422\u0420-\u0437\u0430\u043f\u0438\u0442\u0456\u0432 \u043d\u0435 \u0431\u0443\u0434\u0435 \u0432\u0438\u0434\u043d\u043e. \u0417\u0430\u043f\u0443\u0441\u0442\u0456\u0442\u044c \u0434\u043e\u0434\u0430\u0442\u043e\u043a \u0456 \u043f\u0435\u0440\u0435\u0433\u043b\u044f\u043d\u044c\u0442\u0435 \u0436\u0443\u0440\u043d\u0430\u043b\u044c\u043d\u0456 \u043f\u043e\u0432\u0456\u0434\u043e\u043c\u043b\u0435\u043d\u043d\u044f, \u044f\u043a\u0456 \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0437\u0438\u043b\u0438\u0441\u044f.<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-195 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/8.png\" alt=\"asp.net core console\" width=\"979\" height=\"515\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/8.png 979w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/8-300x158.png 300w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/8-768x404.png 768w\" sizes=\"auto, (max-width: 979px) 100vw, 979px\" \/><\/p>\n<p>\u0406\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity F\u0433amework Core \u043f\u043e\u043b\u0435\u0433\u0448\u0443\u0454 \u0437\u0430\u043f\u0438\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u0411\u0414 \u0456\u0437 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f\u043c LINQ, \u0445\u043e\u0447\u0430 \u0439 \u043d\u0435 \u0437\u0430\u0432\u0436\u0434\u0438 \u043f\u0440\u0430\u0446\u044e\u0454 \u0442\u0430\u043a, \u044f\u043a \u043c\u043e\u0436\u043d\u0430 \u0431\u0443\u043b\u043e \u0431 \u043e\u0447\u0456\u043a\u0443\u0432\u0430\u0442\u0438. \u0423 \u043f\u043e\u0434\u0430\u043d\u043d\u0456 Index, \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u043d\u043e\u043c\u0443 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u043e\u043c Home, \u0434\u043b\u044f \u0437&#8217;\u044f\u0441\u0443\u0432\u0430\u043d\u043d\u044f \u043a\u0456\u043b\u044c\u043a\u043e\u0441\u0442\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 Product, \u044f\u043a\u0456 \u0431\u0443\u043b\u0438 \u0437\u0431\u0435\u0440\u0435\u0436\u0435\u043d\u0456 \u0432 \u0411\u0414, \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u043c\u0435\u0442\u043e\u0434<strong> Count()<\/strong> \u0437 LINQ:<\/p>\n<pre class=\"lang:default decode:true\">@if (Model.Count() == 0)\r\n    {\r\n        &lt;div class=\"row\"&gt;\r\n            &lt;div class=\"col text-center p-2\"&gt;\u041d\u0435\u0442 \u0434\u0430\u043d\u043d\u044b\u0445&lt;\/div&gt;\r\n        &lt;\/div&gt;\r\n    }\r\n<\/pre>\n<p>\u0429\u043e\u0431 \u0432\u0438\u0437\u043d\u0430\u0447\u0438\u0442\u0438, \u0441\u043a\u0456\u043b\u044c\u043a\u0438 Product \u0454 \u0432 \u0411\u0414, \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 Entity Framework \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0454 SQL \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440 <strong>SELECT<\/strong> \u0434\u043b\u044f \u043e\u0442\u0440\u0438\u043c\u0430\u043d\u043d\u044f \u0432\u0441\u0456\u0445 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u0438\u0445 \u0434\u0430\u043d\u0438\u0445 Product, \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454 \u043e\u0442\u0440\u0438\u043c\u0430\u043d\u0456 \u0434\u0430\u043d\u0456 \u0434\u043b\u044f \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043f\u043e\u0441\u043b\u0456\u0434\u043e\u0432\u043d\u043e\u0441\u0442\u0456 \u0442\u0430 \u043f\u043e\u0442\u0456\u043c \u043f\u0456\u0434\u0440\u0430\u0445\u043e\u0432\u0443\u0454 \u0457\u0445.<\/p>\n<p>\u041a\u043e\u043b\u0438 \u0432 \u0411\u0414 \u0454 \u0442\u0456\u043b\u044c\u043a\u0438 \u0442\u0440\u0438 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438, \u0441\u043a\u043b\u0430\u0434\u043d\u043e\u0449\u0456\u0432 \u043d\u0435 \u0432\u0438\u043d\u0438\u043a\u0430\u0454, \u0430\u043b\u0435 \u0437\u0456 \u0437\u0440\u043e\u0441\u0442\u0430\u043d\u043d\u044f\u043c \u043a\u0456\u043b\u044c\u043a\u043e\u0441\u0442\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 \u043e\u0431\u0441\u044f\u0433 \u0440\u043e\u0431\u043e\u0442\u0438, \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u043e\u0457 \u0434\u043b\u044f \u0457\u0445 \u043f\u0456\u0434\u0440\u0430\u0445\u0443\u043d\u043a\u0443 \u0432 \u0442\u0430\u043a\u0456\u0439 \u043c\u0430\u043d\u0435\u0440\u0456, \u0441\u0442\u0430\u0454 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043e\u044e. \u0415\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u0456\u0448\u0438\u0439 \u043f\u0456\u0434\u0445\u0456\u0434 \u043f\u0435\u0440\u0435\u0434\u0431\u0430\u0447\u0430\u0454 \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u043f\u0456\u0434\u0440\u0430\u0445\u0443\u043d\u043a\u0443 \u0441\u0435\u0440\u0432\u0435\u0440\u043e\u043c \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445, \u0449\u043e \u0437\u0432\u0456\u043b\u044c\u043d\u044f\u0454 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 \u0415ntity Framework Core \u0432\u0456\u0434 \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u043e\u0441\u0442\u0456 \u043f\u0435\u0440\u0435\u043c\u0456\u0449\u0435\u043d\u043d\u044f \u0432\u0441\u0456\u0445 \u0434\u0430\u043d\u0438\u0445 \u0456 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432.<\/p>\n<p>\u0420\u0435\u0430\u043b\u0456\u0437\u0443\u0432\u0430\u0442\u0438 \u0442\u0430\u043a\u0438\u0439 \u043f\u0456\u0434\u0445\u0456\u0434 \u043c\u043e\u0436\u043d\u0430, \u0432\u043d\u0456\u0441\u0448\u0438 \u0432 \u0442\u0438\u043f \u043c\u043e\u0434\u0435\u043b\u0456 \u043f\u043e\u0434\u0430\u043d\u043d\u044f \u043e\u0434\u043d\u0443 \u043f\u0440\u043e\u0441\u0442\u0443 \u0437\u043c\u0456\u043d\u0443, \u0437\u043c\u0456\u043d\u0438\u0442\u0438 \u0442\u0438\u043f \u043c\u043e\u0434\u0435\u043b\u0456 \u0437 <strong>IEnumerable<\/strong> \u043d\u0430 <strong>IQueryable<\/strong>:<\/p>\n<pre class=\"lang:default decode:true \">@model IQueryable&lt;Product&gt;<\/pre>\n<p>\u041f\u0435\u0440\u0435\u0437\u0430\u0432\u0430\u043d\u0442\u0430\u0436\u0438\u0432\u0448\u0438 \u0432\u0456\u043a\u043d\u043e \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430, \u0432\u0438 \u043f\u043e\u0431\u0430\u0447\u0438\u0442\u0435, \u0449\u043e \u043f\u0435\u0440\u0448\u0456 \u0434\u0432\u0430 \u0437\u0430\u043f\u0438\u0442\u0438, \u044f\u043a\u0456 \u0415ntity Framework Core \u043f\u043e\u0441\u0438\u043b\u0430\u0454 \u0441\u0435\u0440\u0432\u0435\u0440\u0443 \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445, \u0437\u043c\u0456\u043d\u0438\u043b\u0438\u0441\u044f:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-196 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/9.png\" alt=\"asp.net core IQueryable\" width=\"975\" height=\"511\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/9.png 975w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/9-300x157.png 300w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/9-768x403.png 768w\" sizes=\"auto, (max-width: 975px) 100vw, 975px\" \/><\/p>\n<p>\u0417\u0430\u043f\u0438\u0442 <strong>SELECT COUNT<\/strong> \u043f\u0440\u043e\u043f\u043e\u043d\u0443\u0454 \u0441\u0435\u0440\u0432\u0435\u0440\u0443 \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445 \u043f\u0456\u0434\u0440\u0430\u0445\u0443\u0432\u0430\u0442\u0438 \u043a\u0456\u043b\u044c\u043a\u0456\u0441\u0442\u044c \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 Product. \u043d\u0435 \u0432\u0438\u0442\u044f\u0433\u0443\u044e\u0447\u0438 \u0434\u0430\u043d\u0456 \u0456 \u043d\u0435 \u0441\u0442\u0432\u043e\u0440\u044e\u044e\u0447\u0438 \u0431\u0443\u0434\u044c-\u044f\u043a\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438 \u0432 \u0434\u043e\u0434\u0430\u0442\u043a\u0443.<\/p>\n<p>\u041e\u0442\u0440\u0438\u043c\u0430\u043d\u043d\u044f \u0440\u0456\u0437\u043d\u0438\u0445 \u0437\u0430\u043f\u0438\u0442\u0456\u0432 \u0434\u043b\u044f \u0440\u0456\u0437\u043d\u0438\u0445 \u0442\u0438\u043f\u0456\u0432 \u043c\u043e\u0434\u0435\u043b\u0435\u0439 \u0443\u044f\u0432\u043b\u0435\u043d\u044c \u043c\u043e\u0436\u0435 \u0432\u0438\u0433\u043b\u044f\u0434\u0430\u0442\u0438 \u044f\u043a \u043d\u0435\u043b\u043e\u0433\u0456\u0447\u043d\u0430 \u043f\u043e\u0432\u0435\u0434\u0456\u043d\u043a\u0430, \u0456 \u0440\u043e\u0437\u0443\u043c\u0456\u043d\u043d\u044f \u043f\u0440\u0438\u0447\u0438\u043d, \u0447\u043e\u043c\u0443 \u0442\u0430\u043a \u0432\u0456\u0434\u0431\u0443\u0432\u0430\u0454\u0442\u044c\u0441\u044f, \u0436\u0438\u0442\u0442\u0454\u0432\u043e \u0432\u0430\u0436\u043b\u0438\u0432\u0435 \u0432 \u0433\u0430\u0440\u0430\u043d\u0442\u0443\u0432\u0430\u043d\u043d\u0456 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0456 \u0415ntity Framework Core \u043c\u043e\u0436\u043b\u0438\u0432\u043e\u0441\u0442\u0435\u0439 \u0435\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u0437\u0430\u043f\u0438\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445.<\/p>\n<p>\u0406\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0415ntity Framework Core \u0432\u043a\u043b\u044e\u0447\u0430\u0454 \u0434\u0443\u0431\u043b\u044e\u044e\u0447\u0438\u0439 \u043d\u0430\u0431\u0456\u0440 \u0440\u043e\u0437\u0448\u0438\u0440\u044e\u0432\u0430\u043b\u044c\u043d\u0438\u0445 \u043c\u0435\u0442\u043e\u0434\u0456\u0432 LINQ, \u044f\u043a\u0456 \u043e\u043f\u0435\u0440\u0443\u044e\u0442\u044c \u043d\u0430 \u043e\u0431&#8217;\u0454\u043a\u0442\u0430\u0445, \u0449\u043e \u0440\u0435\u0430\u043b\u0456\u0437\u0443\u044e\u0442\u044c \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 IQueryable&lt;T&gt;. \u0426\u0435\u0439 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0454 \u0437\u0430\u043f\u0438\u0442 \u0434\u043e \u0411\u0414, \u0456 \u0442\u0430\u043a\u0435 \u0434\u0443\u0431\u043b\u044e\u0432\u0430\u043d\u043d\u044f \u043e\u0437\u043d\u0430\u0447\u0430\u0454, \u0449\u043e \u043e\u043f\u0435\u0440\u0430\u0446\u0456\u0457 \u043d\u0430 \u043a\u0448\u0442\u0430\u043b\u0442 Count() \u043c\u043e\u0436\u0443\u0442\u044c \u0442\u0430\u043a \u0441\u0430\u043c\u043e \u043b\u0435\u0433\u043a\u043e \u0432\u0438\u043a\u043e\u043d\u0443\u0432\u0430\u0442\u0438\u0441\u044f \u043d\u0430\u0434 \u0434\u0430\u043d\u0438\u043c\u0438 \u0432 \u0411\u0414, \u044f\u043a \u043d\u0430\u0434 \u043e\u0431&#8217;\u0454\u043a\u0442\u0430\u043c\u0438 \u0432 \u043f\u0430\u043c&#8217;\u044f\u0442\u0456.<\/p>\n<h2 id=\"final\">\u041f\u0456\u0434\u0441\u0443\u043c\u043e\u043a<\/h2>\n<p>\u0412 \u0443\u0440\u043e\u0446\u0456 \u0431\u0443\u043b\u043e \u0434\u043e\u0434\u0430\u043d\u043e \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0443 \u0434\u043b\u044f \u0437\u0431\u0435\u0440\u0435\u0436\u0435\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0443 \u0411\u0414 \u0456 \u0432\u0438\u0434\u0430\u0447\u0456 \u0437\u0430\u043f\u0438\u0442\u0456\u0432 \u0434\u043e \u043d\u0435\u0457. \u041d\u0430\u0432\u043e\u0434\u0438\u043b\u0438\u0441\u044f \u043f\u043e\u044f\u0441\u043d\u0435\u043d\u043d\u044f \u043f\u0440\u043e\u0446\u0435\u0441\u0443 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0443 \u0434\u043e \u043f\u043e\u0441\u0442\u0456\u0439\u043d\u043e\u0433\u043e \u0441\u0445\u043e\u0432\u0438\u0449\u0430 \u0434\u0430\u043d\u0438\u0445 \u0456 \u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0430\u0446\u0456\u0457, \u044f\u043a\u0438\u043c \u0447\u0438\u043d\u043e\u043c \u0437\u0430\u043f\u0438\u0442\u0438, \u0456\u043d\u0456\u0446\u0456\u0439\u043e\u0432\u0430\u043d\u0456 \u0434\u043e\u0434\u0430\u0442\u043a\u043e\u043c, \u043f\u043e\u0432\u0438\u043d\u043d\u0456 \u0430\u0434\u0430\u043f\u0442\u0443\u0432\u0430\u0442\u0438\u0441\u044f \u0434\u043e \u0435\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e\u0457 \u0440\u043e\u0431\u043e\u0442\u0438 \u0437 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043e\u044e Entity Framework Core.<\/p>\n<p>\u0423 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u043e\u043c\u0443 \u0443\u0440\u043e\u0446\u0456 \u0431\u0443\u0434\u0435 \u0434\u043e\u0434\u0430\u043d\u043e \u0437\u0430\u0441\u043e\u0431\u0438 \u0434\u043b\u044f \u043c\u043e\u0434\u0438\u0444\u0456\u043a\u0430\u0446\u0456\u0457 \u0442\u0430 \u0432\u0438\u0434\u0430\u043b\u0435\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0443 \u0411\u0414.<\/p>\n<p>\u041d\u0430 \u0446\u044c\u043e\u043c\u0443 \u0441\u0442\u0430\u0442\u0442\u044f &#8220;\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF&#8221;, \u043f\u0456\u0434\u0456\u0439\u0448\u043b\u0430 \u0434\u043e \u043a\u0456\u043d\u0446\u044f, \u0441\u043f\u043e\u0434\u0456\u0432\u0430\u044e\u0441\u044f \u0432\u0430\u043c \u0431\u0443\u043b\u043e \u0446\u0456\u043a\u0430\u0432\u043e. \u0412\u0438 \u043c\u043e\u0436\u0435\u0442\u0435 \u0437\u0430\u0432\u0430\u043d\u0442\u0430\u0436\u0438\u0442\u0438 \u0432\u0438\u0445\u0456\u0434\u043d\u0438\u0439 \u043a\u043e\u0434 \u0443 \u043c\u043e\u0454\u043c\u0443 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0456\u0457 \u2014 <a href=\"https:\/\/github.com\/murzilaka2\/GameStore-Part-1\">Github<\/a>.<\/p>\n<p>\u041f\u043e\u0434\u0456\u043b\u0456\u0442\u044c\u0441\u044f \u0432\u0430\u0448\u0438\u043c \u0434\u043e\u0441\u0432\u0456\u0434\u043e\u043c \u0443 \u043a\u043e\u043c\u0435\u043d\u0442\u0430\u0440\u044f\u0445, \u044f\u043a\u0438\u0439 \u0431\u0443\u0432 \u0432\u0430\u0448 \u043f\u0435\u0440\u0448\u0438\u0439 \u043f\u0440\u043e\u0454\u043a\u0442, \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF \u0430\u0431\u043e \u0449\u043e\u0441\u044c \u0456\u043d\u0448\u0435?<\/p>\n<p>\u0422\u0430\u043a \u0441\u0430\u043c\u043e \u0432\u0430\u043c \u043c\u043e\u0436\u0435 \u0431\u0443\u0442\u0438 \u0446\u0456\u043a\u0430\u0432\u0430 \u043f\u043e\u043f\u0435\u0440\u0435\u0434\u043d\u044f \u0441\u0442\u0430\u0442\u0442\u044f:<\/p>\n<blockquote class=\"wp-embedded-content\" data-secret=\"JMempbbLqD\"><p><a href=\"https:\/\/dijix.com.ua\/blog\/uk\/otpravka-email-v-asp-net-core\/\">\u041d\u0430\u0434\u0441\u0438\u043b\u0430\u043d\u043d\u044f Email \u0432 Asp.Net Core<\/a><\/p><\/blockquote>\n<p><iframe loading=\"lazy\" class=\"wp-embedded-content\" sandbox=\"allow-scripts\" security=\"restricted\" style=\"position: absolute; clip: rect(1px, 1px, 1px, 1px);\" title=\"&#8220;\u041d\u0430\u0434\u0441\u0438\u043b\u0430\u043d\u043d\u044f Email \u0432 Asp.Net Core&#8221; &#8212; Dijix -  \u0411\u043b\u043e\u0433\" src=\"https:\/\/dijix.com.ua\/blog\/uk\/otpravka-email-v-asp-net-core\/embed\/#?secret=DjTka9qJwu#?secret=JMempbbLqD\" data-secret=\"JMempbbLqD\" width=\"500\" height=\"282\" frameborder=\"0\" marginwidth=\"0\" marginheight=\"0\" scrolling=\"no\"><\/iframe><\/p>\n<hr \/>\n<h4><strong>\u0412\u0438 \u0445\u043e\u0447\u0435\u0442\u0435 \u043d\u0430\u0432\u0447\u0438\u0442\u0438\u0441\u044f \u043f\u0438\u0441\u0430\u0442\u0438 \u043a\u043e\u0434 \u043c\u043e\u0432\u043e\u044e \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0443\u0432\u0430\u043d\u043d\u044f C#?<\/strong><\/h4>\n<p>\u0421\u0442\u0432\u043e\u0440\u044e\u0432\u0430\u0442\u0438 \u0440\u0456\u0437\u043d\u0456 \u0456\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0456\u0439\u043d\u0456 \u0441\u0438\u0441\u0442\u0435\u043c\u0438, \u0449\u043e \u0441\u043a\u043b\u0430\u0434\u0430\u044e\u0442\u044c\u0441\u044f \u0437 \u0441\u0430\u0439\u0442\u0456\u0432, \u043c\u043e\u0431\u0456\u043b\u044c\u043d\u0438\u0445 \u043a\u043b\u0456\u0454\u043d\u0442\u0456\u0432, \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u043d\u0438\u0445 \u0434\u043e\u0434\u0430\u0442\u043a\u0456\u0432, \u0442\u0435\u043b\u0435\u0433\u0440\u0430\u043c-\u0431\u043e\u0442\u0456\u0432 \u0442\u043e\u0449\u043e.<\/p>\n<p><a href=\"https:\/\/dijix.com.ua\/\"><img loading=\"lazy\" decoding=\"async\" class=\"alignleft wp-image-94 size-full\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/08\/logog-brand.png\" alt=\"\" width=\"355\" height=\"77\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/08\/logog-brand.png 355w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/08\/logog-brand-300x65.png 300w\" sizes=\"auto, (max-width: 355px) 100vw, 355px\" \/><\/a><\/p>\n<p>\u041f\u0435\u0440\u0435\u0445\u043e\u0434\u044c\u0442\u0435 \u0434\u043e \u043d\u0430\u0441 \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0443 Dijix \u0456 \u043e\u0437\u043d\u0430\u0439\u043e\u043c\u0442\u0435\u0441\u044f \u0437 \u0443\u043c\u043e\u0432\u0430\u043c\u0438 \u043d\u0430\u0432\u0447\u0430\u043d\u043d\u044f, \u043c\u0438 \u0441\u043f\u0435\u0446\u0456\u0430\u043b\u0456\u0437\u0443\u0454\u043c\u043e\u0441\u044f \u0442\u0456\u043b\u044c\u043a\u0438 \u043d\u0430 \u0456\u043d\u0434\u0438\u0432\u0456\u0434\u0443\u0430\u043b\u044c\u043d\u0438\u0445 \u0437\u0430\u043d\u044f\u0442\u0442\u044f\u0445, \u044f\u043a \u0434\u043b\u044f \u043f\u043e\u0447\u0430\u0442\u043a\u0456\u0432\u0446\u0456\u0432, \u0442\u0430\u043a \u0456 \u0434\u043b\u044f \u043f\u0440\u043e\u0441\u0443\u043d\u0443\u0442\u0438\u0445 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0456\u0441\u0442\u0456\u0432. \u0412\u0438 \u043c\u043e\u0436\u0435\u0442\u0435 \u0432\u0437\u044f\u0442\u0438 \u044f\u043a \u043e\u0434\u043d\u0435 \u0437\u0430\u043d\u044f\u0442\u0442\u044f \u0434\u043b\u044f \u043e\u043f\u0440\u0430\u0446\u044e\u0432\u0430\u043d\u043d\u044f \u043f\u0438\u0442\u0430\u043d\u043d\u044f, \u0449\u043e \u0432\u0430\u0441 \u0446\u0456\u043a\u0430\u0432\u0438\u0442\u044c, \u0442\u0430\u043a \u0456 \u043a\u0456\u043b\u044c\u043a\u0430, \u0434\u043b\u044f \u0431\u0456\u043b\u044c\u0448 \u0449\u0456\u043b\u044c\u043d\u043e\u0457 \u0440\u043e\u0431\u043e\u0442\u0438. \u0417\u0430\u0432\u0434\u044f\u043a\u0438 \u043e\u0441\u043e\u0431\u0438\u0441\u0442\u043e\u043c\u0443 \u043a\u0430\u0431\u0456\u043d\u0435\u0442\u0443, \u043a\u043e\u0436\u0435\u043d \u0441\u0442\u0443\u0434\u0435\u043d\u0442 \u043f\u0456\u0434\u0432\u0438\u0449\u0438\u0442\u044c \u044f\u043a\u0456\u0441\u0442\u044c \u0441\u0432\u043e\u0433\u043e \u043d\u0430\u0432\u0447\u0430\u043d\u043d\u044f, \u0443 \u0432\u0430\u0448\u043e\u043c\u0443 \u0440\u043e\u0437\u043f\u043e\u0440\u044f\u0434\u0436\u0435\u043d\u043d\u0456:<\/p>\n<ul>\n<li>\u0414\u043e\u0441\u0442\u0443\u043f \u0434\u043e \u043f\u0440\u043e\u0439\u0434\u0435\u043d\u043e\u0433\u043e \u043c\u0430\u0442\u0435\u0440\u0456\u0430\u043b\u0443<\/li>\n<li>\u0422\u0435\u043c\u0430\u0442\u0438\u0447\u043d\u0456 \u0441\u0442\u0430\u0442\u0442\u0456<\/li>\n<li>\u0411\u0456\u0431\u043b\u0456\u043e\u0442\u0435\u043a\u0430 \u043a\u043d\u0438\u0433<\/li>\n<li>\u041e\u043d\u043b\u0430\u0439\u043d \u0442\u0435\u0441\u0442\u0443\u0432\u0430\u043d\u043d\u044f<\/li>\n<li>\u0421\u043f\u0456\u043b\u043a\u0443\u0432\u0430\u043d\u043d\u044f \u0432 \u0437\u0430\u043a\u0440\u0438\u0442\u0438\u0445 \u0433\u0440\u0443\u043f\u0430\u0445<\/li>\n<\/ul>\n<blockquote>\n<p style=\"text-align: right;\"><a href=\"https:\/\/dijix.com.ua\/uk\/\">https:\/\/dijix.com.ua<\/a><\/p>\n<p style=\"text-align: right;\"><a href=\"https:\/\/ms.dijix.com.ua\/\">\u0416\u0438\u0432\u0438 \u0443 \u0441\u0432\u043e\u0454\u043c\u0443 \u0441\u0432\u0456\u0442\u0456, \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0443\u0439 \u0443 \u043d\u0430\u0448\u043e\u043c\u0443<\/a>.<\/p>\n<\/blockquote>\n<hr \/>\n<p>&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0423 \u0446\u044c\u043e\u043c\u0443 \u0443\u0440\u043e\u0446\u0456 \u0440\u043e\u0437\u0433\u043b\u044f\u043d\u0435\u043c\u043e \u043f\u0440\u043e\u0446\u0435\u0441 \u043f\u043e\u0431\u0443\u0434\u043e\u0432\u0438 \u0440\u0435\u0430\u043b\u0456\u0441\u0442\u0438\u0447\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0454\u043a\u0442\u0443, \u044f\u043a\u0438\u0439 \u043f\u0440\u043e\u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0443\u0454 \u0441\u043f\u0456\u043b\u044c\u043d\u0435 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f ASP.NET Core MVC \u0456 Entity Framework Core. \u041f\u0440\u043e\u0454\u043a\u0442 \u0431\u0443\u0434\u0435 \u043f\u0440\u043e\u0441\u0442\u0438\u043c, \u0430\u043b\u0435 \u0431\u043b\u0438\u0437\u044c\u043a\u0438\u043c \u0434\u043e&#8230;<\/p>\n<div class=\"more-link-wrapper\"><a class=\"more-link\" href=\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/\">Continue reading<span class=\"screen-reader-text\">\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1<\/span><\/a><\/div>\n","protected":false},"author":1,"featured_media":201,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_locale":"uk","_original_post":"https:\/\/dijix.com.ua\/blog\/?p=187","footnotes":""},"categories":[8],"tags":[],"class_list":["post-364","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-asp-net-core","uk","entry"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.13 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\r\n<title>\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1 - Dijix - \u0411\u043b\u043e\u0433<\/title>\r\n<meta name=\"description\" content=\"\u0423 \u0446\u044c\u043e\u043c\u0443 \u0443\u0440\u043e\u0446\u0456 \u0440\u043e\u0437\u0433\u043b\u044f\u043d\u0435\u043c\u043e \u043f\u0440\u043e\u0446\u0435\u0441 \u043f\u043e\u0431\u0443\u0434\u043e\u0432\u0438 \u043f\u0440\u043e\u0454\u043a\u0442\u0443, \u044f\u043a\u0438\u0439 \u043f\u0440\u043e\u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0443\u0454 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f ASP.NET Core MVC \u0456 Entity Framework Core.\" \/>\r\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\r\n<link rel=\"canonical\" href=\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/\" \/>\r\n<meta property=\"og:locale\" content=\"uk_UA\" \/>\r\n<meta property=\"og:type\" content=\"article\" \/>\r\n<meta property=\"og:title\" content=\"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1 - Dijix - \u0411\u043b\u043e\u0433\" \/>\r\n<meta property=\"og:url\" content=\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/\" \/>\r\n<meta property=\"og:site_name\" content=\"Dijix - \u0411\u043b\u043e\u0433\" \/>\r\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/Dijixs\" \/>\r\n<meta property=\"article:published_time\" content=\"2023-02-03T10:57:27+00:00\" \/>\r\n<meta property=\"article:modified_time\" content=\"2023-02-03T10:58:55+00:00\" \/>\r\n<meta property=\"og:image\" content=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3-1.png\" \/>\r\n\t<meta property=\"og:image:width\" content=\"572\" \/>\r\n\t<meta property=\"og:image:height\" content=\"384\" \/>\r\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\r\n<meta name=\"author\" content=\"\u041b\u0435\u043e\u043d\u0438\u0434 \u041a\u0430\u0440\u0443\u043d\u0430\" \/>\r\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\r\n<meta name=\"twitter:label1\" content=\"\u041d\u0430\u043f\u0438\u0441\u0430\u043d\u043e\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u041b\u0435\u043e\u043d\u0438\u0434 \u041a\u0430\u0440\u0443\u043d\u0430\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u041f\u0440\u0438\u0431\u043b. \u0447\u0430\u0441 \u0447\u0438\u0442\u0430\u043d\u043d\u044f\" \/>\n\t<meta name=\"twitter:data2\" content=\"16 \u0445\u0432\u0438\u043b\u0438\u043d\" \/>\r\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/\"},\"author\":{\"name\":\"\u041b\u0435\u043e\u043d\u0438\u0434 \u041a\u0430\u0440\u0443\u043d\u0430\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/#\/schema\/person\/4ce2240cdf3db189e17ca0ff422a0c3d\"},\"headline\":\"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1\",\"datePublished\":\"2023-02-03T10:57:27+00:00\",\"dateModified\":\"2023-02-03T10:58:55+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/\"},\"wordCount\":2186,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/#organization\"},\"articleSection\":[\"Asp.Net Core\"],\"inLanguage\":\"uk\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/\",\"url\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/\",\"name\":\"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1 - Dijix - \u0411\u043b\u043e\u0433\",\"isPartOf\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/#website\"},\"datePublished\":\"2023-02-03T10:57:27+00:00\",\"dateModified\":\"2023-02-03T10:58:55+00:00\",\"description\":\"\u0423 \u0446\u044c\u043e\u043c\u0443 \u0443\u0440\u043e\u0446\u0456 \u0440\u043e\u0437\u0433\u043b\u044f\u043d\u0435\u043c\u043e \u043f\u0440\u043e\u0446\u0435\u0441 \u043f\u043e\u0431\u0443\u0434\u043e\u0432\u0438 \u043f\u0440\u043e\u0454\u043a\u0442\u0443, \u044f\u043a\u0438\u0439 \u043f\u0440\u043e\u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0443\u0454 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f ASP.NET Core MVC \u0456 Entity Framework Core.\",\"breadcrumb\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/#breadcrumb\"},\"inLanguage\":\"uk\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u0413\u043b\u0430\u0432\u043d\u0430\u044f \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430\",\"item\":\"https:\/\/dijix.com.ua\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/#website\",\"url\":\"https:\/\/dijix.com.ua\/blog\/\",\"name\":\"Dijix - \u0411\u043b\u043e\u0433\",\"description\":\"\ud83d\udc9c\",\"publisher\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/dijix.com.ua\/blog\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"uk\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/#organization\",\"name\":\"Dijix - \u0411\u043b\u043e\u0433\",\"url\":\"https:\/\/dijix.com.ua\/blog\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"uk\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/08\/\u0421\u043d\u0438\u043c\u043e\u043a.png\",\"contentUrl\":\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/08\/\u0421\u043d\u0438\u043c\u043e\u043a.png\",\"width\":159,\"height\":92,\"caption\":\"Dijix - \u0411\u043b\u043e\u0433\"},\"image\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/#\/schema\/logo\/image\/\"},\"sameAs\":[\"https:\/\/www.facebook.com\/Dijixs\"]},{\"@type\":\"Person\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/#\/schema\/person\/4ce2240cdf3db189e17ca0ff422a0c3d\",\"name\":\"\u041b\u0435\u043e\u043d\u0438\u0434 \u041a\u0430\u0440\u0443\u043d\u0430\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"uk\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/e3e8fa72f5adf168d30934fb574a97a5e812e7d6e2795075f0e7ea19311e3ba9?s=96&d=monsterid&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/e3e8fa72f5adf168d30934fb574a97a5e812e7d6e2795075f0e7ea19311e3ba9?s=96&d=monsterid&r=g\",\"caption\":\"\u041b\u0435\u043e\u043d\u0438\u0434 \u041a\u0430\u0440\u0443\u043d\u0430\"},\"sameAs\":[\"https:\/\/dijix.com.ua\/blog\"],\"url\":\"https:\/\/dijix.com.ua\/blog\/author\/admin\/\"}]}<\/script>\r\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1 - Dijix - \u0411\u043b\u043e\u0433","description":"\u0423 \u0446\u044c\u043e\u043c\u0443 \u0443\u0440\u043e\u0446\u0456 \u0440\u043e\u0437\u0433\u043b\u044f\u043d\u0435\u043c\u043e \u043f\u0440\u043e\u0446\u0435\u0441 \u043f\u043e\u0431\u0443\u0434\u043e\u0432\u0438 \u043f\u0440\u043e\u0454\u043a\u0442\u0443, \u044f\u043a\u0438\u0439 \u043f\u0440\u043e\u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0443\u0454 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f ASP.NET Core MVC \u0456 Entity Framework Core.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/","og_locale":"uk_UA","og_type":"article","og_title":"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1 - Dijix - \u0411\u043b\u043e\u0433","og_url":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/","og_site_name":"Dijix - \u0411\u043b\u043e\u0433","article_publisher":"https:\/\/www.facebook.com\/Dijixs","article_published_time":"2023-02-03T10:57:27+00:00","article_modified_time":"2023-02-03T10:58:55+00:00","og_image":[{"width":572,"height":384,"url":"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3-1.png","type":"image\/png"}],"author":"\u041b\u0435\u043e\u043d\u0438\u0434 \u041a\u0430\u0440\u0443\u043d\u0430","twitter_card":"summary_large_image","twitter_misc":{"\u041d\u0430\u043f\u0438\u0441\u0430\u043d\u043e":"\u041b\u0435\u043e\u043d\u0438\u0434 \u041a\u0430\u0440\u0443\u043d\u0430","\u041f\u0440\u0438\u0431\u043b. \u0447\u0430\u0441 \u0447\u0438\u0442\u0430\u043d\u043d\u044f":"16 \u0445\u0432\u0438\u043b\u0438\u043d"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/#article","isPartOf":{"@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/"},"author":{"name":"\u041b\u0435\u043e\u043d\u0438\u0434 \u041a\u0430\u0440\u0443\u043d\u0430","@id":"https:\/\/dijix.com.ua\/blog\/#\/schema\/person\/4ce2240cdf3db189e17ca0ff422a0c3d"},"headline":"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1","datePublished":"2023-02-03T10:57:27+00:00","dateModified":"2023-02-03T10:58:55+00:00","mainEntityOfPage":{"@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/"},"wordCount":2186,"commentCount":0,"publisher":{"@id":"https:\/\/dijix.com.ua\/blog\/#organization"},"articleSection":["Asp.Net Core"],"inLanguage":"uk","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/","url":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/","name":"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1 - Dijix - \u0411\u043b\u043e\u0433","isPartOf":{"@id":"https:\/\/dijix.com.ua\/blog\/#website"},"datePublished":"2023-02-03T10:57:27+00:00","dateModified":"2023-02-03T10:58:55+00:00","description":"\u0423 \u0446\u044c\u043e\u043c\u0443 \u0443\u0440\u043e\u0446\u0456 \u0440\u043e\u0437\u0433\u043b\u044f\u043d\u0435\u043c\u043e \u043f\u0440\u043e\u0446\u0435\u0441 \u043f\u043e\u0431\u0443\u0434\u043e\u0432\u0438 \u043f\u0440\u043e\u0454\u043a\u0442\u0443, \u044f\u043a\u0438\u0439 \u043f\u0440\u043e\u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0443\u0454 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f ASP.NET Core MVC \u0456 Entity Framework Core.","breadcrumb":{"@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/#breadcrumb"},"inLanguage":"uk","potentialAction":[{"@type":"ReadAction","target":["https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-1\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u0413\u043b\u0430\u0432\u043d\u0430\u044f \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430","item":"https:\/\/dijix.com.ua\/blog\/"},{"@type":"ListItem","position":2,"name":"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u044c 1"}]},{"@type":"WebSite","@id":"https:\/\/dijix.com.ua\/blog\/#website","url":"https:\/\/dijix.com.ua\/blog\/","name":"Dijix - \u0411\u043b\u043e\u0433","description":"\ud83d\udc9c","publisher":{"@id":"https:\/\/dijix.com.ua\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/dijix.com.ua\/blog\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"uk"},{"@type":"Organization","@id":"https:\/\/dijix.com.ua\/blog\/#organization","name":"Dijix - \u0411\u043b\u043e\u0433","url":"https:\/\/dijix.com.ua\/blog\/","logo":{"@type":"ImageObject","inLanguage":"uk","@id":"https:\/\/dijix.com.ua\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/08\/\u0421\u043d\u0438\u043c\u043e\u043a.png","contentUrl":"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/08\/\u0421\u043d\u0438\u043c\u043e\u043a.png","width":159,"height":92,"caption":"Dijix - \u0411\u043b\u043e\u0433"},"image":{"@id":"https:\/\/dijix.com.ua\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/www.facebook.com\/Dijixs"]},{"@type":"Person","@id":"https:\/\/dijix.com.ua\/blog\/#\/schema\/person\/4ce2240cdf3db189e17ca0ff422a0c3d","name":"\u041b\u0435\u043e\u043d\u0438\u0434 \u041a\u0430\u0440\u0443\u043d\u0430","image":{"@type":"ImageObject","inLanguage":"uk","@id":"https:\/\/dijix.com.ua\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/e3e8fa72f5adf168d30934fb574a97a5e812e7d6e2795075f0e7ea19311e3ba9?s=96&d=monsterid&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/e3e8fa72f5adf168d30934fb574a97a5e812e7d6e2795075f0e7ea19311e3ba9?s=96&d=monsterid&r=g","caption":"\u041b\u0435\u043e\u043d\u0438\u0434 \u041a\u0430\u0440\u0443\u043d\u0430"},"sameAs":["https:\/\/dijix.com.ua\/blog"],"url":"https:\/\/dijix.com.ua\/blog\/author\/admin\/"}]}},"_links":{"self":[{"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/posts\/364","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/comments?post=364"}],"version-history":[{"count":2,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/posts\/364\/revisions"}],"predecessor-version":[{"id":367,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/posts\/364\/revisions\/367"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/media\/201"}],"wp:attachment":[{"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/media?parent=364"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/categories?post=364"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/tags?post=364"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}