{"id":379,"date":"2023-02-03T13:18:02","date_gmt":"2023-02-03T13:18:02","guid":{"rendered":"https:\/\/dijix.com.ua\/blog\/?p=379"},"modified":"2023-02-03T13:29:53","modified_gmt":"2023-02-03T13:29:53","slug":"magazin-na-asp-net-core-mvc-ef-chast-4","status":"publish","type":"post","link":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/","title":{"rendered":"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u0438\u043d\u0430 4"},"content":{"rendered":"<p>\u0423 \u0446\u0456\u0439 \u0441\u0442\u0430\u0442\u0442\u0456, \u043c\u0438 \u043f\u0440\u043e\u0434\u043e\u0432\u0436\u0438\u043c\u043e \u043f\u0438\u0441\u0430\u0442\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core \u0456 Entity Framework Core. \u0423 \u0442\u0440\u0435\u0442\u0456\u0439 \u0447\u0430\u0441\u0442\u0438\u043d\u0456 \u043c\u0438 \u0440\u043e\u0437\u0448\u0438\u0440\u0438\u043b\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u0437\u0430 \u0440\u0430\u0445\u0443\u043d\u043e\u043a \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043d\u043e\u0432\u0438\u0445 \u043a\u043b\u0430\u0441\u0456\u0432 \u0456 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0432\u0456\u0434\u043d\u043e\u0441\u0438\u043d \u043c\u0456\u0436 \u043d\u0438\u043c\u0438. \u0414\u0456\u0437\u043d\u0430\u043b\u0438\u0441\u044f, \u044f\u043a \u0437\u0430\u043f\u0438\u0442\u0443\u0432\u0430\u0442\u0438 \u043f\u043e\u0432&#8217;\u044f\u0437\u0430\u043d\u0456 \u0434\u0430\u043d\u0456, \u044f\u043a\u0438\u043c \u0447\u0438\u043d\u043e\u043c \u0432\u0438\u043a\u043e\u043d\u0443\u0432\u0430\u0442\u0438 \u043e\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044f. \u0414\u043b\u044f \u043e\u0437\u043d\u0430\u0439\u043e\u043c\u043b\u0435\u043d\u043d\u044f \u0437 \u0442\u0440\u0435\u0442\u044c\u043e\u044e \u0447\u0430\u0441\u0442\u0438\u043d\u043e\u044e, \u043f\u0435\u0440\u0435\u0439\u0434\u0456\u0442\u044c \u0437\u0430 <a href=\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-3\/\">\u043f\u043e\u0441\u0438\u043b\u0430\u043d\u043d\u044f\u043c<\/a>.<\/p>\n<p>\u041f\u0440\u0438 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u0456 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043a\u0443 \u043e\u0441\u043d\u043e\u0432\u043d\u0430 \u0443\u0432\u0430\u0433\u0430 \u0437\u0430\u0437\u0432\u0438\u0447\u0430\u0439 \u043f\u0440\u0438\u0434\u0456\u043b\u044f\u0454\u0442\u044c\u0441\u044f \u043f\u043e\u0431\u0443\u0434\u043e\u0432\u0456 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0433\u043e \u0444\u0443\u043d\u0434\u0430\u043c\u0435\u043d\u0442\u0443, \u0456 \u044f\u043a\u0440\u0430\u0437 \u0442\u0430\u043a\u0438\u0439 \u043f\u0456\u0434\u0445\u0456\u0434 \u0431\u0443\u0432 \u043f\u0440\u0438\u0439\u043d\u044f\u0442\u0438\u0439 \u0443 \u043f\u0440\u043e\u0454\u043a\u0442\u0456 GameStore. \u0423 \u043c\u0456\u0440\u0443 \u0440\u043e\u0437\u0432\u0438\u0442\u043a\u0443 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0438 \u0447\u0430\u0441\u0442\u043e \u043a\u043e\u0440\u0438\u0441\u043d\u043e \u0437\u0431\u0456\u043b\u044c\u0448\u0443\u0432\u0430\u0442\u0438 \u043e\u0431\u0441\u044f\u0433 \u0434\u0430\u043d\u0438\u0445, \u0437 \u044f\u043a\u0438\u043c\u0438 \u043f\u0440\u043e\u0432\u043e\u0434\u0438\u0442\u044c\u0441\u044f \u0440\u043e\u0431\u043e\u0442\u0430, \u0449\u043e\u0431 \u043c\u043e\u0436\u043d\u0430 \u0431\u0443\u043b\u043e \u0431\u0430\u0447\u0438\u0442\u0438, \u044f\u043a\u0438\u0439 \u0432\u043f\u043b\u0438\u0432 \u0432\u043e\u043d\u0438 \u0447\u0438\u043d\u044f\u0442\u044c \u043d\u0430 \u043e\u043f\u0435\u0440\u0430\u0446\u0456\u0457, \u0449\u043e \u0456\u043d\u0456\u0446\u0456\u044e\u044e\u0442\u044c\u0441\u044f \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u043c, \u0456 \u043d\u0430 \u0447\u0430\u0441, \u0449\u043e \u043f\u043e\u0442\u0440\u0456\u0431\u0435\u043d \u0434\u043b\u044f \u0457\u0445 \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f. \u0423 \u0446\u044c\u043e\u043c\u0443 \u0440\u043e\u0437\u0434\u0456\u043b\u0456 \u0434\u043e \u0411\u0414 \u0431\u0443\u0434\u0435 \u0434\u043e\u0434\u0430\u043d\u043e \u0442\u0435\u0441\u0442\u043e\u0432\u0456 \u0434\u0430\u043d\u0456, \u0449\u043e\u0431 \u043f\u0440\u043e\u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0443\u0432\u0430\u0442\u0438 \u043d\u0435\u0434\u043e\u043b\u0456\u043a\u0438 \u0441\u043f\u043e\u0441\u043e\u0431\u0443, \u044f\u043a\u0438\u043c \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043e\u043a \u043f\u043e\u0434\u0430\u0454 \u0434\u0430\u043d\u0456 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456, \u0442\u0430 \u0432\u0436\u0438\u0442\u0438 \u0432\u0456\u0434\u043f\u043e\u0432\u0456\u0434\u043d\u0438\u0445 \u0437\u0430\u0445\u043e\u0434\u0456\u0432 \u0437\u0430 \u0440\u0430\u0445\u0443\u043d\u043e\u043a \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0438 \u0440\u043e\u0437\u0431\u0438\u0442\u0442\u044f \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438, \u0443\u043f\u043e\u0440\u044f\u0434\u043a\u0443\u0432\u0430\u043d\u043d\u044f \u0442\u0430 \u043f\u043e\u0448\u0443\u043a\u0443 \u0432 \u0434\u0430\u043d\u0438\u0445. \u0422\u0430\u043a\u043e\u0436 \u0431\u0443\u0434\u0435 \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u043e, \u044f\u043a\u0438\u043c \u0447\u0438\u043d\u043e\u043c \u043f\u043e\u043b\u0456\u043f\u0448\u0438\u0442\u0438 \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0438\u0432\u043d\u0456\u0441\u0442\u044c \u043e\u043f\u0435\u0440\u0430\u0446\u0456\u0439 \u0437 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f\u043c \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0438 Entity Framework Core, \u044f\u043a\u0430 \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u0443\u0454 \u0440\u043e\u0437\u0448\u0438\u0440\u0435\u043d\u0456 \u0432\u0430\u0440\u0456\u0430\u043d\u0442\u0438 \u043a\u043e\u043d\u0444\u0456\u0433\u0443\u0440\u0430\u0446\u0456\u0457 \u043c\u043e\u0434\u0435\u043b\u0456 \u0434\u0430\u043d\u0438\u0445, \u0432\u0456\u0434\u043e\u043c\u0456 \u044f\u043a \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 Fluent \u0410\u0420I.<\/p>\n<h2>\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u0438\u043d\u0430 4<\/h2>\n<p>&nbsp;<\/p>\n<h2>\u0421\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u0430 \u0456 \u043f\u043e\u0434\u0430\u043d\u043d\u044f \u0434\u043b\u044f \u043f\u043e\u0447\u0430\u0442\u043a\u043e\u0432\u043e\u0433\u043e \u0437\u0430\u043f\u043e\u0432\u043d\u0435\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u043c\u0438<\/h2>\n<p>\u041d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u0438\u0439 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440, \u044f\u043a\u0438\u0439 \u0437\u043c\u043e\u0436\u0435 \u0437\u0430\u043f\u043e\u0432\u043d\u044e\u0432\u0430\u0442\u0438 \u0411\u0414 \u0442\u0435\u0441\u0442\u043e\u0432\u0438\u043c\u0438 \u0434\u0430\u043d\u0438\u043c\u0438. \u0414\u043e\u0434\u0430\u0439\u0442\u0435 \u0432 \u043f\u0430\u043f\u043a\u0443 Controller, \u043d\u043e\u0432\u0438\u0439 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440 <strong>SeedController<\/strong>, \u0437 \u0442\u0430\u043a\u0438\u043c \u0432\u043c\u0456\u0441\u0442\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">public class SeedController : Controller\r\n    {\r\n        private readonly ApplicationContext _context;\r\n\r\n        public SeedController(ApplicationContext context)\r\n        {\r\n            _context = context;\r\n        }\r\n        public IActionResult Index()\r\n        {\r\n            ViewBag.Count = _context.Products.Count();\r\n            return View(_context.Products.Include(e =&gt; e.Category).OrderBy(e =&gt; e.Id).Take(20));\r\n        }\r\n        [HttpPost]\r\n        public IActionResult CreateSeedData(int count)\r\n        {\r\n            ClearData();\r\n            if (count &gt; 0)\r\n            {\r\n                _context.Database.SetCommandTimeout(TimeSpan.FromMinutes(10));\r\n                _context.Database.ExecuteSqlRaw(\"DROP PROCEDURE IF EXISTS CreateSeedData\");\r\n                _context.Database.ExecuteSqlRaw($@\"\r\n                CREATE PROCEDURE CreateSeedData \r\n                @RowCount decimal\r\n                AS\r\n                BEGIN\r\n                SET NOCOUNT ON\r\n                DECLARE @i INT = 0;\r\n                DECLARE @catId INT;\r\n                DECLARE @CatCount INT = @RowCount \/ 10;\r\n                DECLARE @pprice DECIMAL(5,2);\r\n                DECLARE @rprice DECIMAL(5,2);\r\n                BEGIN TRANSACTION\r\n                WHILE @i &lt; @CatCount\r\n                BEGIN \r\n                INSERT INTO Categories (Name,Description)\r\n                VALUES (CONCAT('Category-',@i),\r\n                'Test Data Category');\r\n                SET @catId = SCOPE_IDENTITY();\r\n                DECLARE @j INT = 1;\r\n                WHILE @j &lt;= 10\r\n                BEGIN\r\n                SET @pprice = RAND() * (500-5+1);\r\n                SET @rprice = (RAND() * @pprice) + @pprice;\r\n                INSERT INTO Products (Name,CategoryId,PurchasePrice,RetailPrice)\r\n                VALUES (CONCAT('Product',@i,'-',@j),@catId,@pprice,@rprice)\r\n                SET @j = @j + 1\r\n                END\r\n                SET @i = @i + 1\r\n                END\r\n                COMMIT\r\n                END\");\r\n                _context.Database.BeginTransaction();\r\n                _context.Database.ExecuteSqlRaw($\"EXEC CreateSeedData @RowCount = {count}\");\r\n                _context.Database.CommitTransaction();\r\n            }\r\n            return RedirectToAction(nameof(Index));\r\n        }\r\n        [HttpPost]\r\n        public IActionResult ClearData()\r\n        {\r\n            _context.Database.SetCommandTimeout(TimeSpan.FromMinutes(10));\r\n            _context.Database.BeginTransaction();\r\n            _context.Database.ExecuteSqlRaw(\"DELETE FROM Orders\");\r\n            _context.Database.ExecuteSqlRaw(\"DELETE FROM Categories\");\r\n            _context.Database.CommitTransaction();\r\n            return RedirectToAction(nameof(Index));\r\n        }\r\n    }\r\n<\/pre>\n<p>\u041a\u043e\u043b\u0438 \u0441\u043f\u0440\u0430\u0432\u0430 \u0434\u043e\u0445\u043e\u0434\u0438\u0442\u044c \u0434\u043e \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0456\u0457 \u0432\u0435\u043b\u0438\u043a\u0438\u0445 \u043e\u0431\u0441\u044f\u0433\u0456\u0432 \u0442\u0435\u0441\u0442\u043e\u0432\u0438\u0445 \u0434\u0430\u043d\u0438\u0445, \u0442\u043e \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 .NET \u0456 \u0457\u0445\u043d\u0454 \u0437\u0431\u0435\u0440\u0435\u0436\u0435\u043d\u043d\u044f \u0432 \u0411\u0414 \u0431\u0443\u0434\u0435 \u043d\u0435\u0435\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u0438\u043c. \u041a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440 Seed \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454 \u0437\u0430\u0441\u043e\u0431\u0438 Entity Framework Core \u0434\u043b\u044f \u0440\u043e\u0431\u043e\u0442\u0438 \u0431\u0435\u0437\u043f\u043e\u0441\u0435\u0440\u0435\u0434\u043d\u044c\u043e \u0437 SQL. \u0449\u043e\u0431 \u0441\u0442\u0432\u043e\u0440\u0438\u0442\u0438 \u0456 \u0432\u0438\u043a\u043e\u043d\u0430\u0442\u0438 \u0437\u0431\u0435\u0440\u0435\u0436\u0435\u043d\u0443 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0443, \u044f\u043a\u0430 \u0432\u0438\u0440\u043e\u0431\u043b\u044f\u0454 \u0442\u0435\u0441\u0442\u043e\u0432\u0456 \u0434\u0430\u043d\u0456 \u043d\u0430\u0431\u0430\u0433\u0430\u0442\u043e \u0448\u0432\u0438\u0434\u0448\u0435.<\/p>\n<hr \/>\n<h3>\u041d\u0435 \u0440\u043e\u0431\u0456\u0442\u044c \u0442\u0430\u043a \u0443 \u0440\u0435\u0430\u043b\u044c\u043d\u0438\u0445 \u043f\u0440\u043e\u0454\u043a\u0442\u0430\u0445<\/h3>\n<p>\u0426\u0435\u0439 \u043f\u0456\u0434\u0445\u0456\u0434 \u043c\u0430\u0454 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u0442\u0438\u0441\u044f \u0442\u0456\u043b\u044c\u043a\u0438 \u0434\u043b\u044f \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0456\u0457 \u0442\u0435\u0441\u0442\u043e\u0432\u0438\u0445 \u0434\u0430\u043d\u0438\u0445 \u0456 \u043d\u0456 \u0432 \u044f\u043a\u0456\u0439 \u0456\u043d\u0448\u0456\u0439 \u0447\u0430\u0441\u0442\u0438\u043d\u0456 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0438. \u0423 \u0446\u044c\u043e\u043c\u0443 \u0440\u043e\u0437\u0434\u0456\u043b\u0456 \u043f\u043e\u0442\u0440\u0456\u0431\u0435\u043d \u043c\u0435\u0445\u0430\u043d\u0456\u0437\u043c, \u044f\u043a\u0438\u0439 \u0434\u0430\u0454 \u0437\u043c\u043e\u0433\u0443 \u043d\u0430\u0434\u0456\u0439\u043d\u043e \u0433\u0435\u043d\u0435\u0440\u0443\u0432\u0430\u0442\u0438 \u0432\u0435\u043b\u0438\u043a\u0456 \u043e\u0431\u0441\u044f\u0433\u0438 \u0442\u0435\u0441\u0442\u043e\u0432\u0438\u0445 \u0434\u0430\u043d\u0438\u0445, \u043d\u0435 \u0432\u0438\u043c\u0430\u0433\u0430\u044e\u0447\u0438 \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u0441\u043a\u043b\u0430\u0434\u043d\u0438\u0445 \u0437\u0430\u0432\u0434\u0430\u043d\u044c \u0443 \u0411\u0414 \u0430\u0431\u043e \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0456\u0445 \u0456\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0456\u0432.<\/p>\n<p>\u041f\u0456\u0434 \u0447\u0430\u0441 \u0440\u043e\u0431\u043e\u0442\u0438 \u0431\u0435\u0437\u043f\u043e\u0441\u0435\u0440\u0435\u0434\u043d\u044c\u043e \u0437 SQL \u0441\u043b\u0456\u0434 \u0434\u043e\u0442\u0440\u0438\u043c\u0443\u0432\u0430\u0442\u0438\u0441\u044f \u043e\u0431\u0435\u0440\u0435\u0436\u043d\u043e\u0441\u0442\u0456, \u043e\u0441\u043a\u0456\u043b\u044c\u043a\u0438 \u0432 \u0442\u0430\u043a\u043e\u043c\u0443 \u0440\u0430\u0437\u0456 \u043e\u0431\u0445\u043e\u0434\u044f\u0442\u044c\u0441\u044f \u0447\u0438\u0441\u043b\u0435\u043d\u043d\u0456 \u043a\u043e\u0440\u0438\u0441\u043d\u0456 \u0437\u0430\u0441\u043e\u0431\u0438 \u0437\u0430\u0445\u0438\u0441\u0442\u0443, \u0449\u043e \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0443\u044e\u0442\u044c\u0441\u044f \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043e\u044e Entity Framework Core. \u041f\u0456\u0434\u0441\u0443\u043c\u043a\u043e\u0432\u0438\u0439 \u043a\u043e\u0434 SQL \u0432\u0430\u0436\u043a\u043e \u0442\u0435\u0441\u0442\u0443\u0432\u0430\u0442\u0438 \u0456 \u0441\u0443\u043f\u0440\u043e\u0432\u043e\u0434\u0436\u0443\u0432\u0430\u0442\u0438, \u0434\u043e \u0442\u043e\u0433\u043e \u0436 \u0447\u0430\u0441\u0442\u043e \u0432\u0438\u044f\u0432\u043b\u044f\u0454\u0442\u044c\u0441\u044f, \u0449\u043e \u0432\u0456\u043d \u043f\u0440\u0430\u0446\u044e\u0454 \u043d\u0430 \u0454\u0434\u0438\u043d\u043e\u043c\u0443 \u0441\u0435\u0440\u0432\u0435\u0440\u0456 \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445. \u041a\u043e\u0440\u043e\u0442\u0448\u0435 \u043a\u0430\u0436\u0443\u0447\u0438, \u043d\u0435 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0439\u0442\u0435 \u0436\u043e\u0434\u043d\u0456 \u0430\u0441\u043f\u0435\u043a\u0442\u0438 \u043f\u0440\u043e\u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u043e\u0432\u0430\u043d\u043e\u0433\u043e \u043f\u0440\u0438\u0439\u043e\u043c\u0443 \u0443 \u0432\u0438\u0440\u043e\u0431\u043d\u0438\u0447\u0438\u0445 \u0447\u0430\u0441\u0442\u0438\u043d\u0430\u0445 \u0441\u0432\u043e\u0457\u0445 \u0434\u043e\u0434\u0430\u0442\u043a\u0456\u0432.<\/p>\n<hr \/>\n<p>\u0429\u043e\u0431 \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0438\u0442\u0438 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440 \u043f\u043e\u0434\u0430\u043d\u043d\u044f\u043c, \u0441\u0442\u0432\u043e\u0440\u0456\u0442\u044c \u043f\u0430\u043f\u043a\u0443<strong> Views \/ Seed<\/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 \u0437\u0430\u043a\u0430\u0437\u044b\";\r\n}\r\n@model IEnumerable&lt;Product&gt;\r\n\r\n&lt;h3 class=\"p-2 bg-primary text-white text-center\"&gt;\u041d\u0430\u0447\u0430\u043b\u044c\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435&lt;\/h3&gt;\r\n&lt;form method=\"post\"&gt;\r\n    &lt;div class=\"form-group\"&gt;\r\n        &lt;label&gt;\u041a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f:&lt;\/label&gt;\r\n        &lt;input class=\"form-control\" name=\"count\" value=\"50\" \/&gt;\r\n    &lt;\/div&gt;\r\n    &lt;div class=\"text-center\"&gt;\r\n        &lt;button type=\"submit\" asp-action=\"CreateSeedData\" class=\"btn btn-primary\"&gt;\u0417\u0430\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0431\u0430\u0437\u0443&lt;\/button&gt;\r\n        &lt;button type=\"submit\" asp-action=\"ClearData\" class=\"btn btn-primary\"&gt;\u041e\u0447\u0438\u0441\u0442\u0438\u0442\u044c \u0431\u0430\u0437\u0443&lt;\/button&gt;\r\n    &lt;\/div&gt;\r\n&lt;\/form&gt;\r\n\r\n&lt;h5&gt;\u0412\u0441\u0435\u0433\u043e @ViewBag.Count \u0442\u043e\u0432\u0430\u0440\u043e\u0432 \u0432 \u0411\u0430\u0437\u0435 \u0414\u0430\u043d\u043d\u044b\u0445&lt;\/h5&gt;\r\n\r\n&lt;div class=\"container-fluid\"&gt;\r\n    &lt;div class=\"row\"&gt;\r\n        &lt;div class=\"col-1 fw-bold\"&gt;Id&lt;\/div&gt;\r\n        &lt;div class=\"col fw-bold\"&gt;\u041d\u0430\u0437\u0432\u0430\u043d\u0438\u0435&lt;\/div&gt;\r\n        &lt;div class=\"col fw-bold\"&gt;\u041a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u044f&lt;\/div&gt;\r\n        &lt;div class=\"col fw-bold\"&gt;\u0417\u0430\u043a\u0443\u043f\u043a\u0430&lt;\/div&gt;\r\n        &lt;div class=\"col fw-bold\"&gt;\u041f\u0440\u043e\u0434\u0430\u0436\u0430&lt;\/div&gt;\r\n    &lt;\/div&gt;\r\n    @foreach (Product product in Model)\r\n    {\r\n        &lt;div class=\"row\"&gt;\r\n            &lt;div class=\"col-1\"&gt;@product.Id&lt;\/div&gt;\r\n            &lt;div class=\"col\"&gt;@product.Name&lt;\/div&gt;\r\n            &lt;div class=\"col\"&gt;@product.Category.Name&lt;\/div&gt;\r\n            &lt;div class=\"col\"&gt;@product.PurchasePrice&lt;\/div&gt;\r\n            &lt;div class=\"col\"&gt;@product.RetailPrice&lt;\/div&gt;\r\n        &lt;\/div&gt;\r\n    }\r\n&lt;\/div&gt;\r\n<\/pre>\n<p>\u041f\u043e\u0434\u0430\u043d\u043d\u044f \u0434\u0430\u0454 \u0437\u043c\u043e\u0433\u0443 \u0432\u043a\u0430\u0437\u0443\u0432\u0430\u0442\u0438, \u0441\u043a\u0456\u043b\u044c\u043a\u0438 \u0442\u0435\u0441\u0442\u043e\u0432\u0438\u0445 \u0434\u0430\u043d\u0438\u0445 \u043c\u0430\u0454 \u0431\u0443\u0442\u0438 \u0437\u0433\u0435\u043d\u0435\u0440\u043e\u0432\u0430\u043d\u043e, \u0456 \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0430\u0454 \u043f\u0435\u0440\u0448\u0456 20 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 Product, \u044f\u043a\u0456 \u043d\u0430\u0434\u0430\u044e\u0442\u044c\u0441\u044f \u0437\u0430\u043f\u0438\u0442\u043e\u043c \u0443 \u0434\u0456\u0457 Index \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u0430 Seed. \u0429\u043e\u0431 \u043f\u043e\u043b\u0435\u0433\u0448\u0438\u0442\u0438 \u0440\u043e\u0431\u043e\u0442\u0443 \u0437 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u043e\u043c Seed, \u0434\u043e\u0434\u0430\u043c\u043e \u043f\u043e\u0441\u0438\u043b\u0430\u043d\u043d\u044f \u0432 \u043c\u0435\u043d\u044e <strong>_Layout.cshtml<\/strong>:<\/p>\n<pre class=\"lang:default decode:true \">  &lt;li class=\"nav-item\"&gt;\r\n                            &lt;a class=\"nav-link text-dark\" asp-area=\"\" asp-controller=\"Seed\" asp-action=\"Index\"&gt;\u041d\u0430\u0447\u0430\u043b\u044c\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435&lt;\/a&gt;\r\n                        &lt;\/li&gt;\r\n<\/pre>\n<p>\u0417\u0430\u043f\u0443\u0441\u0442\u0456\u0442\u044c \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043e\u043a, \u043f\u0435\u0440\u0435\u0439\u0434\u0456\u0442\u044c \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0443 <strong>Seed\/Index.cshtml<\/strong>, \u0432\u0438\u043a\u043e\u043d\u0430\u0439\u0442\u0435 \u043e\u0447\u0438\u0449\u0435\u043d\u043d\u044f \u0431\u0430\u0437\u0438 (\u044f\u043a\u0449\u043e \u0445\u043e\u0447\u0435\u0442\u0435), \u043d\u0430\u0442\u0438\u0441\u043d\u0443\u0432\u0448\u0438 \u043a\u043d\u043e\u043f\u043a\u0443 &#8220;\u041e\u0447\u0438\u0441\u0442\u0438\u0442\u0438 \u0431\u0430\u0437\u0443&#8221;. \u0422\u0435\u043f\u0435\u0440 \u0432\u043a\u0430\u0436\u0456\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u043d\u044f 500 \u0432 \u0435\u043b\u0435\u043c\u0435\u043d\u0442\u0456 <strong>input<\/strong> \u0456 \u043d\u0430\u0442\u0438\u0441\u043d\u0456\u0442\u044c \u043a\u043d\u043e\u043f\u043a\u0443 &#8220;\u0417\u0430\u043f\u043e\u0432\u043d\u0438\u0442\u0438 \u0431\u0430\u0437\u0443&#8221;. \u0413\u0435\u043d\u0435\u0440\u0430\u0446\u0456\u044f \u0434\u0430\u043d\u0438\u0445 \u0437\u0430\u0439\u043c\u0435 \u044f\u043a\u0438\u0439\u0441\u044c \u0447\u0430\u0441, \u043f\u0456\u0441\u043b\u044f \u0447\u043e\u0433\u043e \u0432\u0438 \u043f\u043e\u0431\u0430\u0447\u0438\u0442\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-241 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1-5.png\" alt=\"asp.net core shop talbe\" width=\"1208\" height=\"922\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1-5.png 1208w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1-5-300x229.png 300w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1-5-1024x782.png 1024w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1-5-768x586.png 768w\" sizes=\"auto, (max-width: 1208px) 100vw, 1208px\" \/><\/p>\n<h2>\u041c\u0430\u0441\u0448\u0442\u0430\u0431\u0443\u0432\u0430\u043d\u043d\u044f \u043f\u043e\u0434\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445<\/h2>\n<p>\u0429\u043e\u0431 \u043f\u0440\u043e\u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0443\u0432\u0430\u0442\u0438 \u0432\u0430\u0434\u0438 \u0441\u043f\u043e\u0441\u043e\u0431\u0443, \u044f\u043a\u0438\u043c \u0434\u043e\u0434\u0430\u0442\u043e\u043a <strong>GameStore<\/strong> \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0454 \u0441\u0432\u043e\u0457 \u0434\u0430\u043d\u0456, \u043e\u0441\u043e\u0431\u043b\u0438\u0432\u043e \u0431\u0430\u0433\u0430\u0442\u043e \u0434\u0430\u043d\u0438\u0445 \u043d\u0435 \u043f\u043e\u0442\u0440\u0456\u0431\u043d\u043e. \u0417\u0430 \u043d\u0430\u044f\u0432\u043d\u043e\u0441\u0442\u0456 \u0442\u0438\u0441\u044f\u0447\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 \u043c\u0435\u0442\u043e\u0434 \u043f\u043e\u0434\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456 \u0441\u0442\u0430\u0454 \u043d\u0435\u043f\u0440\u0438\u0434\u0430\u0442\u043d\u0438\u043c, \u0456 \u0446\u0435 \u0432\u0441\u0435 \u0449\u0435 \u0432\u0456\u0434\u043d\u043e\u0441\u043d\u043e \u043d\u0435\u0432\u0435\u043b\u0438\u043a\u0438\u0439 \u043e\u0431\u0441\u044f\u0433 \u0434\u0430\u043d\u0438\u0445, \u0437 \u044f\u043a\u0438\u043c \u0434\u043e\u0434\u0430\u0442\u043a\u0443 \u0434\u043e\u0432\u043e\u0434\u0438\u0442\u044c\u0441\u044f \u043c\u0430\u0442\u0438 \u0441\u043f\u0440\u0430\u0432\u0443. \u0423 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u0438\u0445 \u0440\u043e\u0437\u0434\u0456\u043b\u0430\u0445 \u0441\u043f\u043e\u0441\u0456\u0431 \u043f\u043e\u0434\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0434\u043e\u0434\u0430\u0442\u043a\u043e\u043c GameStore \u0431\u0443\u0434\u0435 \u0437\u043c\u0456\u043d\u0435\u043d\u043e, \u0449\u043e\u0431 \u0434\u043e\u043f\u043e\u043c\u043e\u0433\u0442\u0438 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456 \u0432\u0438\u043a\u043e\u043d\u0443\u0432\u0430\u0442\u0438 \u043e\u0441\u043d\u043e\u0432\u043d\u0456 \u043e\u043f\u0435\u0440\u0430\u0446\u0456\u0457 \u0442\u0430 \u0437\u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0438 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438, \u044f\u043a\u0456 \u0439\u043e\u0433\u043e \u0446\u0456\u043a\u0430\u0432\u043b\u044f\u0442\u044c.<\/p>\n<h2>\u0414\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0438 \u0440\u043e\u0437\u0431\u0438\u0442\u0442\u044f \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438<\/h2>\n<p>\u041f\u0435\u0440\u0448\u0438\u043c \u0431\u0443\u0434\u0435 \u0440\u043e\u0437\u0432&#8217;\u044f\u0437\u0430\u043d\u043e \u0437\u0430\u0434\u0430\u0447\u0443 \u0440\u043e\u0437\u0431\u0438\u0442\u0442\u044f \u0434\u0430\u043d\u0438\u0445, \u0449\u043e \u043f\u043e\u0434\u0430\u044e\u0442\u044c\u0441\u044f \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456, \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0449\u043e\u0431 \u0432\u043e\u043d\u0438 \u043d\u0435 \u0432\u0438\u0433\u043b\u044f\u0434\u0430\u043b\u0438 \u044f\u043a \u043e\u0434\u0438\u043d \u0434\u043e\u0432\u0433\u0438\u0439 \u0441\u043f\u0438\u0441\u043e\u043a. \u0412\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f \u043f\u0440\u043e\u0441\u0442\u0438\u0445 \u0442\u0430\u0431\u043b\u0438\u0446\u044c, \u044f\u043a\u0456 \u0432\u043a\u043b\u044e\u0447\u0430\u044e\u0442\u044c \u0432\u0441\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438, \u0454 \u0437\u0440\u0443\u0447\u043d\u0438\u043c \u043f\u0456\u0434\u0445\u043e\u0434\u043e\u043c, \u043a\u043e\u043b\u0438 \u0444\u043e\u0440\u043c\u0443\u044e\u0442\u044c\u0441\u044f \u043e\u0441\u043d\u043e\u0432\u0438 \u0434\u043e\u0434\u0430\u0442\u043a\u0430, \u0430\u043b\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u0456, \u0449\u043e \u043c\u0456\u0441\u0442\u044f\u0442\u044c \u0442\u0438\u0441\u044f\u0447\u0456 \u0440\u044f\u0434\u043a\u0456\u0432, \u043d\u0435\u043f\u0440\u0438\u0434\u0430\u0442\u043d\u0456 \u0434\u043b\u044f \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f \u0432 \u0431\u0456\u043b\u044c\u0448\u043e\u0441\u0442\u0456 \u0434\u043e\u0434\u0430\u0442\u043a\u0456\u0432. \u0429\u043e\u0431 \u0440\u043e\u0437\u0432&#8217;\u044f\u0437\u0430\u0442\u0438 \u0446\u044e \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443, \u043c\u0438 \u0434\u043e\u0434\u0430\u043c\u043e \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0443 \u0437\u0430\u043f\u0438\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u0432 \u0411\u0414 \u043d\u0435\u0432\u0435\u043b\u0438\u043a\u0438\u0445 \u043e\u0431\u0441\u044f\u0433\u0456\u0432 \u0434\u0430\u043d\u0438\u0445 \u0456 \u0434\u043e\u0437\u0432\u043e\u043b\u0438\u043c\u043e \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456 \u043f\u0435\u0440\u0435\u043c\u0456\u0449\u0430\u0442\u0438\u0441\u044f, \u043f\u0435\u0440\u0435\u0433\u043e\u0440\u0442\u0430\u044e\u0447\u0438 \u0442\u0430\u043a\u0456 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438 \u0437 \u043d\u0435\u0432\u0435\u043b\u0438\u043a\u0438\u043c\u0438 \u043e\u0431\u0441\u044f\u0433\u0430\u043c\u0438 \u0434\u0430\u043d\u0438\u0445.<\/p>\n<p>\u041f\u0456\u0434 \u0447\u0430\u0441 \u0440\u043e\u0431\u043e\u0442\u0438 \u0437 \u0432\u0435\u043b\u0438\u043a\u0438\u043c\u0438 \u043e\u0431\u0441\u044f\u0433\u0430\u043c\u0438 \u0434\u0430\u043d\u0438\u0445 \u0432\u0430\u0436\u043b\u0438\u0432\u043e \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0438\u0442\u0438 \u0443\u0437\u0433\u043e\u0434\u0436\u0435\u043d\u0435 \u0443\u043f\u0440\u0430\u0432\u043b\u0456\u043d\u043d\u044f \u0434\u043e\u0441\u0442\u0443\u043f\u043e\u043c \u0434\u043e \u0446\u0438\u0445 \u0434\u0430\u043d\u0438\u0445, \u0449\u043e\u0431 \u0432 \u043e\u0434\u043d\u0456\u0454\u0457 \u0447\u0430\u0441\u0442\u0438\u043d\u0438 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043a\u0443 \u043d\u0435 \u0431\u0443\u043b\u043e \u0436\u043e\u0434\u043d\u043e\u0457 \u043c\u043e\u0436\u043b\u0438\u0432\u043e\u0441\u0442\u0456 \u0432\u0438\u043f\u0430\u0434\u043a\u043e\u0432\u043e \u0437\u0430\u043f\u0440\u043e\u0441\u0438\u0442\u0438 \u043c\u0456\u043b\u044c\u0439\u043e\u043d\u0438 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432. \u041c\u0438 \u043f\u0440\u0438\u0439\u043c\u0435\u043c\u043e \u043f\u0456\u0434\u0445\u0456\u0434, \u0449\u043e \u043f\u0435\u0440\u0435\u0434\u0431\u0430\u0447\u0430\u0454 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043a\u043b\u0430\u0441\u0443 \u043a\u043e\u043b\u0435\u043a\u0446\u0456\u0457, \u044f\u043a\u0438\u0439 \u043c\u0456\u0441\u0442\u0438\u0442\u044c \u0443 \u0441\u043e\u0431\u0456 \u0440\u043e\u0437\u0431\u0438\u0442\u0442\u044f \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438.<\/p>\n<p>\u0414\u043b\u044f \u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u043d\u044f \u043a\u043e\u043b\u0435\u043a\u0446\u0456\u0457, \u044f\u043a\u0430 \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0438\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f \u0434\u043e \u0440\u043e\u0437\u0431\u0438\u0442\u0438\u0445 \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438 \u0434\u0430\u043d\u0438\u0445, \u0441\u0442\u0432\u043e\u0440\u0438\u043c\u043e \u043f\u0430\u043f\u043a\u0443 <strong>Models\/Pages<\/strong>, \u0434\u043e\u0434\u0430\u043c\u043e \u0434\u043e \u043d\u0435\u0457 \u0444\u0430\u0439\u043b \u043a\u043b\u0430\u0441 \u043d\u0430 \u0456\u043c&#8217;\u044f <strong>PagedList.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 PagedList&lt;T&gt;:List&lt;T&gt;\r\n    {\r\n        public PagedList(IQueryable&lt;T&gt; query, QueryOptions options = null)\r\n        {\r\n            CurrentPage = options.CurrentPage;\r\n            PageSize = options.PageSize;\r\n            TotalPages = query.Count() \/ PageSize;\r\n            AddRange(query.Skip((CurrentPage - 1) * PageSize).Take(PageSize));\r\n        }\r\n        public int CurrentPage { get; set; }\r\n        public int PageSize { get; set; }\r\n        public int TotalPages { get; set; }\r\n\r\n        public bool HasPreviousPage =&gt; CurrentPage &gt; 1;\r\n        public bool HasNextPage =&gt; CurrentPage &lt; TotalPages;\r\n    }\r\n<\/pre>\n<p>\u042f\u043a \u0431\u0430\u0437\u043e\u0432\u0438\u0439 \u043a\u043b\u0430\u0441 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u0441\u0442\u0440\u043e\u0433\u043e \u0442\u0438\u043f\u0456\u0437\u043e\u0432\u0430\u043d\u0438\u0439 List. \u044f\u043a\u0438\u0439 \u0434\u043e\u0437\u0432\u043e\u043b\u0438\u0442\u044c \u043b\u0435\u0433\u043a\u043e \u043d\u0430\u0440\u043e\u0449\u0443\u0432\u0430\u0442\u0438 \u0431\u0430\u0437\u043e\u0432\u0443 \u043f\u043e\u0432\u0435\u0434\u0456\u043d\u043a\u0443 \u043a\u043e\u043b\u0435\u043a\u0446\u0456\u0457. \u041a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440 \u043f\u0440\u0438\u0439\u043c\u0430\u0454 \u043e\u0431&#8217;\u0454\u043a\u0442 \u0440\u0435\u0430\u043b\u0456\u0437\u0430\u0446\u0456\u0457 <strong>IQueryable&lt;T&gt;<\/strong>, \u0449\u043e \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0454 \u0437\u0430\u043f\u0438\u0442, \u044f\u043a\u0438\u0439 \u0431\u0443\u0434\u0435 \u043f\u043e\u0441\u0442\u0430\u0447\u0430\u0442\u0438 \u0434\u0430\u043d\u0456 \u0434\u043b\u044f \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u043d\u044f \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456. \u0422\u0430\u043a\u0438\u0439 \u0437\u0430\u043f\u0438\u0442 \u0431\u0443\u0434\u0435 \u0432\u0438\u043a\u043e\u043d\u0443\u0432\u0430\u0442\u0438\u0441\u044f \u0434\u0432\u0456\u0447\u0456 &#8211; \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u0434\u043b\u044f \u043e\u0442\u0440\u0438\u043c\u0430\u043d\u043d\u044f \u0437\u0430\u0433\u0430\u043b\u044c\u043d\u043e\u0457 \u043a\u0456\u043b\u044c\u043a\u043e\u0441\u0442\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432, \u044f\u043a\u0443 \u043c\u0456\u0433 \u0431\u0438 \u043f\u043e\u0432\u0435\u0440\u043d\u0443\u0442\u0438 \u0437\u0430\u043f\u0438\u0442, \u0456 \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u0434\u043b\u044f \u043e\u0442\u0440\u0438\u043c\u0430\u043d\u043d\u044f \u0442\u0456\u043b\u044c\u043a\u0438 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432, \u0449\u043e \u043f\u0456\u0434\u043b\u044f\u0433\u0430\u044e\u0442\u044c \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u043d\u044e \u043d\u0430 \u043f\u043e\u0442\u043e\u0447\u043d\u0456\u0439 \u0441\u0442\u043e\u0440\u0456\u043d\u0446\u0456. \u0426\u0435 \u043a\u043e\u043c\u043f\u0440\u043e\u043c\u0456\u0441, \u043f\u0440\u0438\u0442\u0430\u043c\u0430\u043d\u043d\u0438\u0439 \u0440\u043e\u0437\u0431\u0438\u0442\u0442\u044e \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438, \u0437\u0430 \u044f\u043a\u043e\u0433\u043e \u0434\u043e\u0434\u0430\u0442\u043a\u043e\u0432\u0438\u0439 \u0437\u0430\u043f\u0438\u0442 COUNT \u0432\u0440\u0456\u0432\u043d\u043e\u0432\u0430\u0436\u0443\u0454\u0442\u044c\u0441\u044f \u0437\u0430\u043f\u0438\u0442\u0430\u043c\u0438 \u0434\u043b\u044f \u043c\u0435\u043d\u0448\u043e\u0457 \u043a\u0456\u043b\u044c\u043a\u043e\u0441\u0442\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 \u0437\u0430\u0433\u0430\u043b\u043e\u043c. \u0412 \u0456\u043d\u0448\u0438\u0445 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430\u0445 \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440\u0430 \u0432\u043a\u0430\u0437\u0443\u044e\u0442\u044c\u0441\u044f \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0430, \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u0430 \u0434\u043b\u044f \u0437\u0430\u043f\u0438\u0442\u0443, \u0456 \u043a\u0456\u043b\u044c\u043a\u0456\u0441\u0442\u044c \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432, \u0449\u043e \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0430\u044e\u0442\u044c\u0441\u044f \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u0446\u0456.<\/p>\n<p>\u0414\u043b\u044f \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u043d\u044f \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0456\u0432, \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u0438\u0445 \u0437\u0430\u043f\u0438\u0442\u0443, \u0434\u043e\u0434\u0430\u0439\u0442\u0435 \u0432 \u043f\u0430\u043f\u043a\u0443 <strong>Models<\/strong>\/<strong>Pages<\/strong> \u0444\u0430\u0439\u043b \u043a\u043b\u0430\u0441\u0443 \u043d\u0430 \u0456\u043c&#8217;\u044f<strong> QueryOptions.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 QueryOptions\r\n    {\r\n        public int CurrentPage { get; set; } = 1;\r\n        public int PageSize { get; set; } = 10;\r\n    }\r\n<\/pre>\n<h2>\u041e\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044f \u0441\u0445\u043e\u0432\u0438\u0449\u0430<\/h2>\n<p>\u0429\u043e\u0431 \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0438\u0442\u0438 \u0443\u0437\u0433\u043e\u0434\u0436\u0435\u043d\u0435 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f \u0437\u0430\u0441\u043e\u0431\u0443 \u0440\u043e\u0437\u0431\u0438\u0432\u043a\u0438 \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438, \u044f\u043a \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0432\u0438\u043a\u043e\u043d\u0443\u0432\u0430\u043d\u0438\u0445 \u0443 \u0441\u0445\u043e\u0432\u0438\u0449\u0456 \u0437\u0430\u043f\u0438\u0442\u0456\u0432 \u0431\u0443\u0434\u0435 \u043f\u043e\u0432\u0435\u0440\u0442\u0430\u0442\u0438\u0441\u044f \u043e\u0431&#8217;\u0454\u043a\u0442 <strong>PagedList<\/strong>. \u0414\u043e\u0434\u0430\u0439\u0442\u0435 \u0432 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 <strong>IProduct<\/strong>, \u043c\u0435\u0442\u043e\u0434 \u043d\u0430 \u0456\u043c&#8217;\u044f<strong> GetProduct()<\/strong>, \u044f\u043a\u0438\u0439 \u043f\u043e\u0432\u0435\u0440\u0442\u0430\u0454 \u0434\u0430\u043d\u0456 \u0434\u043b\u044f \u043e\u0434\u0438\u043d\u043e\u0447\u043d\u043e\u0457 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438:<\/p>\n<pre class=\"lang:default decode:true \">public interface IProduct\r\n    {\r\n        PagedList&lt;Product&gt; GetProducts(QueryOptions options);\r\n\r\n\r\n        IEnumerable&lt;Product&gt; GetAllProducts();\r\n        Product GetProduct(int id);\r\n        void AddProduct(Product product);\r\n        void UpdateProduct(Product product);\r\n        void UpdateAll(Product[] products);\r\n        void DeleteProduct(Product product);\r\n    }\r\n\u0412\u043d\u0435\u0441\u0438\u0442\u0435 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0435 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0432 \u043a\u043b\u0430\u0441\u0441 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0445\u0440\u0430\u043d\u0438\u043b\u0438\u0449\u0430 ProductRepository:\r\npublic class ProductRepository : IProduct\r\n    {\r\n        \/\/...\r\n        public PagedList&lt;Product&gt; GetProducts(QueryOptions options)\r\n        {\r\n            return new PagedList&lt;Product&gt;(_context.Products.Include(e =&gt; e.Category), options);\r\n        }\r\n    }\r\n<\/pre>\n<p>\u041d\u043e\u0432\u0438\u0439 \u043c\u0435\u0442\u043e\u0434 \u043f\u043e\u0432\u0435\u0440\u0442\u0430\u0454 \u043a\u043e\u043b\u0435\u043a\u0446\u0456\u044e <strong>PagedList<\/strong> \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 <strong>Product<\/strong> \u0434\u043b\u044f \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438, \u0437\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u043e\u0457 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430\u043c\u0438.<\/p>\n<h2>\u041e\u043d\u043e\u0432\u043b\u0435\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>\u0414\u043b\u044f \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u0432 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440 <strong>Home<\/strong> \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0438 \u0440\u043e\u0437\u0431\u0438\u0432\u043a\u0438 \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438 \u0437\u043c\u0456\u043d\u0456\u0442\u044c, \u0434\u0456\u044e <strong>Index<\/strong>, \u0449\u043e\u0431 \u0432\u043e\u043d\u0430 \u043f\u0440\u0438\u0439\u043c\u0430\u043b\u0430 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0438, \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u0456 \u043f\u0440\u0438 \u0432\u0438\u0431\u043e\u0440\u0456 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438, \u0456 \u0432 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0456 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u043b\u0430 \u043d\u043e\u0432\u0438\u0439 \u043c\u0435\u0442\u043e\u0434 \u0441\u0445\u043e\u0432\u0438\u0449\u0430:<\/p>\n<pre class=\"lang:default decode:true \">public class HomeController : Controller\r\n    {\r\n        \/\/...\r\n        [HttpGet]\r\n        public IActionResult Index(QueryOptions options)\r\n        {\r\n            return View(_products.GetProducts(options));\r\n        }\r\n    }\r\n<\/pre>\n<p>\u0411\u0430\u0437\u043e\u0432\u0438\u0439 \u043a\u043b\u0430\u0441 \u043a\u043e\u043b\u0435\u043a\u0446\u0456\u0457 \u0434\u0430\u043d\u0438\u0445, \u0440\u043e\u0437\u0431\u0438\u0442\u0438\u0445 \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438, \u0440\u0435\u0430\u043b\u0456\u0437\u0443\u0454 \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 <strong>IEnumerable&lt;T&gt;<\/strong>, \u044f\u043a\u0438\u0439 \u0437\u0432\u043e\u0434\u0438\u0442\u044c \u0434\u043e \u043c\u0456\u043d\u0456\u043c\u0443\u043c\u0443 \u043e\u0431\u0441\u044f\u0433 \u0437\u043c\u0456\u043d, \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u0438\u0445 \u0434\u043b\u044f \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0438 \u0440\u043e\u0437\u0431\u0438\u0442\u0438\u0445 \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438 \u0434\u0430\u043d\u0438\u0445. \u0404\u0434\u0438\u043d\u0430 \u0437\u043c\u0456\u043d\u0430, \u044f\u043a\u0443 \u0437\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u044c\u0441\u044f \u0432\u043d\u0435\u0441\u0442\u0438 \u0432 \u043f\u043e\u0434\u0430\u043d\u043d\u044f \u0434\u043b\u044f \u0434\u0456\u0457 <strong>Index<\/strong> \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u0430 <strong>Home<\/strong>, \u043f\u043e\u0432&#8217;\u044f\u0437\u0430\u043d\u0430 \u0437 \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u043d\u044f\u043c \u0447\u0430\u0441\u0442\u043a\u043e\u0432\u043e\u0433\u043e \u043f\u043e\u0434\u0430\u043d\u043d\u044f \u0437 \u0434\u0435\u0442\u0430\u043b\u044f\u043c\u0438 \u0440\u043e\u0437\u0431\u0438\u0442\u0442\u044f \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438.<\/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-primary text-white text-center\"&gt;\u0422\u043e\u0432\u0430\u0440\u044b&lt;\/h3&gt;\r\n\r\n&lt;div class=\"text-center\"&gt;\r\n    @Html.Partial(\"Pages\", Model)\r\n&lt;\/div&gt;\r\n\r\n\r\n&lt;div class=\"container\"&gt;\r\n\r\n    &lt;div class=\"row\"&gt;\r\n        &lt;div class=\"col fw-bold\"&gt;\u041d\u0430\u0437\u0432\u0430\u043d\u0438\u0435&lt;\/div&gt;\r\n        &lt;div class=\"col fw-bold\"&gt;\u041a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u044f&lt;\/div&gt;\r\n        &lt;div class=\"col fw-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 fw-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\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.Name&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;\r\n                &lt;form asp-action=\"DeleteProduct\" method=\"post\"&gt;\r\n                    &lt;input type=\"hidden\" name=\"Id\" value=\"@product.Id\"&gt;\r\n                                    &lt;a asp-action=\"UpdateProduct\" asp-route-id=\"@product.Id\" class=\"btn btn-outline-primary\"&gt;\u0420\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c&lt;\/a&gt;\r\n&lt;button type=\"submit\" class=\"btn btn-outline-danger\"&gt;\u0423\u0434\u0430\u043b\u0438\u0442\u044c&lt;\/button&gt;\r\n                &lt;\/form&gt;\r\n            &lt;\/div&gt;\r\n        &lt;\/div&gt;\r\n    }\r\n\r\n    &lt;div class=\"text-cente r \u0440-2\"&gt;\r\n        &lt;a asp-action=\"UpdateProduct\" asp-route-id=\"0\" class=\"btn btn-primary\"&gt;\u0414\u043e\u0431\u0430\u0432\u0438\u0442\u044c&lt;\/a&gt;\r\n    &lt;\/div&gt;\r\n\r\n&lt;\/div&gt;\r\n<\/pre>\n<p>\u0429\u043e\u0431 \u0437\u0430\u0432\u0435\u0440\u0448\u0438\u0442\u0438 \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0443 \u0440\u043e\u0437\u0431\u0438\u0442\u0442\u044f \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438 \u0434\u043b\u044f \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 Product, \u0432\u0438\u0437\u043d\u0430\u0447\u0442\u0435 \u0447\u0430\u0441\u0442\u043a\u043e\u0432\u0435 \u043f\u043e\u0434\u0430\u043d\u043d\u044f, \u0434\u043e\u0434\u0430\u0432\u0448\u0438 \u0432 \u043f\u0430\u043f\u043a\u0443 <strong>Views \/ Shared<\/strong> \u0444\u0430\u0439\u043b \u043d\u0430 \u0456\u043c&#8217;\u044f <strong>Pages.cshtml<\/strong> \u0456\u0437 \u0442\u0430\u043a\u0438\u043c \u0432\u043c\u0456\u0441\u0442\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">&lt;form method=\"get\" class=\"form-inline m-3\" id=\"pageform\"&gt;\r\n    &lt;button name=\"options.CurrentPage\" value=\"@(Model.CurrentPage - 1)\"\r\n            class=\"btn btn-outline-primary @(!Model.HasPreviousPage ? \"disabled\" : \"\")\" type=\"submit\"&gt;\r\n        \u041d\u0430\u0437\u0430\u0434\r\n    &lt;\/button&gt;\r\n\r\n    @for (int i = 1; i &lt;= 3 &amp;&amp; i &lt;= Model.TotalPages; i++)\r\n    {\r\n        &lt;button name=\"options.CurrentPage\" value=\"@i\" type=\"submit\"\r\n            class=\"btn btn-outline-primary @(Model.CurrentPage == i ? \"active\" : \"\")\"&gt;\r\n            @i\r\n        &lt;\/button&gt;\r\n    }\r\n    @if (Model.CurrentPage &gt; 3 &amp;&amp; Model.TotalPages - Model.CurrentPage &gt;= 3)\r\n    {\r\n        @:...\r\n        &lt;button class=\"btn btn-outline-primary active\"&gt;@Model.CurrentPage&lt;\/button&gt;\r\n    }\r\n    @if (Model.TotalPages &gt; 3)\r\n    {\r\n        @:...\r\n        @for (int i = Math.Max(4, Model.TotalPages - 2); i &lt;= Model.TotalPages; i++)\r\n        {\r\n            &lt;button name=\"options.CurrentPage\" value=\"@i\" type=\"submit\"\r\n            class=\"btn btn-outline-primary @(Model.CurrentPage == i ? \"active\" : \"\")\"&gt;\r\n                @i\r\n            &lt;\/button&gt;\r\n        }\r\n    }\r\n    &lt;button name=\"options.CurrentPage\" value=\"@(Model.CurrentPage + 1)\" type=\"submit\"\r\n            class=\"btn btn-outline-primary @(!Model.HasNextPage ? \"disabled\":\"\")\"&gt;\r\n        \u0412\u043f\u0435\u0440\u0435\u0434\r\n    &lt;\/button&gt;\r\n  \r\n    &lt;select name=\"options.PageSize\" class=\"my-form-control\"&gt;\r\n        @foreach (int val in new int[] { 10, 25, 50, 100 })\r\n        {\r\n            &lt;option value=\"@val\" selected=\"@(Model.PageSize == val)\"&gt;@val&lt;\/option&gt;\r\n        }\r\n    &lt;\/select&gt;\r\n    &lt;input type=\"hidden\" name=\"options.CurrentPage\" value=\"1\" \/&gt;\r\n    &lt;button type=\"submit\" class=\"btn btn-outline-primary\"&gt;\u0418\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u0440\u0430\u0437\u043c\u0435\u0440 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b&lt;\/button&gt;\r\n&lt;\/form&gt;\r\n\r\n\r\n&lt;style&gt;\r\n    .my-form-control {\r\n        padding: 0.375rem 0.75rem;\r\n        font-size: 1rem;\r\n        font-weight: 400;\r\n        line-height: 1.5;\r\n        color: #212529;\r\n        background-color: #fff;\r\n        background-clip: padding-box;\r\n        border: 1px solid #ced4da;\r\n        -webkit-appearance: none;\r\n        -moz-appearance: none;\r\n        appearance: none;\r\n        border-radius: 0.25rem;\r\n        transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;\r\n    }\r\n&lt;\/style&gt;\r\n<\/pre>\n<p>\u041f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u041d\u0422\u041cL-\u0444\u043e\u0440\u043c\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f \u0434\u043b\u044f \u043e\u0442\u043f\u0440\u0430\u0432\u043a\u0438 \u041d\u0422\u0422\u0420\u00ad<\/p>\n<p>\u0437\u0430\u043f\u0438\u0442\u0456\u0432 GET \u043d\u0430\u0437\u0430\u0434 \u0434\u043e \u043c\u0435\u0442\u043e\u0434\u0443 \u0434\u0456\u0457 \u0441\u0442\u043e\u0440\u0456\u043d\u043e\u043a \u0434\u0430\u043d\u0438\u0445 \u0456 \u0434\u043b\u044f \u0437\u043c\u0456\u043d\u0438 \u0440\u043e\u0437\u043c\u0456\u0440\u0443 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438. \u0412\u0438\u0440\u0430\u0437\u0438 Razor \u0432\u0438\u0433\u043b\u044f\u0434\u0430\u044e\u0442\u044c \u0437\u0430\u043f\u043b\u0443\u0442\u0430\u043d\u0438\u043c\u0438, \u0430\u043b\u0435 \u0432\u043e\u043d\u0438 \u043f\u0440\u0438\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u044e\u0442\u044c \u043a\u043d\u043e\u043f\u043a\u0438 \u0441\u0442\u043e\u0440\u0456\u043d\u043e\u043a, \u0449\u043e \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0430\u044e\u0442\u044c\u0441\u044f \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456, \u0434\u043e \u043d\u0430\u044f\u0432\u043d\u043e\u0457 \u043a\u0456\u043b\u044c\u043a\u043e\u0441\u0442\u0456 \u0441\u0442\u043e\u0440\u0456\u043d\u043e\u043a.<\/p>\n<p>\u0422\u0430\u043a \u0441\u0430\u043c\u043e \u043e\u0431\u043e\u0432&#8217;\u044f\u0437\u043a\u043e\u0432\u043e \u0434\u043e\u0434\u0430\u0439\u0442\u0435 \u0434\u043e &lt;form&gt;,<strong> id=&#8221;pageform&#8221;<\/strong>, \u0432\u0456\u043d \u043d\u0430\u043c \u0441\u0442\u0430\u043d\u0435 \u0432 \u043d\u0430\u0433\u043e\u0434\u0456 \u0432 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u043e\u043c\u0443 \u0447\u0430\u0441\u0442\u043a\u043e\u0432\u043e\u043c\u0443 \u043f\u043e\u0434\u0430\u043d\u043d\u0456.<\/p>\n<p>\u041f\u0456\u0434 \u0447\u0430\u0441 \u0437\u0430\u043f\u0443\u0441\u043a\u0443 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0438 \u0441\u043f\u0438\u0441\u043e\u043a \u0442\u043e\u0432\u0430\u0440\u0456\u0432 \u0431\u0443\u0434\u0435 \u0440\u043e\u0437\u0431\u0438\u0442\u043e \u043d\u0430 10 \u0435\u043b\u0435\u043c\u0435\u043d\u0442\u0456\u0432, \u0437\u0430 \u044f\u043a\u0438\u043c\u0438 \u043c\u043e\u0436\u043d\u0430 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442\u0438 \u0437\u0430 \u0434\u043e\u043f\u043e\u043c\u043e\u0433\u043e\u044e \u043f\u043e\u0441\u043b\u0456\u0434\u043e\u0432\u043d\u043e\u0441\u0442\u0456 \u043a\u043d\u043e\u043f\u043e\u043a:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-242 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/2-5.png\" alt=\"asp.net core orderby\" width=\"1466\" height=\"849\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/2-5.png 1466w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/2-5-300x174.png 300w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/2-5-1024x593.png 1024w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/2-5-768x445.png 768w\" sizes=\"auto, (max-width: 1466px) 100vw, 1466px\" \/><\/p>\n<p>\u0412\u0438\u043a\u043e\u043d\u0430\u0439\u0442\u0435 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438 \u043f\u043e\u0441\u0442\u043e\u0440\u0456\u043d\u043a\u043e\u0432\u043e, \u0437\u043c\u0456\u043d\u0456\u0442\u044c \u043a\u0456\u043b\u044c\u043a\u0456\u0441\u0442\u044c \u0441\u0442\u043e\u0440\u0456\u043d\u043e\u043a \u0434\u043b\u044f \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u043d\u044f, \u043f\u0435\u0440\u0435\u0432\u0456\u0440\u0442\u0435 \u0440\u043e\u0431\u043e\u0442\u0443 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u0438.<\/p>\n<h2>\u0414\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0438 \u043f\u043e\u0448\u0443\u043a\u0443 \u0442\u0430 \u0432\u043f\u043e\u0440\u044f\u0434\u043a\u0443\u0432\u0430\u043d\u043d\u044f<\/h2>\n<p>\u0412\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u043d\u044f \u0441\u0442\u043e\u0440\u0456\u043d\u043e\u043a &#8211; \u0433\u0430\u0440\u043d\u0438\u0439 \u043f\u043e\u0447\u0430\u0442\u043e\u043a, \u0430\u043b\u0435 \u043a\u043e\u043d\u0446\u0435\u043d\u0442\u0440\u0443\u0432\u0430\u0442\u0438\u0441\u044f \u043d\u0430 \u0441\u043f\u0435\u0446\u0438\u0444\u0456\u0447\u043d\u043e\u043c\u0443 \u043d\u0430\u0431\u043e\u0440\u0456 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432, \u044f\u043a \u0456 \u0440\u0430\u043d\u0456\u0448\u0435, \u0432\u0430\u0436\u043a\u043e. \u0414\u043b\u044f \u043e\u0441\u043d\u0430\u0449\u0435\u043d\u043d\u044f \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0430 \u0456\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430\u043c\u0438 \u0437\u043d\u0430\u0445\u043e\u0434\u0436\u0435\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445, \u044f\u043a\u0456 \u0439\u043e\u0433\u043e \u0446\u0456\u043a\u0430\u0432\u043b\u044f\u0442\u044c, \u043c\u0438 \u0434\u043e\u0434\u0430\u043c\u043e \u0434\u043e \u0440\u043e\u0437\u0431\u0438\u0432\u043a\u0438 \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438 \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0443 \u0437\u043c\u0456\u043d\u0438 \u043f\u043e\u0440\u044f\u0434\u043a\u0443 \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u043d\u044f \u0456 \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u043f\u043e\u0448\u0443\u043a\u0443. \u0412\u0456\u0434\u043f\u0440\u0430\u0432\u043d\u043e\u044e \u0442\u043e\u0447\u043a\u043e\u044e \u0431\u0443\u0434\u0435 \u0440\u043e\u0437\u0448\u0438\u0440\u0435\u043d\u043d\u044f \u043a\u043b\u0430\u0441\u0443 <strong>PagedList<\/strong>, \u0449\u043e\u0431 \u0432\u0456\u043d \u043c\u0456\u0433 \u0432\u0438\u043a\u043e\u043d\u0443\u0432\u0430\u0442\u0438 \u043f\u043e\u0448\u0443\u043a \u0456 \u0432\u043f\u043e\u0440\u044f\u0434\u043a\u043e\u0432\u0443\u0432\u0430\u0442\u0438 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0438 \u0437\u0430\u043f\u0438\u0442\u0456\u0432 \u0456\u0437 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u043d\u043d\u044f\u043c \u0456\u043c\u0435\u043d \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0435\u0439, \u0430 \u043d\u0435 \u043b\u044f\u043c\u0431\u0434\u0430-\u0432\u0438\u0440\u0430\u0437\u0456\u0432, \u0449\u043e \u0432\u0438\u0431\u0438\u0440\u0430\u044e\u0442\u044c \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0456.<\/p>\n<p>\u0412\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u0442\u0430\u043a\u0438\u0445 \u043e\u043f\u0435\u0440\u0430\u0446\u0456\u0439 \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0432\u0430\u0442\u0438\u043c\u0435 \u0434\u0435\u0449\u043e \u0437\u0430\u043f\u043b\u0443\u0442\u0430\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0443, \u0430\u043b\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043c\u043e\u0436\u0435 \u0431\u0443\u0442\u0438 \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0430\u043d\u0438\u0439 \u0434\u043e \u0431\u0443\u0434\u044c-\u044f\u043a\u043e\u0433\u043e \u043a\u043b\u0430\u0441\u0443 \u043c\u043e\u0434\u0435\u043b\u0456 \u0434\u0430\u043d\u0438\u0445 \u0456 \u043b\u0435\u0433\u0448\u0435 \u0456\u043d\u0442\u0435\u0433\u0440\u0443\u0454\u0442\u044c\u0441\u044f \u0437 \u0447\u0430\u0441\u0442\u0438\u043d\u0430\u043c\u0438 ASP.NET \u0421ore MVC \u0434\u043e\u0434\u0430\u0442\u043a\u0430.<\/p>\n<p>\u0417\u043c\u0456\u043d\u0438\u043c\u043e \u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u043d\u044f \u043a\u043b\u0430\u0441\u0443 <strong>PagedList<\/strong> \u0442\u0430\u043a\u0438\u043c \u0447\u0438\u043d\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">public class PagedList&lt;T&gt; : List&lt;T&gt;\r\n    {\r\n        public PagedList(IQueryable&lt;T&gt; query, QueryOptions options = null)\r\n        {\r\n            CurrentPage = options.CurrentPage;\r\n            PageSize = options.PageSize;\r\n            Options = options;\r\n\r\n            if (options != null)\r\n            {\r\n                if (!string.IsNullOrEmpty(options.OrderPropertyName))\r\n                {\r\n                    query = Order(query, options.OrderPropertyName, options.DescendingOrder);\r\n                }\r\n                if (!string.IsNullOrEmpty(options.SearchPropertyName) &amp;&amp; !string.IsNullOrEmpty(options.SearchTerm))\r\n                {\r\n                    query = Search(query, options.SearchPropertyName, options.SearchTerm);\r\n                }\r\n            }\r\n\r\n            TotalPages = query.Count() \/ PageSize;\r\n            AddRange(query.Skip((CurrentPage - 1) * PageSize).Take(PageSize));\r\n        }\r\n        public int CurrentPage { get; set; }\r\n        public int PageSize { get; set; }\r\n        public int TotalPages { get; set; }\r\n        public QueryOptions Options { get; set; }\r\n\r\n        public bool HasPreviousPage =&gt; CurrentPage &gt; 1;\r\n        public bool HasNextPage =&gt; CurrentPage &lt; TotalPages;\r\n\r\n        private static IQueryable&lt;T&gt; Search(IQueryable&lt;T&gt; query, string propertyName, string searchTerm)\r\n        {\r\n            var parameter = Expression.Parameter(typeof(T), \"x\");\r\n            var source = propertyName.Split('.').Aggregate((Expression)parameter, Expression.Property);\r\n            var body = Expression.Call(source, \"Contains\", Type.EmptyTypes, Expression.Constant(searchTerm, typeof(string)));\r\n            var lambda = Expression.Lambda&lt;Func&lt;T, bool&gt;&gt;(body, parameter);\r\n            return query.Where(lambda);\r\n        }\r\n        private static IQueryable&lt;T&gt; Order(IQueryable&lt;T&gt; query, string propertyName, bool desc)\r\n        {\r\n            var parameter = Expression.Parameter(typeof(T), \"x\");\r\n            var source = propertyName.Split('.').Aggregate((Expression)parameter, Expression.Property);\r\n            var lambda = Expression.Lambda(typeof(Func&lt;,&gt;).MakeGenericType(typeof(T), source.Type), source, parameter);\r\n            return typeof(Queryable).GetMethods().Single(e =&gt; e.Name == (desc ? \"OrderByDescending\" : \"OrderBy\") &amp;&amp;\r\n            e.IsGenericMethodDefinition &amp;&amp;\r\n            e.GetGenericArguments().Length == 2 &amp;&amp;\r\n            e.GetParameters().Length == 2)\r\n            .MakeGenericMethod(typeof(T), source.Type)\r\n            .Invoke(null, new object[] { query, lambda }) as IQueryable&lt;T&gt;;\r\n        }\r\n    }\r\n<\/pre>\n<p>\u041f\u0435\u0440\u0435\u0439\u0434\u0435\u043c\u043e \u0432 \u043a\u043b\u0430\u0441 <strong>QueryOptions<\/strong>, \u0456 \u0437\u043c\u0456\u043d\u0438\u043c\u043e \u0439\u043e\u0433\u043e \u0432\u043c\u0456\u0441\u0442 \u0442\u0430\u043a\u0438\u043c \u0447\u0438\u043d\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">public class QueryOptions\r\n    {\r\n        public int CurrentPage { get; set; } = 1;\r\n        public int PageSize { get; set; } = 10;\r\n\r\n        public string OrderPropertyName { get; set; }\r\n        public bool DescendingOrder { get; set; }\r\n        public string SearchPropertyName { get; set; }\r\n        public string SearchTerm { get; set; }\r\n    }\r\n<\/pre>\n<p>\u0429\u043e\u0431 \u0441\u0442\u0432\u043e\u0440\u0438\u0442\u0438 \u0443\u0437\u0430\u0433\u0430\u043b\u044c\u043d\u0435\u043d\u0435 \u043f\u043e\u0434\u0430\u043d\u043d\u044f, \u044f\u043a\u0435 \u043f\u0440\u043e\u043f\u043e\u043d\u0443\u0432\u0430\u0442\u0438\u043c\u0435 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456 \u043c\u043e\u0436\u043b\u0438\u0432\u043e\u0441\u0442\u0456 \u043f\u043e\u0448\u0443\u043a\u0443 \u0442\u0430 \u0432\u043f\u043e\u0440\u044f\u0434\u043a\u0443\u0432\u0430\u043d\u043d\u044f, \u0434\u043e\u0434\u0430\u043c\u043e \u0432 \u043f\u0430\u043f\u043a\u0443 <strong>Views\/Shared<\/strong> \u0444\u0430\u0439\u043b \u043d\u0430 \u0456\u043c&#8217;\u044f <strong>PageOptions.cshtml<\/strong>, \u0437 \u0442\u0430\u043a\u0438\u043c \u0432\u043c\u0456\u0441\u0442\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">&lt;div class=\"container-fluid mt-2\"&gt;\r\n    &lt;div class=\"row m-1\"&gt;\r\n        &lt;div class=\"col\"&gt;&lt;\/div&gt;\r\n        &lt;div class=\"col-1\"&gt;\r\n            &lt;label class=\"col-from-label\"&gt;\u041f\u043e\u0438\u0441\u043a&lt;\/label&gt;\r\n        &lt;\/div&gt;\r\n        &lt;div class=\"col-3\"&gt;\r\n            &lt;select form=\"pageform\" name=\"options.searchpropertyname\" class=\"form-control\"&gt;\r\n                @foreach (string s in ViewBag.searches as string[])\r\n                {\r\n                    &lt;option value=\"@s\" selected=\"@(Model.Options.SearchPropertyName == s)\"&gt;\r\n                        @(s.IndexOf('.') == -1 ? s : s.Substring(0,s.IndexOf('.')))\r\n                    &lt;\/option&gt;\r\n                }\r\n            &lt;\/select&gt;\r\n        &lt;\/div&gt;\r\n        &lt;div class=\"col\"&gt;\r\n            &lt;input form=\"pageform\" class=\"form-control\" name=\"options.searchterm\" value=\"@Model.Options.SearchTerm\" \/&gt;\r\n        &lt;\/div&gt;\r\n        &lt;div class=\"col-1 text-right\"&gt;\r\n            &lt;button form=\"pageform\" class=\"btn btn-secondary\" type=\"submit\"&gt;\u041f\u043e\u0438\u0441\u043a&lt;\/button&gt;\r\n        &lt;\/div&gt;\r\n        &lt;div class=\"col\"&gt;&lt;\/div&gt;\r\n    &lt;\/div&gt;\r\n    &lt;div class=\"row m-1\"&gt;\r\n        &lt;div class=\"col\"&gt;&lt;\/div&gt;\r\n        &lt;div class=\"col-1\"&gt;\r\n            &lt;label class=\"col-form-label\"&gt;\u0421\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430&lt;\/label&gt;\r\n        &lt;\/div&gt;\r\n        &lt;div class=\"col-3\"&gt;\r\n            &lt;select form=\"pageform\" name=\"options.OrderPropertyName\" class=\"form-control\"&gt;\r\n                @foreach (string s in ViewBag.sorts as string[])\r\n                {\r\n                    &lt;option value=\"@s\" selected=\"@(Model.Options.OrderPropertyName == s)\"&gt;\r\n                        @(s.IndexOf('.') == -1 ? s : s.Substring(0,s.IndexOf('.')))\r\n                    &lt;\/option&gt;\r\n                }\r\n            &lt;\/select&gt;\r\n        &lt;\/div&gt;\r\n        &lt;div class=\"col btn-check form-check-inline\"&gt;\r\n            &lt;input form=\"pageform\" type=\"checkbox\" name=\"Options.DescendingOrder\" id=\"Options.DescendingOrder\" class=\"form-check-input\"\r\n                   value=\"true\" checked=\"@Model.Options.DescendingOrder\" \/&gt;\r\n            &lt;label class=\"form-check-label\"&gt;\u0421\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430 \u043f\u043e \u0443\u0431\u044b\u0432\u0430\u043d\u0438\u044e&lt;\/label&gt;\r\n        &lt;\/div&gt;\r\n        &lt;div class=\"col-1 text-right\"&gt;\r\n            &lt;button form=\"pageform\" class=\"btn btn-secondary\" type=\"submit\"&gt;\u0421\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430&lt;\/button&gt;\r\n        &lt;\/div&gt;\r\n        &lt;div class=\"col\"&gt;&lt;\/div&gt;\r\n    &lt;\/div&gt;\r\n&lt;\/div&gt;\r\n<\/pre>\n<p>\u041f\u043e\u0434\u0430\u043d\u043d\u044f \u0441\u043f\u0438\u0440\u0430\u0454\u0442\u044c\u0441\u044f \u043d\u0430 \u043c\u043e\u0436\u043b\u0438\u0432\u0456\u0441\u0442\u044c HTML 5 \u0430\u0441\u043e\u0446\u0456\u044e\u0432\u0430\u0442\u0438 \u0437 \u0444\u043e\u0440\u043c\u0430\u043c\u0438 \u0435\u043b\u0435\u043c\u0435\u043d\u0442\u0438, \u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u0456 \u0437\u0430 \u043c\u0435\u0436\u0430\u043c\u0438 \u0435\u043b\u0435\u043c\u0435\u043d\u0442\u0430 form. \u0426\u0435 \u0434\u0430\u0454 \u0437\u043c\u043e\u0433\u0443 \u0440\u043e\u0437\u0448\u0438\u0440\u0438\u0442\u0438 \u0444\u043e\u0440\u043c\u0443, \u044f\u043a\u0430 \u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u0430 \u0432 \u043f\u043e\u0434\u0430\u043d\u043d\u0456 Pages, \u0435\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c\u0438, \u0441\u043f\u0435\u0446\u0438\u0444\u0456\u0447\u043d\u0438\u043c\u0438 \u0434\u043b\u044f \u043f\u043e\u0448\u0443\u043a\u0443 \u0442\u0430 \u0432\u043f\u043e\u0440\u044f\u0434\u043a\u0443\u0432\u0430\u043d\u043d\u044f.<\/p>\n<p>\u0416\u043e\u0440\u0441\u0442\u043a\u043e \u043a\u043e\u0434\u0443\u0432\u0430\u0442\u0438 \u0441\u043f\u0438\u0441\u043e\u043a \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0435\u0439, \u044f\u043a\u0456 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447 \u043c\u043e\u0436\u0435 \u0437\u0430\u0434\u0456\u044f\u0442\u0438 \u0434\u043b\u044f \u043f\u043e\u0448\u0443\u043a\u0443 \u0430\u0431\u043e \u0432\u043f\u043e\u0440\u044f\u0434\u043a\u0443\u0432\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445 \u0443 \u043f\u043e\u0434\u0430\u043d\u043d\u0456, \u043d\u0435\u0431\u0430\u0436\u0430\u043d\u043e, \u0442\u043e\u043c\u0443 \u0437 \u043c\u0435\u0442\u043e\u044e \u043f\u0440\u043e\u0441\u0442\u043e\u0442\u0438 \u0442\u0430\u043a\u0456 \u0437\u043d\u0430\u0447\u0435\u043d\u043d\u044f \u043e\u0442\u0440\u0438\u043c\u0443\u044e\u0442\u044c \u0456\u0437 <strong>ViewBag<\/strong>. \u0420\u0456\u0448\u0435\u043d\u043d\u044f \u043d\u0435 \u0432\u0432\u0430\u0436\u0430\u0454\u0442\u044c\u0441\u044f \u0456\u0434\u0435\u0430\u043b\u044c\u043d\u0438\u043c, \u0430\u043b\u0435 \u0432\u043e\u043d\u043e \u0437\u0430\u0431\u0435\u0437\u043f\u0435\u0447\u0443\u0454 \u0432\u0438\u0441\u043e\u043a\u0443 \u0433\u043d\u0443\u0447\u043a\u0456\u0441\u0442\u044c \u0456 \u0434\u0430\u0454 \u0437\u043c\u043e\u0433\u0443 \u043b\u0435\u0433\u043a\u043e \u0430\u0434\u0430\u043f\u0442\u0443\u0432\u0430\u0442\u0438 \u043e\u0434\u0438\u043d \u0456 \u0442\u043e\u0439 \u0441\u0430\u043c\u0438\u0439 \u0432\u043c\u0456\u0441\u0442 \u0434\u043e \u0440\u0456\u0437\u043d\u0438\u0445 \u043f\u043e\u0434\u0430\u043d\u044c \u0456 \u0434\u0430\u043d\u0438\u0445.<\/p>\n<p>\u0429\u043e\u0431 \u0432\u0456\u0434\u043e\u0431\u0440\u0430\u0437\u0438\u0442\u0438 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456 \u0435\u043b\u0435\u043c\u0435\u043d\u0442\u0438, \u043f\u043e\u0432&#8217;\u044f\u0437\u0430\u043d\u0456 \u0437 \u043f\u043e\u0448\u0443\u043a\u043e\u043c \u0456 \u0432\u043f\u043e\u0440\u044f\u0434\u043a\u0443\u0432\u0430\u043d\u043d\u044f\u043c, \u043f\u043e\u0440\u044f\u0434 \u0437\u0456 \u0441\u043f\u0438\u0441\u043a\u043e\u043c \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 <strong>Product<\/strong>, \u0434\u043e\u0434\u0430\u043c\u043e \u0434\u043e \u043f\u043e\u0434\u0430\u043d\u043d\u044f <strong>Index<\/strong>, \u044f\u043a\u0435 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u043e\u043c \u041d\u043em\u0435, \u0442\u0430\u043a\u0438\u0439 \u0432\u043c\u0456\u0441\u0442:<\/p>\n<pre class=\"lang:default decode:true \">&lt;div class=\"text-center\"&gt;\r\n    @Html.Partial(\"Pages\", Model)\r\n\r\n    @{\r\n        ViewBag.searches = new string[] { \"Name\", \"Category.Name\" };\r\n        ViewBag.sorts = new string[] { \"Name\", \"Category.Name\", \"PurchasePrice\", \"RetailPrice\" };\r\n    }\r\n    @Html.Partial(\"PageOptions\", Model)\r\n&lt;\/div&gt;\r\n<\/pre>\n<p>\u0411\u043b\u043e\u043a \u043a\u043e\u0434\u0443 \u0432\u043a\u0430\u0437\u0443\u0454 \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0456 \u043a\u043b\u0430\u0441\u0443 <strong>Product<\/strong>, \u0437\u0430 \u0434\u043e\u043f\u043e\u043c\u043e\u0433\u043e\u044e \u044f\u043a\u0438\u0445 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447 \u043e\u0442\u0440\u0438\u043c\u0430\u0454 \u043c\u043e\u0436\u043b\u0438\u0432\u0456\u0441\u0442\u044c \u0448\u0443\u043a\u0430\u0442\u0438 \u0439 \u0443\u043f\u043e\u0440\u044f\u0434\u043a\u043e\u0432\u0443\u0432\u0430\u0442\u0438 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438 Product, \u0430 \u0432\u0438\u0440\u0430\u0437 <strong>@Html.Partial<\/strong> \u0432\u0456\u0437\u0443\u0430\u043b\u0456\u0437\u0443\u0454 \u0435\u043b\u0435\u043c\u0435\u043d\u0442\u0438 \u0434\u043b\u044f \u0442\u0430\u043a\u0438\u0445 \u0437\u0430\u0441\u043e\u0431\u0456\u0432.<\/p>\n<h2>\u041f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445 \u043a \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u044f\u043c<\/h2>\n<p>\u041f\u0440\u043e\u0446\u0435\u0441 \u0440\u043e\u0437\u043c\u0456\u0449\u0435\u043d\u043d\u044f \u0437\u0430\u0441\u043e\u0431\u0456\u0432 \u0434\u043b\u044f \u0440\u043e\u0437\u0431\u0438\u0442\u0442\u044f \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438, \u043f\u043e\u0448\u0443\u043a\u0443 \u0442\u0430 \u0441\u043e\u0440\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u043d\u0430 \u0441\u0432\u043e\u0457\u0445 \u043c\u0456\u0441\u0446\u044f\u0445 \u0431\u0443\u0432 \u043d\u0435\u043f\u0440\u043e\u0441\u0442\u0438\u043c, \u0430\u043b\u0435 \u0442\u0435\u043f\u0435\u0440, \u043a\u043e\u043b\u0438 \u0444\u0443\u043d\u0434\u0430\u043c\u0435\u043d\u0442 \u0433\u043e\u0442\u043e\u0432\u0438\u0439, \u0457\u0445 \u043c\u043e\u0436\u043d\u0430 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u0442\u0438 \u0434\u043e \u0456\u043d\u0448\u0438\u0445 \u0442\u0438\u043f\u0456\u0432 \u0434\u0430\u043d\u0438\u0445 \u0443 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u043d\u043a\u0443, \u044f\u043a-\u043e\u0442 \u043e\u0431&#8217;\u0454\u043a\u0442\u0438 <strong>Category<\/strong>.<\/p>\n<p>\u041d\u0430\u0441\u0430\u043c\u043f\u0435\u0440\u0435\u0434 \u043e\u043d\u043e\u0432\u0438\u043c\u043e \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 <strong>ICategory<\/strong> \u0456 \u043a\u043b\u0430\u0441\u0438 \u0440\u0435\u0430\u043b\u0456\u0437\u0430\u0446\u0456\u0457, \u0434\u043e\u0434\u0430\u0432\u0448\u0438 \u043c\u0435\u0442\u043e\u0434, \u044f\u043a\u0438\u0439 \u043f\u0440\u0438\u0439\u043c\u0430\u0454 \u043e\u0431&#8217;\u0454\u043a\u0442 <strong>QueryOptions<\/strong> \u0456 \u043f\u043e\u0432\u0435\u0440\u0442\u0430\u0454 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 <strong>PagedList<\/strong>:<\/p>\n<pre class=\"lang:default decode:true\">public interface ICategory\r\n    {\r\n        PagedList&lt;Category&gt; GetCategories(QueryOptions options);\r\n        IEnumerable&lt;Category&gt; GetAllCategories();\r\n        void AddCategory(Category category);\r\n        void UpdateCategory(Category category);\r\n        void DeleteCategory(Category category);\r\n    }\r\n<\/pre>\n<p>\u0422\u0435\u043f\u0435\u0440 \u0441\u0430\u043c \u043a\u043b\u0430\u0441 <strong>CategoryRepository<\/strong>:<\/p>\n<pre class=\"lang:default decode:true \">public class CategoryRepository : ICategory\r\n    {\r\n        \/\/...\r\n        public PagedList&lt;Category&gt; GetCategories(QueryOptions options)\r\n        {\r\n            return new PagedList&lt;Category&gt;(_context.Categories, options);   \r\n        }\r\n    }\r\n<\/pre>\n<p>\u0414\u043e\u0434\u0430\u043c\u043e \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 <strong>QueryOptions<\/strong> \u0434\u043e \u0434\u0456\u0457 Index \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u0430 <strong>CategoriesController<\/strong>, \u044f\u043a\u0438\u0439 \u043a\u0435\u0440\u0443\u0454 \u043e\u0431&#8217;\u0454\u043a\u0442\u0430\u043c\u0438 <strong>Category<\/strong>, \u0456 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u0454\u043c\u043e \u0439\u043e\u0433\u043e \u0434\u043b\u044f \u0437\u0430\u043f\u0438\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u0441\u0445\u043e\u0432\u0438\u0449\u0430:<\/p>\n<pre class=\"lang:default decode:true \">public class CategoriesController : Controller\r\n    {\r\n        \/\/...\r\n        public IActionResult Index(QueryOptions options)\r\n        {\r\n            return View(_categories.GetCategories(options));\r\n        }        \r\n    }\r\n<\/pre>\n<p>\u041d\u0430\u0440\u0435\u0448\u0442\u0456, \u043d\u0430\u0434\u0430\u043c\u043e \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456 \u043c\u043e\u0436\u043b\u0438\u0432\u0456\u0441\u0442\u044c \u0440\u043e\u0431\u043e\u0442\u0438 \u0456\u0437 \u0437\u0430\u0441\u043e\u0431\u0430\u043c\u0438, \u0434\u043e\u0434\u0430\u0432\u0448\u0438 \u0435\u043b\u0435\u043c\u0435\u043d\u0442\u0438 \u0432 \u043f\u043e\u0434\u0430\u043d\u043d\u044f <strong>Index<\/strong>, \u044f\u043a\u0435 \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0454\u0442\u044c\u0441\u044f \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u043e\u043c <strong>CategoriesController<\/strong>:<\/p>\n<pre class=\"lang:default decode:true \">&lt;div class=\"text-center\"&gt;\r\n    @Html.Partial(\"Pages\", Model)\r\n\r\n    @{\r\n        ViewBag.searches = new string[] { \"Name\", \"Description\" };\r\n        ViewBag.sorts = new string[] { \"Name\", \"Description\" };\r\n    }\r\n    @Html.Partial(\"PageOptions\", Model)\r\n&lt;\/div&gt;\r\n<\/pre>\n<p>\u0417\u0430\u043f\u0443\u0441\u0442\u0456\u0442\u044c \u0434\u043e\u0434\u0430\u0442\u043e\u043a, \u043f\u0435\u0440\u0435\u0439\u0434\u0456\u0442\u044c \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0443 <strong>\u041a\u0430\u0442\u0435\u0433\u043e\u0440\u0456\u0439<\/strong>. \u041d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u0446\u0456 \u043f\u0440\u0438\u0441\u0443\u0442\u043d\u0456\u0439 \u0441\u043f\u0438\u0441\u043e\u043a \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0456\u0439, \u0430 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447 \u043c\u043e\u0436\u0435 \u0432\u0438\u043a\u043e\u043d\u0443\u0432\u0430\u0442\u0438 \u0432 \u043d\u0438\u0445 \u043f\u043e\u0448\u0443\u043a \u0456 \u0432\u043f\u043e\u0440\u044f\u0434\u043a\u0443\u0432\u0430\u043d\u043d\u044f. \u041f\u0435\u0440\u0435\u0432\u0456\u0440\u0442\u0435 \u0432\u0441\u0435 \u0441\u0430\u043c\u0456:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-243 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3-5.png\" alt=\"asp.net core pagination\" width=\"1314\" height=\"834\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3-5.png 1314w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3-5-300x190.png 300w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3-5-1024x650.png 1024w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/3-5-768x487.png 768w\" sizes=\"auto, (max-width: 1314px) 100vw, 1314px\" \/><\/p>\n<h2><strong>\u0418\u043d\u0434\u0435\u043a\u0441\u0430\u0446\u0438\u044f \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445<\/strong><\/h2>\n<p>\u0414\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u0432 \u0411\u0414 \u0442\u0438\u0441\u044f\u0447\u0456 \u0442\u0435\u0441\u0442\u043e\u0432\u0438\u0445 \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 \u0432\u0438\u044f\u0432\u0438\u043b\u043e\u0441\u044f \u0434\u043e\u0441\u0442\u0430\u0442\u043d\u0456\u043c \u0434\u043b\u044f \u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0430\u0446\u0456\u0457 \u043e\u0431\u043c\u0435\u0436\u0435\u043d\u044c \u0441\u043f\u043e\u0441\u043e\u0431\u0443, \u044f\u043a\u0438\u043c \u0434\u0430\u043d\u0456 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u043b\u0438\u0441\u044f \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456, \u0430\u043b\u0435 \u0442\u0430\u043a\u043e\u0433\u043e \u043e\u0431\u0441\u044f\u0433\u0443 \u0434\u0430\u043d\u0438\u0445 \u043d\u0435 \u0432\u0438\u0441\u0442\u0430\u0447\u0438\u0442\u044c, \u0449\u043e\u0431 \u0432\u0438\u044f\u0432\u0438\u0442\u0438 \u043e\u0431\u043c\u0435\u0436\u0435\u043d\u043d\u044f \u0441\u0430\u043c\u043e\u0457 \u0411\u0414. \u0414\u043b\u044f \u0437&#8217;\u044f\u0441\u0443\u0432\u0430\u043d\u043d\u044f \u0435\u0444\u0435\u043a\u0442\u0443 \u0432\u0456\u0434 \u0440\u043e\u0431\u043e\u0442\u0438 \u0437 \u0432\u0435\u043b\u0438\u043a\u0438\u043c\u0438 \u043e\u0431\u0441\u044f\u0433\u0430\u043c\u0438 \u0434\u0430\u043d\u0438\u0445 \u0434\u043e\u0434\u0430\u043c\u043e \u0434\u043e \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440\u0430 PagedList \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0438, \u044f\u043a\u0456 \u0432\u0438\u043c\u0456\u0440\u044e\u044e\u0442\u044c \u0442\u0440\u0438\u0432\u0430\u043b\u0456\u0441\u0442\u044c \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u0437\u0430\u043f\u0438\u0442\u0443 \u0456 \u0432\u0438\u0432\u043e\u0434\u044f\u0442\u044c \u0432\u0438\u0442\u0440\u0430\u0447\u0435\u043d\u0438\u0439 \u0447\u0430\u0441 \u043d\u0430 \u043a\u043e\u043d\u0441\u043e\u043b\u044c. \u041f\u0435\u0440\u0435\u0439\u0434\u0435\u043c\u043e \u0432 \u043a\u043b\u0430\u0441 <strong>PagedList<\/strong> \u0456 \u0434\u043e\u043f\u043e\u0432\u043d\u0438\u043c\u043e \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440 \u0442\u0430\u043a\u0438\u043c \u043a\u043e\u0434\u043e\u043c:<\/p>\n<pre class=\"lang:default decode:true \">        {\r\n            CurrentPage = options.CurrentPage;\r\n            PageSize = options.PageSize;\r\n            Options = options;\r\n\r\n            if (options != null)\r\n            {\r\n                if (!string.IsNullOrEmpty(options.OrderPropertyName))\r\n                {\r\n                    query = Order(query, options.OrderPropertyName, options.DescendingOrder);\r\n                }\r\n                if (!string.IsNullOrEmpty(options.SearchPropertyName) &amp;&amp; !string.IsNullOrEmpty(options.SearchTerm))\r\n                {\r\n                    query = Search(query, options.SearchPropertyName, options.SearchTerm);\r\n                }\r\n            }\r\n\r\n            Stopwatch stopwatch = Stopwatch.StartNew();\r\n            Console.Clear();\r\n\r\n            TotalPages = query.Count() \/ PageSize;\r\n            AddRange(query.Skip((CurrentPage - 1) * PageSize).Take(PageSize));\r\n\r\n            Console.WriteLine($\"\u0412\u0440\u0435\u043c\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f: {stopwatch.ElapsedMilliseconds} \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434.\");\r\n        }\r\n<\/pre>\n<p>\u0417\u0430\u043f\u0443\u0441\u0442\u0456\u0442\u044c \u0434\u043e\u0434\u0430\u0442\u043e\u043a, \u043f\u0435\u0440\u0435\u0439\u0434\u0456\u0442\u044c \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0443 &#8220;\u041f\u043e\u0447\u0430\u0442\u043a\u043e\u0432\u0456 \u0434\u0430\u043d\u0456&#8221; \u0456 \u0437\u0430\u043f\u043e\u0432\u043d\u0456\u0442\u044c \u0411\u0414 \u043f\u043e\u0442\u0440\u0456\u0431\u043d\u043e\u044e \u043a\u0456\u043b\u044c\u043a\u0456\u0441\u0442\u044e \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432. \u041f\u0456\u0441\u043b\u044f \u0446\u044c\u043e\u0433\u043e, \u043f\u0435\u0440\u0435\u0439\u0434\u0456\u0442\u044c \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0443 \u0442\u043e\u0432\u0430\u0440\u0456\u0432, \u0432\u0438\u0431\u0435\u0440\u0456\u0442\u044c \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u0456\u0441\u0442\u044c <strong>PurchasePrice<\/strong> \u0434\u043b\u044f \u0441\u043e\u0440\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u0456 \u0432\u0438\u043a\u043e\u043d\u0430\u0439\u0442\u0435 \u0439\u043e\u0433\u043e.<\/p>\n<p>\u042f\u043a\u0449\u043e \u0432\u0438 \u043f\u0435\u0440\u0435\u0433\u043b\u044f\u043d\u0435\u0442\u0435 \u0436\u0443\u0440\u043d\u0430\u043b\u044c\u043d\u0456 \u043f\u043e\u0432\u0456\u0434\u043e\u043c\u043b\u0435\u043d\u043d\u044f, \u0437\u0433\u0435\u043d\u0435\u0440\u043e\u0432\u0430\u043d\u0456 \u0434\u043e\u0434\u0430\u0442\u043a\u043e\u043c, \u0442\u043e \u043f\u043e\u043c\u0456\u0442\u0438\u0442\u0435 \u0437\u0430\u043f\u0438\u0442\u0438, \u0449\u043e \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0443\u0432\u0430\u043b\u0438\u0441\u044f \u0434\u043b\u044f \u043e\u0442\u0440\u0438\u043c\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445, \u0430 \u0442\u0430\u043a\u043e\u0436 \u0447\u0430\u0441 \u0457\u0445\u043d\u044c\u043e\u0433\u043e \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f:<\/p>\n<pre class=\"lang:default decode:true \">SELECT[t].[Id], [t].[CategoryId], [t].[Name], [t].[PurchasePrice], [t].[RetailPrice], [c].[Id], [c].[Description], [c].[Name]\r\nFROM (\r\nSELECT[p].[Id], [p].[CategoryId], [p].[Name], [p].[PurchasePrice], [p].[RetailPrice]\r\n          FROM [Products] AS [p]\r\n          ORDER BY [p].[PurchasePrice]\r\n          OFFSET @__p_0 ROWS FETCH NEXT @__p_1 ROWS ONLY\r\n) AS[t]\r\n      INNER JOIN[Categories] AS [c] ON[t].[CategoryId] = [c].[Id]\r\n      ORDER BY[t].[PurchasePrice]\r\n\r\n\u0412\u0440\u0435\u043c\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f: 83 \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434.\r\n<\/pre>\n<p>\u0423 \u0442\u0430\u043a\u0456\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0456 \u043d\u0430\u0432\u0435\u0434\u0435\u043d\u043e \u043f\u043e\u043a\u0430\u0437\u043d\u0438\u043a\u0438 \u0447\u0430\u0441\u0443, \u044f\u043a\u0438\u0439 \u0437\u0430\u0439\u043d\u044f\u043b\u043e \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u0446\u0438\u0445 \u0437\u0430\u043f\u0438\u0442\u0456\u0432 \u043d\u0430 \u043c\u043e\u0457\u0439 \u043c\u0430\u0448\u0438\u043d\u0456 \u0440\u043e\u0437\u0440\u043e\u0431\u043a\u0438, \u0434\u043b\u044f \u0440\u0456\u0437\u043d\u0438\u0445 \u043e\u0431\u0441\u044f\u0433\u0456\u0432 \u043f\u043e\u0447\u0430\u0442\u043a\u043e\u0432\u0438\u0445 \u0434\u0430\u043d\u0438\u0445. \u0412\u0438 \u043c\u043e\u0436\u0435\u0442\u0435 \u043e\u0442\u0440\u0438\u043c\u0430\u0442\u0438 \u0456\u043d\u0448\u0456 \u043f\u043e\u043a\u0430\u0437\u043d\u0438\u043a\u0438, \u0430\u043b\u0435 \u0432\u0430\u0436\u043b\u0438\u0432\u043e \u0437\u0430\u0437\u043d\u0430\u0447\u0438\u0442\u0438, \u0449\u043e \u0437\u0456 \u0437\u0440\u043e\u0441\u0442\u0430\u043d\u043d\u044f\u043c \u043e\u0431\u0441\u044f\u0433\u0443 \u0434\u0430\u043d\u0438\u0445 \u0432\u043e\u043d\u0438 \u0437\u0431\u0456\u043b\u044c\u0448\u0443\u044e\u0442\u044c\u0441\u044f.<\/p>\n<table>\n<tbody>\n<tr>\n<td width=\"319\"><strong>\u041a\u0456\u043b\u044c\u043a\u0456\u0441\u0442\u044c \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432<\/strong><\/td>\n<td width=\"319\"><strong>\u0427\u0430\u0441<\/strong><\/td>\n<\/tr>\n<tr>\n<td width=\"319\">1000<\/td>\n<td width=\"319\">86 \u043c\u0441<\/td>\n<\/tr>\n<tr>\n<td width=\"319\">10 000<\/td>\n<td width=\"319\">104 \u043c\u0441<\/td>\n<\/tr>\n<tr>\n<td width=\"319\">100 000<\/td>\n<td width=\"319\">314 \u043c\u0441<\/td>\n<\/tr>\n<tr>\n<td width=\"319\">1\u00a0000 000<\/td>\n<td width=\"319\">2578 \u043c\u0441<\/td>\n<\/tr>\n<tr>\n<td width=\"319\">2\u00a0000 000<\/td>\n<td width=\"319\">5156 \u043c\u0441<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h2>\u0421\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0442\u0430 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f \u0456\u043d\u0434\u0435\u043a\u0441\u0456\u0432<\/h2>\n<p>\u041e\u0434\u043d\u0430 \u0437 \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u0456\u0437 \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0438\u0432\u043d\u0456\u0441\u0442\u044e \u0432\u0438\u043d\u0438\u043a\u0430\u0454 \u0447\u0435\u0440\u0435\u0437 \u0442\u0435, \u0449\u043e \u0441\u0435\u0440\u0432\u0435\u0440\u0443 \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445 \u0434\u043e\u0432\u043e\u0434\u0438\u0442\u044c\u0441\u044f \u0434\u043e\u0441\u043b\u0456\u0434\u0436\u0443\u0432\u0430\u0442\u0438 \u0431\u0430\u0433\u0430\u0442\u043e \u0440\u044f\u0434\u043a\u0456\u0432 \u0434\u0430\u043d\u0438\u0445 \u0443 \u043f\u043e\u0448\u0443\u043a\u0443 \u0434\u0430\u043d\u0438\u0445, \u043d\u0435\u043e\u0431\u0445\u0456\u0434\u043d\u0438\u0445 \u0434\u043e\u0434\u0430\u0442\u043a\u0443. \u0415\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u0438\u0439 \u0441\u043f\u043e\u0441\u0456\u0431 \u0441\u043a\u043e\u0440\u043e\u0447\u0435\u043d\u043d\u044f \u043e\u0431\u0441\u044f\u0433\u0443 \u0440\u043e\u0431\u043e\u0442\u0438, \u0432\u0438\u043a\u043e\u043d\u0443\u0432\u0430\u043d\u043e\u0457 \u0441\u0435\u0440\u0432\u0435\u0440\u043e\u043c \u0431\u0430\u0437 \u0434\u0430\u043d\u0438\u0445, \u043f\u0435\u0440\u0435\u0434\u0431\u0430\u0447\u0430\u0454 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0456\u043d\u0434\u0435\u043a\u0441\u0456\u0432, \u044f\u043a\u0456 \u043f\u0440\u0438\u0441\u043a\u043e\u0440\u044e\u044e\u0442\u044c \u0437\u0430\u043f\u0438\u0442\u0438, \u0430\u043b\u0435 \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u044e\u0442\u044c \u043f\u0435\u0432\u043d\u043e\u0433\u043e \u0447\u0430\u0441\u0443 \u043d\u0430 \u043f\u043e\u0447\u0430\u0442\u043a\u043e\u0432\u0443 \u043f\u0456\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0443 \u0442\u0430 \u043d\u0435\u0432\u0435\u043b\u0438\u043a\u043e\u0457 \u0434\u043e\u0434\u0430\u0442\u043a\u043e\u0432\u043e\u0457 \u0440\u043e\u0431\u043e\u0442\u0438 \u043f\u0456\u0441\u043b\u044f \u043a\u043e\u0436\u043d\u043e\u0433\u043e \u043e\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044f. \u0429\u043e \u0441\u0442\u043e\u0441\u0443\u0454\u0442\u044c\u0441\u044f \u0434\u043e\u0434\u0430\u0442\u043a\u0430 GameStore, \u0442\u043e \u043c\u0438 \u0434\u043e\u0434\u0430\u043c\u043e \u0456\u043d\u0434\u0435\u043a\u0441\u0438 \u0434\u043b\u044f \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0435\u0439 \u043a\u043b\u0430\u0441\u0456\u0432 <strong>Product<\/strong> \u0456 <strong>Category<\/strong>, \u044f\u043a\u0456 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447 \u0437\u043c\u043e\u0436\u0435 \u0432\u0438\u043a\u043e\u0440\u0438\u0441\u0442\u043e\u0432\u0443\u0432\u0430\u0442\u0438 \u043f\u0456\u0434 \u0447\u0430\u0441 \u043f\u043e\u0448\u0443\u043a\u0443 \u0430\u0431\u043e \u0432\u043f\u043e\u0440\u044f\u0434\u043a\u0443\u0432\u0430\u043d\u043d\u044f \u0434\u0430\u043d\u0438\u0445.<\/p>\n<p>\u0421\u0442\u0432\u043e\u0440\u0438\u043c\u043e \u0456\u043d\u0434\u0435\u043a\u0441\u0438 \u0432 \u043a\u043b\u0430\u0441\u0456 <strong>ApplicationContext<\/strong> \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0443 \u0411\u0414, \u0434\u043b\u044f \u0446\u044c\u043e\u0433\u043e \u0434\u043e\u0434\u0430\u043c\u043e \u043c\u0435\u0442\u043e\u0434 <strong>OnModelCreating<\/strong> \u044f\u043a \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u043e \u0432 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u043e\u043c\u0443 \u043a\u043e\u0434\u0456:<\/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        public DbSet&lt;Category&gt; Categories { get; set; }\r\n\r\n        public DbSet&lt;Order&gt; Orders { get; set; }\r\n        public DbSet&lt;OrderLine&gt; OrderLines { get; set; }\r\n\r\n        protected override void OnModelCreating(ModelBuilder modelBuilder)\r\n        {\r\n            modelBuilder.Entity&lt;Product&gt;().HasIndex(e =&gt; e.Name);\r\n            modelBuilder.Entity&lt;Product&gt;().HasIndex(e =&gt; e.PurchasePrice);\r\n            modelBuilder.Entity&lt;Product&gt;().HasIndex(e =&gt; e.RetailPrice);\r\n            modelBuilder.Entity&lt;Category&gt;().HasIndex(e =&gt; e.Name);\r\n            modelBuilder.Entity&lt;Category&gt;().HasIndex(e =&gt; e.Description);\r\n        }\r\n    }\r\n<\/pre>\n<p>\u041c\u0435\u0442\u043e\u0434 <strong>OnModelCreating()<\/strong> \u043f\u0435\u0440\u0435\u0432\u0438\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u0434\u043b\u044f \u043d\u0430\u043b\u0430\u0448\u0442\u0443\u0432\u0430\u043d\u043d\u044f \u043c\u043e\u0434\u0435\u043b\u0456 \u0434\u0430\u043d\u0438\u0445 \u0456\u0437 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f\u043c \u0437\u0430\u0441\u043e\u0431\u0443 Fluent API \u0437 Entity Framework Core. \u0406\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 Fluent API \u0434\u0430\u0454 \u0437\u043c\u043e\u0433\u0443 \u043f\u0435\u0440\u0435\u0432\u0438\u0437\u043d\u0430\u0447\u0430\u0442\u0438 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u0456 \u043b\u0456\u043d\u0456\u0457 \u043f\u043e\u0432\u0435\u0434\u0456\u043d\u043a\u0438 Entity Framework Core \u0456 \u043e\u0442\u0440\u0438\u043c\u0443\u0432\u0430\u0442\u0438 \u0434\u043e\u0441\u0442\u0443\u043f \u0434\u043e \u0440\u043e\u0437\u0448\u0438\u0440\u0435\u043d\u0438\u0445 \u043c\u043e\u0436\u043b\u0438\u0432\u043e\u0441\u0442\u0435\u0439, \u0442\u0430\u043a\u0438\u0445 \u044f\u043a \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0456\u043d\u0434\u0435\u043a\u0441\u0456\u0432. \u0423 \u0446\u044c\u043e\u043c\u0443 \u0432\u0438\u043f\u0430\u0434\u043a\u0443 \u0441\u0442\u0432\u043e\u0440\u044e\u044e\u0442\u044c\u0441\u044f \u0456\u043d\u0434\u0435\u043a\u0441\u0438 \u0434\u043b\u044f \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0435\u0439 Name, PurchasePrice \u0456 RetailPrice \u043a\u043b\u0430\u0441\u0443 Product, \u0430 \u0442\u0430\u043a\u043e\u0436 \u0434\u043b\u044f \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0435\u0439 Name \u0456 Description \u043a\u043b\u0430\u0441\u0443 Category.<\/p>\n<p>\u0421\u0442\u0432\u043e\u0440\u044e\u0432\u0430\u0442\u0438 \u0456\u043d\u0434\u0435\u043a\u0441\u0438 \u0434\u043b\u044f \u0432\u043b\u0430\u0441\u0442\u0438\u0432\u043e\u0441\u0442\u0435\u0439 \u043f\u0435\u0440\u0432\u0438\u043d\u043d\u0438\u0445 \u0430\u0431\u043e \u0437\u043e\u0432\u043d\u0456\u0448\u043d\u0456\u0445 \u043a\u043b\u044e\u0447\u0456\u0432 \u043d\u0435 \u043f\u043e\u0442\u0440\u0456\u0431\u043d\u043e, \u043e\u0441\u043a\u0456\u043b\u044c\u043a\u0438 \u0456\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0415ntity Framework Core \u0437\u0430 \u0437\u0430\u043c\u043e\u0432\u0447\u0443\u0432\u0430\u043d\u043d\u044f\u043c \u0441\u0442\u0432\u043e\u0440\u044e\u0454 \u0457\u0445 \u0441\u0430\u043c\u043e\u0441\u0442\u0456\u0439\u043d\u043e.<\/p>\n<p>\u0421\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0456\u043d\u0434\u0435\u043a\u0441\u0456\u0432 \u0432\u0438\u043c\u0430\u0433\u0430\u0454 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u043d\u043e\u0432\u043e\u0457 \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u0457 \u0442\u0430 \u0457\u0457 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f \u0434\u043e \u0411\u0414.<\/p>\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 AddIndexes<\/pre>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-244 aligncenter\" src=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/4-4.png\" alt=\"asp.net core add migration\" width=\"401\" height=\"204\" srcset=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/4-4.png 401w, https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/4-4-300x153.png 300w\" sizes=\"auto, (max-width: 401px) 100vw, 401px\" \/><\/p>\n<p>\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<\/p>\n<p>P.S. \u0417\u0430 \u043d\u0430\u044f\u0432\u043d\u043e\u0441\u0442\u0456 \u0432 \u0411\u0414 \u0432\u0435\u043b\u0438\u043a\u043e\u0433\u043e \u043e\u0431\u0441\u044f\u0433\u0443 \u0434\u0430\u043d\u0438\u0445 \u0437\u0430\u0441\u0442\u043e\u0441\u0443\u0432\u0430\u043d\u043d\u044f \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u0457, \u0449\u043e \u0441\u0442\u0432\u043e\u0440\u044e\u0454 \u0456\u043d\u0434\u0435\u043a\u0441\u0438, \u043c\u043e\u0436\u0435 \u0437\u0430\u0439\u043d\u044f\u0442\u0438 \u0434\u0435\u044f\u043a\u0438\u0439 \u0447\u0430\u0441, \u0442\u043e\u043c\u0443 \u0449\u043e \u0432\u0441\u0456 \u043d\u0430\u044f\u0432\u043d\u0456 \u0434\u0430\u043d\u0456 \u043c\u0430\u044e\u0442\u044c \u0431\u0443\u0442\u0438 \u0434\u043e\u0434\u0430\u043d\u0456 \u0432 \u0456\u043d\u0434\u0435\u043a\u0441. \u041f\u0435\u0440\u0435\u0434 \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f\u043c \u043a\u043e\u043c\u0430\u043d\u0434 \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u0457, \u043c\u043e\u0436\u043b\u0438\u0432\u043e, \u0443 \u0432\u0430\u0441 \u0432\u0438\u043d\u0438\u043a\u043d\u0435 \u0431\u0430\u0436\u0430\u043d\u043d\u044f \u0441\u043a\u043e\u0440\u0438\u0441\u0442\u0430\u0442\u0438\u0441\u044f \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u0440\u043e\u043c Seed \u0434\u043b\u044f \u0441\u043a\u043e\u0440\u043e\u0447\u0435\u043d\u043d\u044f \u043e\u0431\u0441\u044f\u0433\u0443 \u0442\u0435\u0441\u0442\u043e\u0432\u0438\u0445 \u0434\u0430\u043d\u0438\u0445.<\/p>\n<p>\u041f\u0456\u0441\u043b\u044f \u0442\u043e\u0433\u043e, \u044f\u043a \u043c\u0456\u0433\u0440\u0430\u0446\u0456\u044e \u0437\u0430\u0441\u0442\u043e\u0441\u043e\u0432\u0430\u043d\u043e, \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0443\u0441\u0442\u0456\u0442\u044c \u0434\u043e\u0434\u0430\u0442\u043e\u043a \u0456 \u043f\u043e\u0432\u0442\u043e\u0440\u0456\u0442\u044c \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u0456 \u0440\u0430\u043d\u0456\u0448\u0435 \u0442\u0435\u0441\u0442\u043e\u0432\u0456 \u0437\u0430\u043f\u0438\u0442\u0438, \u0449\u043e\u0431 \u043f\u043e\u0434\u0438\u0432\u0438\u0442\u0438\u0441\u044f, \u044f\u043a \u0456\u043d\u0434\u0435\u043a\u0441\u0438 \u0432\u043f\u043b\u0438\u043d\u0443\u043b\u0438 \u043d\u0430 \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0438\u0432\u043d\u0456\u0441\u0442\u044c. \u0423 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u0456\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0456 \u043d\u0430\u0432\u0435\u0434\u0435\u043d\u043e \u043f\u043e\u043a\u0430\u0437\u043d\u0438\u043a\u0438 \u0447\u0430\u0441\u0443, \u044f\u043a\u0438\u0439 \u0437\u0430\u0439\u043d\u044f\u043b\u043e \u0432\u0438\u043a\u043e\u043d\u0430\u043d\u043d\u044f \u0446\u0438\u0445 \u0437\u0430\u043f\u0438\u0442\u0456\u0432 \u0437 \u0456\u043d\u0434\u0435\u043a\u0441\u0430\u043c\u0438 \u043d\u0430 \u043c\u043e\u0457\u0439 \u043c\u0430\u0448\u0438\u043d\u0456 \u0440\u043e\u0437\u0440\u043e\u0431\u043a\u0438, \u0434\u043b\u044f \u0440\u0456\u0437\u043d\u0438\u0445 \u043e\u0431\u0441\u044f\u0433\u0456\u0432 \u043f\u043e\u0447\u0430\u0442\u043a\u043e\u0432\u0438\u0445 \u0434\u0430\u043d\u0438\u0445.<\/p>\n<table>\n<tbody>\n<tr>\n<td width=\"319\"><strong>\u041a\u0456\u043b\u044c\u043a\u0456\u0441\u0442\u044c \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432<\/strong><\/td>\n<td width=\"319\"><strong>\u0427\u0430\u0441<\/strong><\/td>\n<\/tr>\n<tr>\n<td width=\"319\">1000<\/td>\n<td width=\"319\">48 \u043c\u0441<\/td>\n<\/tr>\n<tr>\n<td width=\"319\">10 000<\/td>\n<td width=\"319\">61 \u043c\u0441<\/td>\n<\/tr>\n<tr>\n<td width=\"319\">100 000<\/td>\n<td width=\"319\">104 \u043c\u0441<\/td>\n<\/tr>\n<tr>\n<td width=\"319\">1\u00a0000 000<\/td>\n<td width=\"319\">287 \u043c\u0441<\/td>\n<\/tr>\n<tr>\n<td width=\"319\">2\u00a0000 000<\/td>\n<td width=\"319\">301 \u043c\u0441<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h2>\u041f\u0456\u0434\u0441\u0443\u043c\u043e\u043a<\/h2>\n<p>\u0423 \u0441\u0442\u0430\u0442\u0442\u0456 \u0431\u0443\u043b\u043e \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u043e, \u044f\u043a\u0438\u043c \u0447\u0438\u043d\u043e\u043c \u0430\u0434\u0430\u043f\u0442\u0443\u0432\u0430\u0442\u0438 \u0434\u043e\u0434\u0430\u0442\u043e\u043a GameStore \u0434\u043b\u044f \u0440\u043e\u0431\u043e\u0442\u0438 \u0437 \u0431\u0456\u043b\u044c\u0448\u0438\u043c\u0438 \u043e\u0431\u0441\u044f\u0433\u0430\u043c\u0438 \u0434\u0430\u043d\u0438\u0445. \u041c\u0438 \u0434\u043e\u0434\u0430\u043b\u0438 \u0434\u043e \u043d\u044c\u043e\u0433\u043e \u043f\u0456\u0434\u0442\u0440\u0438\u043c\u043a\u0443 \u0440\u043e\u0437\u0431\u0438\u0442\u0442\u044f \u043d\u0430 \u0441\u0442\u043e\u0440\u0456\u043d\u043a\u0438, \u0443\u043f\u043e\u0440\u044f\u0434\u043a\u0443\u0432\u0430\u043d\u043d\u044f \u0442\u0430 \u043f\u043e\u0448\u0443\u043a\u0443 \u0434\u0430\u043d\u0438\u0445, \u0449\u043e \u0434\u0430\u0454 \u0437\u043c\u043e\u0433\u0443 \u043a\u043e\u0440\u0438\u0441\u0442\u0443\u0432\u0430\u0447\u0435\u0432\u0456 \u043c\u0430\u0442\u0438 \u0441\u043f\u0440\u0430\u0432\u0443 \u0437 \u043a\u0435\u0440\u043e\u0432\u0430\u043d\u043e\u044e \u043a\u0456\u043b\u044c\u043a\u0456\u0441\u0442\u044e \u043e\u0431&#8217;\u0454\u043a\u0442\u0456\u0432 \u0437\u0430 \u0440\u0430\u0437. \u041a\u0440\u0456\u043c \u0442\u043e\u0433\u043e, \u0437\u0430 \u0434\u043e\u043f\u043e\u043c\u043e\u0433\u043e\u044e Fluent \u0410\u0420I \u0431\u0443\u043b\u043e \u043d\u0430\u043b\u0430\u0448\u0442\u043e\u0432\u0430\u043d\u043e \u043c\u043e\u0434\u0435\u043b\u044c \u0434\u0430\u043d\u0438\u0445 \u0456 \u0434\u043e\u0434\u0430\u043d\u043e \u0456\u043d\u0434\u0435\u043a\u0441\u0438 \u0434\u043b\u044f \u043f\u043e\u043b\u0456\u043f\u0448\u0435\u043d\u043d\u044f \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0438\u0432\u043d\u043e\u0441\u0442\u0456 \u0437\u0430\u043f\u0438\u0442\u0456\u0432. \u0423 \u043d\u0430\u0441\u0442\u0443\u043f\u043d\u043e\u043c\u0443 \u0440\u043e\u0437\u0434\u0456\u043b\u0456 \u0434\u043e \u0434\u043e\u0434\u0430\u0442\u043a\u0430 GameStore \u0431\u0443\u0434\u0435 \u0434\u043e\u0434\u0430\u043d\u043e \u0456\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u0434\u043b\u044f \u043f\u043e\u043a\u0443\u043f\u0446\u0456\u0432.<\/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-4\">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=\"rTLU7PLCwy\"><p><a href=\"https:\/\/dijix.com.ua\/blog\/uk\/optimizacziya-izobrazhenij-dlya-sajta-na-c\/\">\u041e\u043f\u0442\u0438\u043c\u0456\u0437\u0430\u0446\u0456\u044f \u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u044c \u0434\u043b\u044f \u0441\u0430\u0439\u0442\u0443 \u043d\u0430 C#<\/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;\u041e\u043f\u0442\u0438\u043c\u0456\u0437\u0430\u0446\u0456\u044f \u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u044c \u0434\u043b\u044f \u0441\u0430\u0439\u0442\u0443 \u043d\u0430 C#&#8221; &#8212; Dijix -  \u0411\u043b\u043e\u0433\" src=\"https:\/\/dijix.com.ua\/blog\/uk\/optimizacziya-izobrazhenij-dlya-sajta-na-c\/embed\/#?secret=DBGdgkZz8T#?secret=rTLU7PLCwy\" data-secret=\"rTLU7PLCwy\" 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\u0456\u0439 \u0441\u0442\u0430\u0442\u0442\u0456, \u043c\u0438 \u043f\u0440\u043e\u0434\u043e\u0432\u0436\u0438\u043c\u043e \u043f\u0438\u0441\u0430\u0442\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core \u0456 Entity Framework Core. \u0423 \u0442\u0440\u0435\u0442\u0456\u0439 \u0447\u0430\u0441\u0442\u0438\u043d\u0456 \u043c\u0438 \u0440\u043e\u0437\u0448\u0438\u0440\u0438\u043b\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u0437\u0430 \u0440\u0430\u0445\u0443\u043d\u043e\u043a \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043d\u043e\u0432\u0438\u0445 \u043a\u043b\u0430\u0441\u0456\u0432&#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-4\/\">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\u0438\u043d\u0430 4<\/span><\/a><\/div>\n","protected":false},"author":1,"featured_media":245,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_locale":"uk","_original_post":"https:\/\/dijix.com.ua\/blog\/?p=240","footnotes":""},"categories":[8],"tags":[],"class_list":["post-379","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\u0438\u043d\u0430 4 - Dijix - \u0411\u043b\u043e\u0433<\/title>\r\n<meta name=\"description\" content=\"\u0423 \u0446\u0456\u0439 \u0441\u0442\u0430\u0442\u0442\u0456, \u043c\u0438 \u043f\u0440\u043e\u0434\u043e\u0432\u0436\u0438\u043c\u043e \u043f\u0438\u0441\u0430\u0442\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core. \u0423 \u0442\u0440\u0435\u0442\u0456\u0439 \u0447\u0430\u0441\u0442\u0438\u043d\u0456 \u043c\u0438 \u0440\u043e\u0437\u0448\u0438\u0440\u0438\u043b\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u0437\u0430 \u0440\u0430\u0445\u0443\u043d\u043e\u043a \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043d\u043e\u0432\u0438\u0445 \u043a\u043b\u0430\u0441\u0456\u0432 \u0456 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0432\u0456\u0434\u043d\u043e\u0441\u0438\u043d.\" \/>\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-4\/\" \/>\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\u0438\u043d\u0430 4 - 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-4\/\" \/>\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-03T13:18:02+00:00\" \/>\r\n<meta property=\"article:modified_time\" content=\"2023-02-03T13:29:53+00:00\" \/>\r\n<meta property=\"og:image\" content=\"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1-6.png\" \/>\r\n\t<meta property=\"og:image:width\" content=\"609\" \/>\r\n\t<meta property=\"og:image:height\" content=\"461\" \/>\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=\"20 \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-4\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/\"},\"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\u0438\u043d\u0430 4\",\"datePublished\":\"2023-02-03T13:18:02+00:00\",\"dateModified\":\"2023-02-03T13:29:53+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/\"},\"wordCount\":2130,\"commentCount\":2,\"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-4\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/\",\"url\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/\",\"name\":\"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u0438\u043d\u0430 4 - Dijix - \u0411\u043b\u043e\u0433\",\"isPartOf\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/#website\"},\"datePublished\":\"2023-02-03T13:18:02+00:00\",\"dateModified\":\"2023-02-03T13:29:53+00:00\",\"description\":\"\u0423 \u0446\u0456\u0439 \u0441\u0442\u0430\u0442\u0442\u0456, \u043c\u0438 \u043f\u0440\u043e\u0434\u043e\u0432\u0436\u0438\u043c\u043e \u043f\u0438\u0441\u0430\u0442\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core. \u0423 \u0442\u0440\u0435\u0442\u0456\u0439 \u0447\u0430\u0441\u0442\u0438\u043d\u0456 \u043c\u0438 \u0440\u043e\u0437\u0448\u0438\u0440\u0438\u043b\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u0437\u0430 \u0440\u0430\u0445\u0443\u043d\u043e\u043a \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043d\u043e\u0432\u0438\u0445 \u043a\u043b\u0430\u0441\u0456\u0432 \u0456 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0432\u0456\u0434\u043d\u043e\u0441\u0438\u043d.\",\"breadcrumb\":{\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/#breadcrumb\"},\"inLanguage\":\"uk\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/#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\u0438\u043d\u0430 4\"}]},{\"@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\u0438\u043d\u0430 4 - Dijix - \u0411\u043b\u043e\u0433","description":"\u0423 \u0446\u0456\u0439 \u0441\u0442\u0430\u0442\u0442\u0456, \u043c\u0438 \u043f\u0440\u043e\u0434\u043e\u0432\u0436\u0438\u043c\u043e \u043f\u0438\u0441\u0430\u0442\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core. \u0423 \u0442\u0440\u0435\u0442\u0456\u0439 \u0447\u0430\u0441\u0442\u0438\u043d\u0456 \u043c\u0438 \u0440\u043e\u0437\u0448\u0438\u0440\u0438\u043b\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u0437\u0430 \u0440\u0430\u0445\u0443\u043d\u043e\u043a \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043d\u043e\u0432\u0438\u0445 \u043a\u043b\u0430\u0441\u0456\u0432 \u0456 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0432\u0456\u0434\u043d\u043e\u0441\u0438\u043d.","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-4\/","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\u0438\u043d\u0430 4 - Dijix - \u0411\u043b\u043e\u0433","og_url":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/","og_site_name":"Dijix - \u0411\u043b\u043e\u0433","article_publisher":"https:\/\/www.facebook.com\/Dijixs","article_published_time":"2023-02-03T13:18:02+00:00","article_modified_time":"2023-02-03T13:29:53+00:00","og_image":[{"width":609,"height":461,"url":"https:\/\/dijix.com.ua\/blog\/wp-content\/uploads\/2022\/09\/1-6.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":"20 \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-4\/#article","isPartOf":{"@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/"},"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\u0438\u043d\u0430 4","datePublished":"2023-02-03T13:18:02+00:00","dateModified":"2023-02-03T13:29:53+00:00","mainEntityOfPage":{"@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/"},"wordCount":2130,"commentCount":2,"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-4\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/","url":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/","name":"\u041c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core MVC EF. \u0427\u0430\u0441\u0442\u0438\u043d\u0430 4 - Dijix - \u0411\u043b\u043e\u0433","isPartOf":{"@id":"https:\/\/dijix.com.ua\/blog\/#website"},"datePublished":"2023-02-03T13:18:02+00:00","dateModified":"2023-02-03T13:29:53+00:00","description":"\u0423 \u0446\u0456\u0439 \u0441\u0442\u0430\u0442\u0442\u0456, \u043c\u0438 \u043f\u0440\u043e\u0434\u043e\u0432\u0436\u0438\u043c\u043e \u043f\u0438\u0441\u0430\u0442\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u043d\u0430 Asp.Net Core. \u0423 \u0442\u0440\u0435\u0442\u0456\u0439 \u0447\u0430\u0441\u0442\u0438\u043d\u0456 \u043c\u0438 \u0440\u043e\u0437\u0448\u0438\u0440\u0438\u043b\u0438 \u043c\u0430\u0433\u0430\u0437\u0438\u043d \u0437\u0430 \u0440\u0430\u0445\u0443\u043d\u043e\u043a \u0434\u043e\u0434\u0430\u0432\u0430\u043d\u043d\u044f \u043d\u043e\u0432\u0438\u0445 \u043a\u043b\u0430\u0441\u0456\u0432 \u0456 \u0441\u0442\u0432\u043e\u0440\u0435\u043d\u043d\u044f \u0432\u0456\u0434\u043d\u043e\u0441\u0438\u043d.","breadcrumb":{"@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/#breadcrumb"},"inLanguage":"uk","potentialAction":[{"@type":"ReadAction","target":["https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/dijix.com.ua\/blog\/uk\/magazin-na-asp-net-core-mvc-ef-chast-4\/#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\u0438\u043d\u0430 4"}]},{"@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\/379","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=379"}],"version-history":[{"count":2,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/posts\/379\/revisions"}],"predecessor-version":[{"id":382,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/posts\/379\/revisions\/382"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/media\/245"}],"wp:attachment":[{"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/media?parent=379"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/categories?post=379"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/dijix.com.ua\/blog\/wp-json\/wp\/v2\/tags?post=379"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}