{"id":340381,"date":"2022-10-28T15:00:23","date_gmt":"2022-10-28T15:00:23","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=340381"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=340381","title":{"rendered":"<span>\u0421\u043e\u0437\u0434\u0430\u0451\u043c \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 Fluent API<\/span>"},"content":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041d\u0435\u0434\u0430\u0432\u043d\u043e \u044f \u0437\u0430\u0445\u043e\u0442\u0435\u043b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0431\u043e\u043b\u0435\u0435 \u0443\u0434\u043e\u0431\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 \u043a\u043e\u0435-\u043a\u0430\u043a\u0438\u043c \u043a\u043b\u0430\u0441\u0441\u043e\u043c \u0432 \u043e\u0434\u043d\u043e\u043c \u0438\u0437 \u043c\u043e\u0434\u0443\u043b\u0435\u0439 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f. \u0422\u043e\u0433\u0434\u0430-\u0442\u043e \u044f \u0432\u0441\u043f\u043e\u043c\u043d\u0438\u043b \u043f\u0440\u043e Fluent API, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432 \u043c\u043e\u0451\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043e\u0447\u0435\u043d\u044c \u0445\u043e\u0440\u043e\u0448\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u043b.<\/p>\n<p>\u042f \u043d\u0430\u0448\u0451\u043b \u043a\u0443\u0447\u0443 \u043e\u0431\u044a\u044f\u0441\u043d\u0435\u043d\u0438\u0439 \u0438 \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u0432 \u043a\u043e\u0434\u0430 \u0434\u043b\u044f \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 Fluent API, \u043e\u0434\u043d\u0430\u043a\u043e \u044f \u043d\u0435 \u043c\u043e\u0433 \u043d\u0430\u0439\u0442\u0438 \u0432\u043d\u044f\u0442\u043d\u044b\u0445 \u043e\u0431\u044a\u044f\u0441\u043d\u0435\u043d\u0438\u0439, \u043a\u0430\u043a \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0432 \u044d\u0442\u043e\u043c \u0436\u0435 Fluent API \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0435 \u043c\u0435\u0442\u043e\u0434\u044b, \u0430\u043a\u0438 \u0434\u0435\u043b\u0430\u0435\u0442 \u044d\u0442\u043e \u043a\u0430\u043a\u043e\u0439-\u043d\u0438\u0431\u0443\u0434\u044c Linq. \u0411\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 \u043a\u0430\u043a\u0443\u044e-\u0442\u043e \u044d\u043b\u044c\u0444\u0438\u0439\u0441\u043a\u0443\u044e \u043c\u0430\u0433\u0438\u044e, \u043d\u043e \u044f \u043d\u0430\u0448\u0451\u043b \u0434\u0440\u0430\u0439\u0432\u0435\u0440 MongoDB, \u043d\u0430 \u0438\u0441\u0445\u043e\u0434\u043d\u043e\u043c \u043a\u043e\u0434\u0435 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u044f \u0438 \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u043b\u0441\u044f, \u043a\u0430\u043a \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 Fluent API.<\/p>\n<h2>\u0421\u043e\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u0435<\/h2>\n<ol>\n<li>\n<p><a href=\"#%D0%A7%D1%82%D0%BE_%D1%82%D0%B0%D0%BA%D0%BE%D0%B5_FluentAPI\" rel=\"noopener noreferrer nofollow\">\u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 Fluent API<\/a>;<\/p>\n<\/li>\n<li>\n<p><a href=\"#%D0%A0%D0%B5%D0%B0%D0%BB%D0%B8%D0%B7%D1%83%D0%B5%D0%BC_%D0%B0%D1%81%D0%B8%D0%BD%D1%85%D1%80%D0%BE%D0%BD%D0%BD%D1%8B%D0%B9_FluentAPI\" rel=\"noopener noreferrer nofollow\">\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 Fluent API<\/a>:<\/p>\n<ol>\n<li>\n<p><a href=\"#%D0%93%D0%BE%D1%82%D0%BE%D0%B2%D0%B8%D0%BC%D1%81%D1%8F_%D1%82%D0%B2%D0%BE%D1%80%D0%B8%D1%82%D1%8C\" rel=\"noopener noreferrer nofollow\">\u0413\u043e\u0442\u043e\u0432\u0438\u043c\u0441\u044f \u0442\u0432\u043e\u0440\u0438\u0442\u044c<\/a>;<\/p>\n<\/li>\n<li>\n<p><a href=\"#%D0%94%D0%B5%D0%BB%D0%B0%D0%B5%D0%BC_%D1%81%D0%BA%D0%B5%D0%BB%D0%B5%D1%82_%D0%BF%D1%80%D0%B8%D0%BB%D0%BE%D0%B6%D0%B5%D0%BD%D0%B8%D1%8F\" rel=\"noopener noreferrer nofollow\">\u0414\u0435\u043b\u0430\u0435\u043c \u0441\u043a\u0435\u043b\u0435\u0442 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f<\/a>:<\/p>\n<ol>\n<li>\n<p><a href=\"#%D0%9F%D0%B5%D1%80%D0%B2%D1%8B%D0%B9_%D1%81%D0%BB%D1%83%D1%87%D0%B0%D0%B9\" rel=\"noopener noreferrer nofollow\">\u041f\u0435\u0440\u0432\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 Fluent API<\/a>;<\/p>\n<\/li>\n<li>\n<p><a href=\"#%D0%92%D1%82%D0%BE%D1%80%D0%BE%D0%B9_%D1%81%D0%BB%D1%83%D1%87%D0%B0%D0%B9\" rel=\"noopener noreferrer nofollow\">\u0412\u0442\u043e\u0440\u043e\u0439 \u0441\u043b\u0443\u0447\u0430\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 Fluent API<\/a>;<\/p>\n<\/li>\n<\/ol>\n<\/li>\n<li>\n<p><a href=\"#%D0%94%D0%BE%D0%B1%D0%B0%D0%B2%D0%BB%D1%8F%D0%B5%D0%BC_%D0%B0%D1%81%D0%B8%D0%BD%D1%85%D1%80%D0%BE%D0%BD%D0%BD%D0%BE%D1%81%D1%82%D1%8C\" rel=\"noopener noreferrer nofollow\">\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0441\u0442\u044c<\/a>;<\/p>\n<\/li>\n<\/ol>\n<\/li>\n<li>\n<p><a href=\"#Optional_pattern\" rel=\"noopener noreferrer nofollow\">Optional pattern<\/a>;<\/p>\n<\/li>\n<li>\n<p><a href=\"#%D0%98%D1%82%D0%BE%D0%B3%D0%BE\" rel=\"noopener noreferrer nofollow\">\u0418\u0442\u043e\u0433\u043e<\/a>.<\/p>\n<\/li>\n<\/ol>\n<p><a class=\"anchor\" name=\"%D0%A7%D1%82%D0%BE_%D1%82%D0%B0%D0%BA%D0%BE%D0%B5_FluentAPI\" id=\"\u0427\u0442\u043e_\u0442\u0430\u043a\u043e\u0435_FluentAPI\"><\/a><\/p>\n<h2>\u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 Fluent API<\/h2>\n<p>\u041d\u0435 \u0431\u0443\u0434\u0443 \u043f\u044b\u0442\u0430\u0442\u044c\u0441\u044f \u0441\u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u0435 Fluent API, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u043e\u0431\u0440\u0430\u0442\u0438\u043c\u0441\u044f \u043a \u0441\u0442\u0430\u0440\u043e\u0439-\u0434\u043e\u0431\u0440\u043e\u0439 <a href=\"https:\/\/en.wikipedia.org\/wiki\/Fluent_interface\" rel=\"noopener noreferrer nofollow\">\u0412\u0438\u043a\u0438\u043f\u0435\u0434\u0438\u0438<\/a>:<\/p>\n<blockquote>\n<p>    \u0412 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u043d\u043e\u0439 \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u0438\u0438\u00a0<strong>Fluent API<\/strong>\u00a0\u2014<strong> <\/strong>\u044d\u0442\u043e\u00a0\u043e\u0431\u044a\u0435\u043a\u0442\u043d\u043e-\u043e\u0440\u0438\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439\u00a0API, \u0434\u0438\u0437\u0430\u0439\u043d \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0432 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0439 \u0441\u0442\u0435\u043f\u0435\u043d\u0438 \u0437\u0430\u0432\u0438\u0441\u0438\u0442 \u043e\u0442 \u0446\u0435\u043f\u043e\u0447\u043a\u0438 \u043c\u0435\u0442\u043e\u0434\u043e\u0432.\u00a0\u0415\u0433\u043e \u0446\u0435\u043b\u044c &#8212; \u043f\u043e\u0432\u044b\u0441\u0438\u0442\u044c \u0440\u0430\u0437\u0431\u043e\u0440\u0447\u0438\u0432\u043e\u0441\u0442\u044c \u043a\u043e\u0434\u0430 \u043f\u0443\u0442\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f DSL.\u00a0\u0422\u0435\u0440\u043c\u0438\u043d \u0431\u044b\u043b \u0432\u0432\u0435\u0434\u0435\u043d \u0432 2005 \u0433\u043e\u0434\u0443 \u042d\u0440\u0438\u043a\u043e\u043c \u042d\u0432\u0430\u043d\u0441\u043e\u043c \u0438 \u041c\u0430\u0440\u0442\u0438\u043d\u043e\u043c \u0424\u0430\u0443\u043b\u0435\u0440\u043e\u043c.<\/p>\n<\/blockquote>\n<p>\u0418\u0437 \u043d\u0435\u043f\u043e\u043d\u044f\u0442\u043d\u044b\u0445 \u0441\u043b\u043e\u0432 \u0432 \u044d\u0442\u043e\u043c \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u0438 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043b\u0438\u0448\u044c DSL. <strong>DSL<\/strong> &#8212; \u044d\u0442\u043e, \u0435\u0441\u043b\u0438 \u043f\u043e-\u0436\u0438\u0442\u0435\u0439\u0441\u043a\u0438, \u044f\u0437\u044b\u043a \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f, \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0439 \u0434\u043b\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0438 \u0432 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u043e\u0439 \u043f\u0440\u0435\u0434\u043c\u0435\u0442\u043d\u043e\u0439 \u043e\u0431\u043b\u0430\u0441\u0442\u0438. \u0414\u043b\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u0430, \u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435, \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0438\u0432\u0435\u0441\u0442\u0438 \u0442\u0430\u043a\u0438\u0435 \u044f\u0437\u044b\u043a\u0438, \u043a\u0430\u043a <a href=\"https:\/\/learn.microsoft.com\/en-us\/dotnet\/csharp\/programming-guide\/concepts\/linq\/\" rel=\"noopener noreferrer nofollow\"><em>LINQ<\/em><\/a><em>, <\/em><a href=\"https:\/\/practicum.yandex.ru\/blog\/chto-takoe-sql\/\" rel=\"noopener noreferrer nofollow\"><em>SQL<\/em><\/a><em>, <\/em><a href=\"https:\/\/graphql.org\/\" rel=\"noopener noreferrer nofollow\"><em>GraphQL<\/em><\/a><em>, <\/em><a href=\"https:\/\/metanit.com\/sharp\/tutorial\/7.4.php\" rel=\"noopener noreferrer nofollow\"><em>Regex<\/em><\/a><em>, <\/em><a href=\"https:\/\/habr.com\/ru\/company\/yandex\/blog\/484068\/\" rel=\"noopener noreferrer nofollow\"><em>gRPC<\/em><\/a><em>, <\/em><a href=\"https:\/\/lifehacker.ru\/chto-takoe-markdown\/\" rel=\"noopener noreferrer nofollow\"><em>Markdown<\/em><\/a><em> \u0438 \u0442.\u043f<\/em>, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u0435\u0434\u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u044b \u0434\u043b\u044f \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0439 \u0441 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0430\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u0445, \u043f\u043e\u0438\u0441\u043a\u0430 \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u0439 \u0432 \u0442\u0435\u043a\u0441\u0442\u0435 \u043f\u043e \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0430\u043c, \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u0441\u0435\u0442\u0435\u0432\u044b\u0445 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0444\u043e\u0440\u043c\u0430\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e. \u041a\u0441\u0442\u0430\u0442\u0438, \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0435 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0438 \u043f\u043e \u0442\u0438\u043f\u0443 <a href=\"https:\/\/habr.com\/ru\/post\/319270\/\" rel=\"noopener noreferrer nofollow\"><em>React<\/em><\/a> \u0438 <a href=\"https:\/\/specialties.bayt.com\/en\/specialties\/q\/1906\/is-jquery-a-dsl\/\" rel=\"noopener noreferrer nofollow\"><em>JQuery <\/em><\/a>\u0442\u0430\u043a\u0436\u0435 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0432\u043d\u0435\u0448\u043d\u0438\u043c\u0438 DSL \u0438 \u043d\u0430\u0437\u044b\u0432\u0430\u044e\u0442\u0441\u044f <strong>eDSL<\/strong>. \u0418\u0441\u0445\u043e\u0434\u044f \u0438\u0437 \u0432\u0442\u043e\u0440\u043e\u0439 \u0441\u0441\u044b\u043b\u043a\u0438 \u043d\u0430 \u0444\u043e\u0440\u0443\u043c \u043f\u0440\u043e JQuery \u043c\u043e\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432\u044b\u0432\u043e\u0434, \u0447\u0442\u043e \u0434\u0430\u043d\u043d\u044b\u0435 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0438 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f DSL \u0438\u0437-\u0437\u0430 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0431\u043e\u043b\u0435\u0435 \u0443\u0434\u043e\u0431\u043d\u043e\u0439 \u043f\u0440\u043e\u0441\u043b\u043e\u0439\u043a\u043e\u0439, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u043e\u0442\u043e\u043c \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0430 \u0432 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0439 Javascript-\u043a\u043e\u0434. \u041d\u0443, \u0438\u043b\u0438 \u0447\u0442\u043e-\u0442\u043e \u0442\u0430\u043a\u043e\u0435. \u0411\u043e\u043b\u0435\u0435 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u043f\u0440\u043e DSL \u043f\u0440\u043e\u0448\u0443 \u0432 \u044d\u0442\u0443 <a href=\"https:\/\/habr.com\/ru\/post\/94259\/\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u044e<\/a>, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u043e, \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e, DSL, \u0447\u0442\u043e \u0442\u0430\u043a\u043e\u0435 API \u0438 \u0434\u0440.<\/p>\n<p>\u0412 \u044d\u0442\u043e\u0439 <a href=\"https:\/\/dev.to\/mcc_ahmed\/building-your-first-async-fluent-api-using-interface-extension-methods-pattern-266a\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u0435<\/a> (\u0441\u0442\u0430\u0442\u044c\u044f, \u043a\u0441\u0442\u0430\u0442\u0438, \u0442\u043e\u0436\u0435 \u043f\u0440\u043e \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 Fluent API, \u043e\u0434\u043d\u0430\u043a\u043e \u0442\u0430\u043c \u043d\u0438\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e) \u043d\u0430\u0448\u0451\u043b \u043f\u0440\u0438\u043c\u0435\u0440 \u043a\u043e\u0434\u0430 \u0432 Fluent-\u0441\u0442\u0438\u043b\u0435 \u0438 \u0435\u0433\u043e \u0430\u043d\u0430\u043b\u043e\u0433\u0435 \u0432 \u0438\u043c\u043f\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u043e\u043c \u0441\u0442\u0438\u043b\u0435, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u043d\u044f\u0442\u044c, \u0432 \u0447\u0451\u043c \u043f\u0440\u0435\u043b\u0435\u0441\u0442\u044c Fluent API:<\/p>\n<pre><code class=\"cs\">var data = await GetNewsAsync()          .Where(newsList => newsList.Date >= DateTime.Today)          .SelectMany(newsList => newsList.NewsItems)          .ToList();<\/code><\/pre>\n<pre><code class=\"cs\">var newsList = await GetNewsAsync();  if (newsList.Date >= DateTime.Today) {    return newsList.Select(news=>news.NewsItems).ToList(); }  return new List&lt;NewsItem>();<\/code><\/pre>\n<p>\u041a\u0430\u043a \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u0442\u044c \u0438\u0437 \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u0432 \u0432\u044b\u0448\u0435, Fluent API \u0434\u0435\u043b\u0430\u0435\u0442 \u043a\u043e\u0434 \u0431\u043e\u043b\u0435\u0435 \u043a\u043e\u043c\u043f\u0430\u043a\u0442\u043d\u044b\u043c \u0438, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0431\u043e\u043b\u0435\u0435 \u0447\u0438\u0442\u0430\u0435\u043c\u044b\u043c, \u0447\u0442\u043e \u0435\u0441\u0442\u044c \u043e\u0434\u043d\u043e\u0437\u043d\u0430\u0447\u043d\u043e \u0445\u043e\u0440\u043e\u0448\u043e.<\/p>\n<p><a class=\"anchor\" name=\"%D0%A0%D0%B5%D0%B0%D0%BB%D0%B8%D0%B7%D1%83%D0%B5%D0%BC_%D0%B0%D1%81%D0%B8%D0%BD%D1%85%D1%80%D0%BE%D0%BD%D0%BD%D1%8B%D0%B9_FluentAPI\" id=\"\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c_\u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439_FluentAPI\"><\/a><\/p>\n<h2>\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 Fluent API<\/h2>\n<p>\u0414\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430, \u0434\u0443\u043c\u0430\u044e, \u0441\u0442\u043e\u0438\u0442 \u043d\u0430\u0447\u0430\u0442\u044c \u0441 \u043f\u0440\u043e\u0441\u0442\u043e\u0433\u043e \u0438 \u0438\u0434\u0442\u0438 \u0434\u0430\u043b\u044c\u0448\u0435, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0434\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440 SQL-\u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0442\u0430\u043a\u0436\u0435 \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435 \u0438\u0437 \u0411\u0414 (\u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0431\u0443\u0434\u0435\u0442 \u044f\u0432\u043b\u044f\u0442\u044c\u0441\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u043f\u0438\u0441\u043e\u043a).<\/p>\n<p>\u041a\u0441\u0442\u0430\u0442\u0438, \u0434\u043b\u044f \u0442\u0435\u0445, \u043a\u0442\u043e \u043c\u0430\u043b\u043e \u0437\u043d\u0430\u043a\u043e\u043c \u0441 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u043c \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\u043c, \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0443\u044e \u043a \u043f\u0440\u043e\u0447\u0442\u0435\u043d\u0438\u044e \u0432\u043e\u0442 \u044d\u0442\u0443 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u0443\u044e <a href=\"https:\/\/habr.com\/ru\/post\/470830\/#conception\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u044e<\/a>.<\/p>\n<p><a class=\"anchor\" name=\"%D0%93%D0%BE%D1%82%D0%BE%D0%B2%D0%B8%D0%BC%D1%81%D1%8F_%D1%82%D0%B2%D0%BE%D1%80%D0%B8%D1%82%D1%8C\" id=\"\u0413\u043e\u0442\u043e\u0432\u0438\u043c\u0441\u044f_\u0442\u0432\u043e\u0440\u0438\u0442\u044c\"><\/a><\/p>\n<h3>\u0413\u043e\u0442\u043e\u0432\u0438\u043c\u0441\u044f \u0442\u0432\u043e\u0440\u0438\u0442\u044c<\/h3>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0438 \u043f\u0440\u043e\u0435\u043a\u0442 \u0433\u0434\u0435-\u0442\u043e \u043d\u0430 \u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u0435 \u0438 \u043e\u0442\u043a\u0440\u043e\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0432 \u0432\u0441\u0435\u043c\u0438 \u043b\u044e\u0431\u0438\u043c\u043e\u043c <a href=\"https:\/\/visualstudio.microsoft.com\/ru\/\" rel=\"noopener noreferrer nofollow\">Visual Studio Code<\/a> \u0441 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u043c \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u043c <a href=\"https:\/\/marketplace.visualstudio.com\/items?itemName=ms-dotnettools.csharp\" rel=\"noopener noreferrer nofollow\">\u043f\u043b\u0430\u0433\u0438\u043d\u043e\u043c \u0434\u043b\u044f C#<\/a> \u0438 <a href=\"https:\/\/marketplace.visualstudio.com\/items?itemName=GitHub.copilot\" rel=\"noopener noreferrer nofollow\">Github Copilot<\/a> (\u043c\u043e\u0439 \u0440\u0435\u043a\u043e\u043c\u0435\u0434\u043e\u0441\u044c\u0451\u043d), \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b, \u0435\u0441\u043b\u0438 \u043a\u043e\u043c\u0443 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e:<\/p>\n<pre><code class=\"bash\">$ dotnet new sln $ dotnet new console -o .\/src\/FluentAPI $ dotnet sln add .\/src\/FluentAPI $ code .<\/code><\/pre>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0435\u0440\u0435\u0439\u0434\u0451\u043c \u043a \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044e \u043a\u043e\u0434\u0430&#8230;<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w780q1\/getpro\/habr\/upload_files\/9fb\/71a\/3d5\/9fb71a3d5c731967607287f642ab89ca.jpg\" alt=\"\u0415\u043d\u043e\u0442\u0438\u043a, \u0433\u043e\u0442\u043e\u0432\u044b\u0439 \u043a\u043e\u0434\u0438\u0442\u044c\" title=\"\u0415\u043d\u043e\u0442\u0438\u043a, \u0433\u043e\u0442\u043e\u0432\u044b\u0439 \u043a\u043e\u0434\u0438\u0442\u044c\" width=\"900\" height=\"602\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/9fb\/71a\/3d5\/9fb71a3d5c731967607287f642ab89ca.jpg\" data-blurred=\"true\"\/><figcaption>\u0415\u043d\u043e\u0442\u0438\u043a, \u0433\u043e\u0442\u043e\u0432\u044b\u0439 \u043a\u043e\u0434\u0438\u0442\u044c<\/figcaption><\/figure>\n<p><a class=\"anchor\" name=\"%D0%94%D0%B5%D0%BB%D0%B0%D0%B5%D0%BC_%D1%81%D0%BA%D0%B5%D0%BB%D0%B5%D1%82_%D0%BF%D1%80%D0%B8%D0%BB%D0%BE%D0%B6%D0%B5%D0%BD%D0%B8%D1%8F\" id=\"\u0414\u0435\u043b\u0430\u0435\u043c_\u0441\u043a\u0435\u043b\u0435\u0442_\u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f\"><\/a><\/p>\n<h3>\u0414\u0435\u043b\u0430\u0435\u043c \u0441\u043a\u0435\u043b\u0435\u0442 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f<\/h3>\n<p>\u041d\u0430\u0448\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u0438\u0437 \u00ab\u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445\u00bb \u0434\u0430\u043d\u043d\u044b\u0435 (\u043a\u0430\u043a \u044f \u043b\u044e\u0431\u043b\u044e \u0442\u0430\u0432\u0442\u043e\u043b\u043e\u0433\u0438\u044e), \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0443\u0434\u0443\u0442 \u043a\u0430\u043a\u0438\u043c\u0438-\u0442\u043e \u0447\u0438\u0441\u043b\u0430\u043c\u0438, \u0437\u0430\u0442\u0435\u043c \u0432\u044b\u0432\u043e\u0434\u0438\u0442\u044c \u044d\u0442\u0438 \u0447\u0438\u0441\u043b\u0430 \u0432 \u0442\u0435\u0440\u043c\u0438\u043d\u0430\u043b.<\/p>\n<p>\u0421 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435\u043c \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u043b\u0438\u0441\u044c, \u0442\u0435\u043f\u0435\u0440\u044c \u0438\u0434\u0451\u043c \u0432 \u0444\u0430\u0439\u043b <code>Program.cs<\/code>, \u043d\u0430\u0445\u043e\u0434\u044f\u0449\u0438\u0439\u0441\u044f \u0432 \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u043e\u043c \u043f\u043e \u043f\u0443\u0442\u0438 <code>.\/src\/FluentAPI<\/code> \u043f\u0440\u043e\u0435\u043a\u0442\u0435, \u0433\u0434\u0435 \u043c\u0435\u043d\u044f\u0435\u043c \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u0444\u0430\u0439\u043b\u0430 \u043d\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<pre><code class=\"cs\">namespace FluentAPI;  public class Program {     public static void Main(string[] args) {         var numbers = FluentSQLConnection&lt;int>             \/\/  \u0421 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 CreateConnection \u0441\u043e\u0437\u0434\u0430\u0451\u043c \u0438              \/\/  \u043d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u043c \u044d\u043a\u0437\u0435\u043c\u043b\u044f\u0440 \u043a\u043b\u0430\u0441\u0441\u0430 FluentSQLConnection             .CreateConnection(builder => {                 builder.ConnectionString = \"Data Source=.;Initial Catalog=FluentAPI;Integrated Security=True\";                 builder.Data = Enumerable.Range(0, 100).ToList();             })             .Query(\"SELECT * FROM Numbers\") \/\/  \u0412\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u0437\u0430\u043f\u0440\u043e\u0441 \u043a \u0431\u0430\u0437\u0435 \u0434\u0430\u043d\u043d\u044b\u0445             .Where(n => n % 2 == 0) \/\/  \u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u0442\u043e\u043b\u044c\u043a\u043e \u0447\u0451\u0442\u043d\u044b\u0435 \u0447\u0438\u0441\u043b\u0430             .ToList(); \/\/  \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0432 \u0432\u0438\u0434\u0435 \u0441\u043f\u0438\u0441\u043a\u0430          \/\/  \u0412\u044b\u0432\u043e\u0434\u0438\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u044c         foreach (var number in numbers) {             System.Console.WriteLine(number);         }     } }<\/code><\/pre>\n<p>\u0418\u0437 \u043a\u043e\u0434\u0430 \u0432\u044b\u0448\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e, \u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435, \u0447\u0442\u043e \u043a\u043e\u0434 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c\u0441\u044f \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e. \u0410\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0441\u0442\u044c \u0432\u0432\u0435\u0434\u0451\u043c \u043f\u043e\u0437\u0436\u0435. \u041a\u0441\u0442\u0430\u0442\u0438, \u043d\u0435 \u043e\u0431\u0440\u0430\u0449\u0430\u0439\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 <code>builder.Data = Enumerable.Range(0, 100).ToList();<\/code>, \u044d\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0432\u0432\u0435\u0441\u0442\u0438 \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0439 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a \u0434\u0430\u043d\u043d\u044b\u0445, \u0432\u0435\u0434\u044c \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0435\u0442\u0443.<\/p>\n<p>\u0410 \u0441\u0435\u0439\u0447\u0430\u0441 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u043a\u043b\u0430\u0441\u0441 <code>FluentSQLConnection<\/code>. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0444\u0430\u0439\u043b <code>FluentSQLConnection.cs<\/code>. \u041e\u0431\u044b\u0447\u043d\u043e Fluent API \u043b\u0438\u0448\u044c \u043c\u0435\u043d\u044f\u0435\u0442 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043a\u043b\u0430\u0441\u0441\u0430, \u043e\u0434\u043d\u0430\u043a\u043e, \u0432 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435, \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u0437\u0430\u043f\u0440\u0435\u0449\u0430\u0435\u0442 \u0432\u0435\u0440\u043d\u0443\u0442\u044c \u043c\u0435\u0442\u043e\u0434\u043e\u043c <code>Query(string)<\/code> \u0442\u0438\u043f <code>IEnumerable&lt;TData><\/code>. <\/p>\n<p><a class=\"anchor\" name=\"%D0%9F%D0%B5%D1%80%D0%B2%D1%8B%D0%B9_%D1%81%D0%BB%D1%83%D1%87%D0%B0%D0%B9\" id=\"\u041f\u0435\u0440\u0432\u044b\u0439_\u0441\u043b\u0443\u0447\u0430\u0439\"><\/a><\/p>\n<h4>\u041f\u0435\u0440\u0432\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439<\/h4>\n<pre><code class=\"cs\">using Microsoft.Data.SqlClient;  namespace FluentAPI;  public record FluentSQLConnectionBuilder&lt;TData> {     public string ConnectionString { get; set; }     public List&lt;TData> Data { get; set; } }  public interface IFluentSQLQuery&lt;TData> {     IFluentSQLSelection&lt;TData> Query(string sql); }  public interface IFluentSQLQueryResult&lt;TData> {     List&lt;TData> ToList(); }  public interface IFluentSQLSelection&lt;TData> : IFluentSQLQueryResult&lt;TData> {     IFluentSQLSelection&lt;TData> Where(Func&lt;TData, bool> predicate);  }  public sealed class FluentSQLConnection&lt;TData>     : IFluentSQLQuery&lt;TData>, IFluentSQLQueryResult&lt;TData>, IFluentSQLSelection&lt;TData> {     IEnumerable&lt;TData> _data;     IEnumerable&lt;TData> _queredData;     SqlConnection _connection;      FluentSQLConnection(string connectionString, IEnumerable&lt;TData> data)     {         _connection = new SqlConnection(connectionString);         _queredData = new List&lt;TData>();         _data = data;     }      public static IFluentSQLQuery&lt;TData> CreateConnection(Action&lt;FluentSQLConnectionBuilder&lt;TData>> configureConnection)     {         var builder = new FluentSQLConnectionBuilder&lt;TData>() {              ConnectionString = \"\",             Data = new List&lt;TData>()          };         configureConnection(builder);         return new FluentSQLConnection&lt;TData>(builder.ConnectionString, builder.Data);     }       IFluentSQLSelection&lt;TData> IFluentSQLQuery&lt;TData>.Query(string sql)     {         \/\/ _connection.Open();         \/\/ var command = new SqlCommand(sql, _connection);         \/\/ var reader = command.ExecuteReader();         \/\/ var data = new List&lt;TData>();         \/\/ while (reader.Read())         \/\/ {         \/\/     data.Add((TData)reader[0]);         \/\/ }         \/\/ _queredData = data;         \/\/ _connection.Close();          Task.Delay(1000).Wait();         _queredData = _data;          return this;     }      public IFluentSQLSelection&lt;TData> Where(Func&lt;TData, bool> predicate)     {         _queredData = _queredData.Where(predicate);         return this;     }      List&lt;TData> IFluentSQLQueryResult&lt;TData>.ToList() => _queredData.ToList(); }<\/code><\/pre>\n<details class=\"spoiler\">\n<summary>Microsoft.Data.SqlClient<\/summary>\n<div class=\"spoiler__content\">\n<p>\u0414\u043b\u044f \u0442\u0435\u0445, \u043a\u0442\u043e \u043d\u0435 \u0437\u043d\u0430\u0435\u0442, \u0442\u043e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 <code>Microsoft.Data.SqlClient<\/code>, \u043a\u043e\u0442\u043e\u0440\u0430\u044f, \u043f\u043e-\u0438\u0434\u0435\u0435, \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0447\u0430\u0441\u0442\u044c\u044e <a href=\"https:\/\/learn.microsoft.com\/ru-ru\/dotnet\/framework\/data\/adonet\/?redirectedfrom=MSDN\" rel=\"noopener noreferrer nofollow\">ADO.NET<\/a>, \u043d\u0443\u0436\u043d\u043e \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c \u0432 \u043f\u0440\u043e\u0435\u043a\u0442 \u0440\u0443\u0447\u043a\u0430\u043c\u0438. \u0414\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443, \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043e\u0442\u043a\u0440\u044b\u0442\u044c \u0442\u0435\u0440\u043c\u0438\u043d\u0430\u043b \u0432 VS Code \u0438 \u043d\u0430\u0431\u0440\u0430\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u043a\u043e\u043c\u0430\u043d\u0434\u0443:<\/p>\n<pre><code class=\"bash\">$ dotnet add .\/src\/FluentAPI package Microsoft.Data.SqlClient<\/code><\/pre>\n<p>\u041f\u0443\u0442\u044c \u043f\u043e\u0441\u043b\u0435 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0430 <code>add<\/code> \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u043f\u0440\u043e\u0435\u043a\u0442, \u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443, \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0438\u0434\u0451\u0442 \u043f\u043e\u0441\u043b\u0435 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0430 <code>package<\/code>, \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0449\u0438\u0439 \u0442\u0438\u043f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0432 \u043f\u0440\u043e\u0435\u043a\u0442: \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u0440\u043e\u0435\u043a\u0442 \u0438\u043b\u0438 \u043f\u0430\u043a\u0435\u0442 NuGet.<\/p>\n<\/div>\n<\/details>\n<p>\u041f\u043e \u043b\u043e\u0433\u0438\u043a\u0435 \u043d\u0430\u0448 \u043c\u0435\u0442\u043e\u0434 <code>Query(string)<\/code> \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0431\u0438\u0440\u0430\u0442\u044c \u043b\u0438\u0448\u044c \u0440\u0430\u0437, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0430\u0448 \u043a\u043b\u0430\u0441\u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043d\u044b\u0439 \u043f\u043e\u0434\u0445\u043e\u0434, \u0447\u0442\u043e \u0432\u044b\u0440\u0430\u0436\u0430\u0435\u0442\u0441\u044f \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0440\u0430\u043d\u0435\u0435 \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u0442\u044b\u0439 \u043c\u0435\u0442\u043e\u0434 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0442\u0438\u043f, \u043d\u0430\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 <code>IFluentSQLQueryResult&lt;TData><\/code>, \u0442\u043e \u0435\u0441\u0442\u044c \u043d\u0430\u0448 \u043a\u043b\u0430\u0441\u0441 <code>FluentSQLConnection&lt;TData><\/code>. \u0414\u0430\u043d\u043d\u044b\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 \u0442\u0430\u043a\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0442\u043e\u0433\u0434\u0430, \u043a\u043e\u0433\u0434\u0430 \u0432 \u043d\u0430\u0448\u0435\u043c \u043a\u043e\u043d\u0435\u0447\u043d\u043e\u043c \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0435 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0441\u0432\u043e\u0439\u0441\u0442\u0432. \u0413\u0434\u0435-\u0442\u043e \u043d\u0430 \u044d\u0442\u043e\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0432\u0438\u0434\u0435\u043e \u043e\u0431\u044a\u044f\u0441\u043d\u044f\u0435\u0442\u0441\u044f \u043d\u0430\u0433\u043b\u044f\u0434\u043d\u043e \u0442\u043e, \u043e \u0447\u0451\u043c \u044f \u0433\u043e\u0432\u043e\u0440\u044e \u0441\u0435\u0439\u0447\u0430\u0441:<\/p>\n<div class=\"tm-iframe_temp\" data-src=\"https:\/\/embedd.srv.habr.com\/iframe\/63559bdf0c924e8d4165ee8d\" data-style=\"\" id=\"63559bdf0c924e8d4165ee8d\" width=\"\"><\/div>\n<p>\u041a\u043b\u0430\u0441\u0441\u043d\u044b\u0439 \u0432\u0438\u0434\u043e\u0441, \u043a\u0430\u043a \u0438 \u043c\u043d\u043e\u0433\u0438\u0435 \u0434\u0440\u0443\u0433\u0438\u0435 \u0432\u0438\u0434\u0435\u043e \u043d\u0430 <a href=\"https:\/\/www.youtube.com\/watch?v=1JAdZul-aRQ&amp;list=RDCMUCrkPsvLGln62OMZRO6K-llg&amp;start_radio=1\" rel=\"noopener noreferrer nofollow\">\u043a\u0430\u043d\u0430\u043b\u0435 \u041d\u0438\u043a\u0430<\/a>. \u0415\u0441\u043b\u0438 \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e \u0432 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0435, \u0442\u043e \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0443\u044e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0434\u0430\u043d\u043d\u043e\u0435 \u0432\u0438\u0434\u0435\u043e. \u041a\u0441\u0442\u0430\u0442\u0438, \u0438\u043c\u0435\u043d\u043d\u043e \u043f\u0440\u0438\u043c\u0435\u0440 \u041d\u0438\u043a\u0430 \u044f \u0441\u0435\u0439\u0447\u0430\u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e.<\/p>\n<p>\u041a\u0430\u043a \u0440\u0430\u043d\u0435\u0435 \u0443\u043f\u043e\u043c\u0438\u043d\u0430\u043b\u043e\u0441\u044c, \u043d\u0435 \u043e\u0431\u0440\u0430\u0449\u0430\u0435\u043c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0432\u0441\u0451, \u0447\u0442\u043e \u0441\u0432\u044f\u0437\u0430\u043d\u043e \u0441 <code>Data<\/code> \u0438 <code>_data<\/code> \u0432 \u043a\u043b\u0430\u0441\u0441\u0435. \u041a\u0443\u0441\u043e\u043a \u0440\u0430\u0431\u043e\u0442\u044b \u0441 SQL-\u0437\u0430\u043f\u0440\u043e\u0441\u0430\u043c\u0438, \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0439 Github Copilot \u0432 \u043c\u0435\u0442\u043e\u0434\u0435 <code>IFluentSQLQuery.Query(string sql)<\/code>, \u0440\u0435\u0448\u0438\u043b \u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0430. \u041f\u0440\u0430\u0432\u0430, \u043a\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e\u0434\u043e\u0431\u043d\u044b\u0439 \u0432\u0435\u043b\u043e\u0441\u0438\u043f\u0435\u0434, \u043a\u043e\u0433\u0434\u0430 \u0435\u0441\u0442\u044c \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u0439 <a href=\"https:\/\/skillbox.ru\/media\/code\/entity_framework\/\" rel=\"noopener noreferrer nofollow\">Entity Framework<\/a> \u0438 \u043c\u0435\u043d\u0435\u0435 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u0439, \u043d\u043e \u0448\u0443\u0441\u0442\u0440\u044b\u0439 <a href=\"https:\/\/habr.com\/ru\/post\/665836\/\" rel=\"noopener noreferrer nofollow\">Dapper<\/a>? \u041d\u043e \u0432\u0441\u0451 \u0436\u0435.<\/p>\n<p><a class=\"anchor\" name=\"%D0%92%D1%82%D0%BE%D1%80%D0%BE%D0%B9_%D1%81%D0%BB%D1%83%D1%87%D0%B0%D0%B9\" id=\"\u0412\u0442\u043e\u0440\u043e\u0439_\u0441\u043b\u0443\u0447\u0430\u0439\"><\/a><\/p>\n<h4>\u0412\u0442\u043e\u0440\u043e\u0439 \u0441\u043b\u0443\u0447\u0430\u0439<\/h4>\n<pre><code class=\"cs\">using Microsoft.Data.SqlClient;  namespace FluentAPI;  public record FluentSQLConnectionBuilder&lt;TData> {     public string ConnectionString { get; set; }     public List&lt;TData> Data { get; set; } }  public sealed class FluentSQLConnection&lt;TData> {     IEnumerable&lt;TData> _data;     SqlConnection _connection;      FluentSQLConnection(string connectionString, IEnumerable&lt;TData> data)     {         _connection = new SqlConnection(connectionString);         _data = data;     }      public static FluentSQLConnection&lt;TData> CreateConnection(Action&lt;FluentSQLConnectionBuilder&lt;TData>> configureConnection)     {         var builder = new FluentSQLConnectionBuilder&lt;TData>() {              ConnectionString = \"\",             Data = new List&lt;TData>()          };         configureConnection(builder);         return new FluentSQLConnection&lt;TData>(builder.ConnectionString, builder.Data);     }       public IEnumerable&lt;TData> Query(string sql)     {         \/\/ _connection.Open();         \/\/ var command = new SqlCommand(sql, _connection);         \/\/ var reader = command.ExecuteReader();         \/\/ var data = new List&lt;TData>();         \/\/ while (reader.Read())         \/\/ {         \/\/     data.Add((TData)reader[0]);         \/\/ }         \/\/ _queredData = data;         \/\/ _connection.Close();          Task.Delay(1000).Wait();         return _data;     } }<\/code><\/pre>\n<p>\u041a\u0430\u043a \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u0442\u044c \u0432 \u043a\u043e\u0434\u0435, \u0432\u0442\u043e\u0440\u043e\u0439 \u0441\u043b\u0443\u0447\u0430\u0439 \u043a\u0443\u0434\u0430 \u043a\u043e\u043c\u043f\u0430\u043a\u0442\u043d\u0435\u0435 \u0438 \u043f\u0440\u043e\u0449\u0435 \u0432 \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0438, \u0442\u0430\u043a \u043a\u0430\u043a \u0443\u0436\u0435 \u0433\u043e\u0442\u043e\u0432\u044b\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u044f Linq \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0442 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0440\u043e\u0432\u043d\u043e \u0442\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0431\u0435\u0437 \u0438\u0437\u043b\u0438\u0448\u043d\u0435\u0433\u043e \u043a\u043e\u0434\u0430: \u0447\u0442\u043e \u0442\u0430\u043c, \u0447\u0442\u043e \u0442\u0430\u043c \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0432\u043e\u0434 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/90c\/be7\/1c3\/90cbe71c348cb97a57ea383c96f0e2aa.png\" alt=\"\u0412\u044b\u0432\u043e\u0434 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u044b\" title=\"\u0412\u044b\u0432\u043e\u0434 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u044b\" width=\"606\" height=\"586\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/90c\/be7\/1c3\/90cbe71c348cb97a57ea383c96f0e2aa.png\"\/><figcaption>\u0412\u044b\u0432\u043e\u0434 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u044b<\/figcaption><\/figure>\n<p>\u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0441\u0447\u0438\u0442\u0430\u044e, \u0447\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u043e\u0431\u0445\u043e\u0434\u0438\u0442\u044c\u0441\u044f \u0432\u0442\u043e\u0440\u044b\u043c \u043f\u043e\u0434\u0445\u043e\u0434\u043e\u043c, \u0435\u0441\u043b\u0438 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0442\u043e\u0433\u043e \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442. \u041f\u043e\u0434 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u043e\u043c \u044f \u043f\u043e\u0434\u0440\u0430\u0437\u0443\u043c\u0435\u0432\u0430\u044e \u0437\u0430\u0434\u0430\u0447\u0443 \u0438 \u0443\u0436\u0435 \u0433\u043e\u0442\u043e\u0432\u044b\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0434\u043b\u044f \u0435\u0451 \u0440\u0435\u0448\u0435\u043d\u0438\u044f.<\/p>\n<p><a class=\"anchor\" name=\"%D0%94%D0%BE%D0%B1%D0%B0%D0%B2%D0%BB%D1%8F%D0%B5%D0%BC_%D0%B0%D1%81%D0%B8%D0%BD%D1%85%D1%80%D0%BE%D0%BD%D0%BD%D0%BE%D1%81%D1%82%D1%8C\" id=\"\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c_\u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0441\u0442\u044c\"><\/a><\/p>\n<h3>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0441\u0442\u044c<\/h3>\n<p>\u0421\u0443\u0434\u044f \u043f\u043e \u0442\u0435\u043c \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0430\u043c, \u0447\u0442\u043e \u044f \u043c\u043e\u0433 \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u0442\u044c, \u0430 \u0442\u043e\u0447\u043d\u0435\u0435 \u0440\u0430\u043d\u0435\u0435 \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u0442\u044b\u0435 \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438 MongoDB, \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u0442\u0441\u044f \u0432\u0441\u0451 \u044d\u0442\u043e \u0447\u0435\u0440\u0435\u0437 \u0442\u0430\u043a\u0443\u044e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 \u0434\u0430\u043d\u043d\u044b\u0445, \u043a\u0430\u043a \u043e\u0447\u0435\u0440\u0435\u0434\u044c. \u0414\u043b\u044f \u0442\u0435\u0445, \u043a\u0442\u043e \u043d\u0435 \u0437\u043d\u0430\u043a\u043e\u043c \u0441 \u044d\u0442\u0438\u043c \u0442\u0438\u043f\u043e\u043c \u0434\u0430\u043d\u043d\u044b\u0445, \u043c\u043e\u0433\u0443 \u043f\u043e\u0441\u043e\u0432\u0435\u0442\u043e\u0432\u0430\u0442\u044c \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0438\u0441\u0447\u0435\u0440\u043f\u044b\u0432\u0430\u044e\u0449\u0443\u044e <a href=\"https:\/\/ru.wikipedia.org\/wiki\/%D0%9E%D1%87%D0%B5%D1%80%D0%B5%D0%B4%D1%8C_(%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D0%B5)\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u044e \u043d\u0430 \u0412\u0438\u043a\u0438\u043f\u0435\u0434\u0438\u0438<\/a>.<\/p>\n<p>\u0412\u043e\u043e\u0431\u0449\u0435, \u0435\u0441\u043b\u0438 \u0433\u043e\u0432\u043e\u0440\u0438\u0442\u044c \u043f\u0440\u043e MongoDB, \u0442\u0430\u043c \u0432\u0441\u0451 \u0441\u043b\u0438\u0448\u043a\u043e\u043c \u0437\u0430\u043f\u0443\u0442\u0430\u043d\u043e \u043d\u0430 \u043c\u043e\u0439 \u0432\u0437\u0433\u043b\u044f\u0434, \u0442\u0430\u043a \u043a\u0430\u043a \u0442\u0430\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043a\u0443\u0447\u0430 \u0432\u0441\u044f\u043a\u0438\u0445 \u0430\u0431\u0441\u0442\u0440\u0430\u043a\u0446\u0438\u0439 \u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u043c\u0435\u0441\u0442\u043e \u043e\u0447\u0435\u0440\u0435\u0434\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f <a href=\"https:\/\/pikabu.ru\/story\/slovar_map_na_yazyike_c_5803175\" rel=\"noopener noreferrer nofollow\">\u0441\u043b\u043e\u0432\u0430\u0440\u044c<\/a>. \u0422\u043e\u0447\u043d\u043e \u043d\u0435 \u0437\u043d\u0430\u044e, \u043d\u043e \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u044e, \u0447\u0442\u043e \u0432\u0441\u0451 \u044d\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0434\u043b\u044f \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u0433\u043e \u043c\u0430\u043f\u043f\u0438\u043d\u0433\u0430 \u0438\u0437 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u0411\u0414 \u0432 \u043e\u0431\u044a\u0435\u043a\u0442\u044b C#.<\/p>\n<p>\u041d\u043e \u0432 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0432\u0441\u0451 \u0431\u0443\u0434\u0435\u0442 \u043a\u0443\u0434\u0430 \u043f\u0440\u043e\u0449\u0435, \u0442\u043e \u0435\u0441\u0442\u044c \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043e \u0447\u0435\u0440\u0435\u0437 \u043f\u0440\u043e\u0441\u0442\u0443\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c. \u0427\u0442\u043e\u0431\u044b \u044d\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c, \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0441\u043a\u043e\u043f\u0438\u0440\u0443\u0435\u043c \u0444\u0430\u0439\u043b \u0441 \u043f\u0435\u0440\u0432\u044b\u043c \u0441\u043b\u0443\u0447\u0430\u0435\u043c \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 Fluent API \u0438 \u043f\u0435\u0440\u0435\u0438\u043c\u0435\u043d\u0443\u0435\u043c \u0435\u0433\u043e \u0432 <code>FluentSQLConnectionAsync.cs<\/code>. \u0421\u043e \u0432\u0442\u043e\u0440\u044b\u043c \u0441\u043b\u0443\u0447\u0430\u0435\u043c \u044f \u043d\u0435 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u044e, \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u044d\u0442\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c. \u0425\u043e\u0442\u044f \u043d\u0435\u0442, \u0434\u043e\u0433\u0430\u0434\u044b\u0432\u0430\u044e\u0441\u044c, \u043d\u043e \u043f\u043e\u043a\u0430 \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u043c \u043b\u0438\u0448\u044c \u043f\u0440\u043e\u0432\u0435\u0440\u0435\u043d\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431.<\/p>\n<p>\u0412 \u0441\u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c \u0444\u0430\u0439\u043b\u0435 <code>FluentSQLConnectionAsync.cs<\/code> \u0442\u0430\u043a\u0436\u0435 \u043f\u0435\u0440\u0435\u0438\u043c\u0435\u043d\u0443\u0435\u043c \u043a\u043b\u0430\u0441\u0441 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u0430 \u043a \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u044f\u043c \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430\u043c \u0434\u043e\u0431\u0430\u0432\u0438\u043c \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0435 \u0441\u043b\u043e\u0432\u043e <code>Async<\/code>. \u041f\u0440\u043e\u0434\u0435\u043b\u0430\u0435\u043c \u0435\u0449\u0451 \u043f\u0430\u0440\u0443 \u0432\u0435\u0449\u0435\u0439 \u043f\u043e \u0442\u0438\u043f\u0443 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u043c \u0435\u0449\u0451 \u043e\u0434\u043d\u043e \u043f\u043e\u043b\u0435 <code>Queue&lt;Func&lt;Task>> _pipeline<\/code>. \u041e\u0447\u0435\u0440\u0435\u0434\u044c \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u043b\u044f\u043c\u0431\u0430-\u0444\u0443\u043d\u043a\u0446\u0438\u0438 (\u043a\u0430\u043a \u043d\u0435\u043e\u0431\u044b\u0447\u043d\u043e \u0441\u043b\u044b\u0448\u0430\u0442\u044c \u0441\u043b\u043e\u0432\u043e \u00ab\u0444\u0443\u043d\u043a\u0446\u0438\u044f\u00bb \u0432 C#, \u0431\u0440\u0440\u0440, \u0430\u0436 \u043c\u0443\u0440\u0430\u0448\u043a\u0438 \u043f\u043e \u043a\u043e\u0436\u0435), \u0442\u0430\u043a \u043a\u0430\u043a \u043c\u044b \u043d\u0435 \u0445\u043e\u0442\u0438\u043c \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u0448\u0430\u043c\u0430\u043d\u0438\u0442\u044c, \u0430 \u0445\u043e\u0442\u0438\u043c \u043a\u0440\u0430\u0441\u0438\u0432\u044b\u0439, \u043b\u0430\u043a\u043e\u043d\u0438\u0447\u043d\u044b\u0439 \u043a\u043e\u0434. \u0412 \u043e\u0431\u0449\u0435\u043c, \u0432\u043e\u0442 \u0432\u0435\u0441\u044c \u043a\u043e\u0434 \u0434\u043b\u044f \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438:<\/p>\n<pre><code class=\"cs\">using Microsoft.Data.SqlClient;  namespace FluentAPI;  public record FluentSQLConnectionAsyncBuilder&lt;TData> {     public string ConnectionString { get; set; }     public List&lt;TData> Data { get; set; } }  public interface IFluentSQLAsyncQuery&lt;TData> {     IFluentSQLAsyncSelection&lt;TData> Query(string sql); }  public interface IFluentSQLAsyncQueryResult&lt;TData> {     Task&lt;List&lt;TData>> ToListAsync(); }  public interface IFluentSQLAsyncSelection&lt;TData> : IFluentSQLAsyncQueryResult&lt;TData> {     IFluentSQLAsyncSelection&lt;TData> Where(Func&lt;TData, bool> predicate);  }  public sealed class FluentSQLConnectionAsync&lt;TData>     : IFluentSQLAsyncQuery&lt;TData>, IFluentSQLAsyncQueryResult&lt;TData>, IFluentSQLAsyncSelection&lt;TData> {     IEnumerable&lt;TData> _data;     IEnumerable&lt;TData> _queredData;     SqlConnection _connection;     Queue&lt;Func&lt;Task>> _pipeline;      FluentSQLConnectionAsync(string connectionString, IEnumerable&lt;TData> data)     {         _queredData = new List&lt;TData>();         _pipeline = new();         _connection = new(connectionString);         _data = data;     }      public static IFluentSQLAsyncQuery&lt;TData> CreateConnection(Action&lt;FluentSQLConnectionAsyncBuilder&lt;TData>> configureConnection)     {         var builder = new FluentSQLConnectionAsyncBuilder&lt;TData>() {              ConnectionString = String.Empty,             Data = new List&lt;TData>()          };         configureConnection(builder);         return new FluentSQLConnectionAsync&lt;TData>(builder.ConnectionString, builder.Data);     }      public IFluentSQLAsyncSelection&lt;TData> Query(string sql)     {         _pipeline.Enqueue(async () => {             await Task.Delay(1000);             await Task.Run(() => _queredData = _data);         });          return this;     }      public IFluentSQLAsyncSelection&lt;TData> Where(Func&lt;TData, bool> predicate)     {         _pipeline.Enqueue(async () => await Task.Run(() => _queredData = _queredData.Where(predicate)));         return this;     }      public Task&lt;List&lt;TData>> ToListAsync() => Task.Run(async () => {             for (var i = 0; i &lt; _pipeline.Count; ++i)                 await _pipeline.Dequeue().Invoke();              return _queredData.ToList();         }); }<\/code><\/pre>\n<p>\u0414\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u043d\u044f\u0442\u044c, \u0434\u043b\u044f \u0447\u0435\u0433\u043e \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u043a\u043e\u0434\u0430, \u0437\u0430\u043f\u0438\u043b\u0438\u043b \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0435\u043d\u0447\u043c\u0430\u0440\u043a\u0438, \u043a\u043e\u0434 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043e\u0441\u0442\u0430\u0432\u0438\u043b \u043d\u0438\u0436\u0435 \u043f\u043e\u0434 \u0441\u043f\u043e\u0439\u043b\u0435\u0440\u043e\u043c. \u0412 \u0442\u0430\u0431\u043b\u0438\u0446\u0435 \u0438 \u0433\u0440\u0430\u0444\u0438\u043a\u0435 \u043d\u0438\u0436\u0435 \u0432\u0438\u0434\u043d\u043e \u0440\u0430\u0437\u043d\u0438\u0446\u0443 \u043c\u0435\u0436\u0434\u0443 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u043c \u0438 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u043c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435\u043c \u043a\u043e\u0434\u0430. \u041d\u043e \u044d\u0442\u043e \u043f\u0440\u0438 \u0442\u043e\u043c \u0443\u0441\u043b\u043e\u0432\u0438\u0438, \u0447\u0442\u043e \u0442\u0430\u0441\u043a\u0438 \u0441\u043e\u0431\u0440\u0430\u043d\u044b \u0432 \u043c\u0430\u0441\u0441\u0438\u0432 \u0438 \u0434\u043b\u044f \u0438\u0445 \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043c\u0435\u0442\u043e\u0434 <code>Task.WaitAll<\/code>.<\/p>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<td colspan=\"2\" data-colwidth=\"109,118\" width=\"109\">\n<p align=\"center\">\u0421\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 \u043a\u043e\u0434<\/p>\n<\/td>\n<td colspan=\"2\" data-colwidth=\"108,130\" width=\"108\">\n<p align=\"center\">\u0421\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 \u043a\u043e\u0434 \u0441 Task.Run<\/p>\n<\/td>\n<td colspan=\"2\" data-colwidth=\"111,98\" width=\"111\">\n<p align=\"center\">\u0410\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 \u043a\u043e\u0434<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td data-colwidth=\"109\" width=\"109\">\n<p align=\"center\">\u041a\u043e\u043b-\u0432\u043e \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439<\/p>\n<\/td>\n<td data-colwidth=\"118\" width=\"118\">\n<p align=\"center\">\u0412\u0440\u0435\u043c\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f (ms)<\/p>\n<\/td>\n<td data-colwidth=\"108\" width=\"108\">\n<p align=\"center\">\u041a\u043e\u043b-\u0432\u043e \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439<\/p>\n<\/td>\n<td data-colwidth=\"130\" width=\"130\">\n<p align=\"center\">\u0412\u0440\u0435\u043c\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f (ms)<\/p>\n<\/td>\n<td data-colwidth=\"111\" width=\"111\">\n<p align=\"center\">\u041a\u043e\u043b-\u0432\u043e \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439<\/p>\n<\/td>\n<td data-colwidth=\"98\" width=\"98\">\n<p align=\"center\">\u0412\u0440\u0435\u043c\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f (ms)<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td data-colwidth=\"109\" width=\"109\">\n<p align=\"center\">1<\/p>\n<\/td>\n<td data-colwidth=\"118\" width=\"118\">\n<p align=\"center\">1093<\/p>\n<\/td>\n<td data-colwidth=\"108\" width=\"108\">\n<p align=\"center\">1<\/p>\n<\/td>\n<td data-colwidth=\"130\" width=\"130\">\n<p align=\"center\">1001<\/p>\n<\/td>\n<td data-colwidth=\"111\" width=\"111\">\n<p align=\"center\">1<\/p>\n<\/td>\n<td data-colwidth=\"98\" width=\"98\">\n<p align=\"center\">1010<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td data-colwidth=\"109\" width=\"109\">\n<p align=\"center\">10<\/p>\n<\/td>\n<td data-colwidth=\"118\" width=\"118\">\n<p align=\"center\">10009<\/p>\n<\/td>\n<td data-colwidth=\"108\" width=\"108\">\n<p align=\"center\">10<\/p>\n<\/td>\n<td data-colwidth=\"130\" width=\"130\">\n<p align=\"center\">1024<\/p>\n<\/td>\n<td data-colwidth=\"111\" width=\"111\">\n<p align=\"center\">10<\/p>\n<\/td>\n<td data-colwidth=\"98\" width=\"98\">\n<p align=\"center\">1005<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td data-colwidth=\"109\" width=\"109\">\n<p align=\"center\">50<\/p>\n<\/td>\n<td data-colwidth=\"118\" width=\"118\">\n<p align=\"center\">50050<\/p>\n<\/td>\n<td data-colwidth=\"108\" width=\"108\">\n<p align=\"center\">50<\/p>\n<\/td>\n<td data-colwidth=\"130\" width=\"130\">\n<p align=\"center\">2704<\/p>\n<\/td>\n<td data-colwidth=\"111\" width=\"111\">\n<p align=\"center\">50<\/p>\n<\/td>\n<td data-colwidth=\"98\" width=\"98\">\n<p align=\"center\">1003<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td data-colwidth=\"109\" width=\"109\">\n<p align=\"center\">100<\/p>\n<\/td>\n<td data-colwidth=\"118\" width=\"118\">\n<p align=\"center\">100099<\/p>\n<\/td>\n<td data-colwidth=\"108\" width=\"108\">\n<p align=\"center\">100<\/p>\n<\/td>\n<td data-colwidth=\"130\" width=\"130\">\n<p align=\"center\">5247<\/p>\n<\/td>\n<td data-colwidth=\"111\" width=\"111\">\n<p align=\"center\">100<\/p>\n<\/td>\n<td data-colwidth=\"98\" width=\"98\">\n<p align=\"center\">1015<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d6c\/ff2\/a72\/d6cff2a72928513293723b8cc215173a.svg\" alt=\"\u0413\u0440\u0430\u0444\u0438\u043a \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0433\u043e \u0438 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430\" title=\"\u0413\u0440\u0430\u0444\u0438\u043a \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0433\u043e \u0438 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430\" width=\"1100\" height=\"400\"\/><figcaption>\u0413\u0440\u0430\u0444\u0438\u043a \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0433\u043e \u0438 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430<\/figcaption><\/figure>\n<p>\u041a\u0430\u043a \u0432\u0438\u0434\u043d\u043e \u0438\u0437 \u0432\u044b\u0448\u0435 \u043f\u0435\u0440\u0435\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0438, \u0432 \u0438\u0434\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u0443\u0441\u043b\u043e\u0432\u0438\u044f\u0445 \u0438 \u043f\u0440\u0438 \u0431\u043e\u043b\u044c\u0448\u043e\u043c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0435 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0439 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 \u043a\u043e\u0434 \u043d\u0435\u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442 \u0441\u0432\u043e\u044e \u0437\u0430\u0434\u0430\u0447\u0443.<\/p>\n<details class=\"spoiler\">\n<summary>\u041a\u043e\u0434 \u0431\u0435\u043d\u0447\u043c\u0430\u0440\u043a\u043e\u0432<\/summary>\n<div class=\"spoiler__content\">\n<p>\u0421\u0440\u0430\u0437\u0443 \u0441\u043a\u0430\u0436\u0443, \u0447\u0442\u043e \u043d\u0435 \u0441\u0442\u0430\u043b \u043f\u0430\u0440\u0438\u0442\u044c\u0441\u044f \u043d\u0430 \u0441\u0447\u0451\u0442 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0437\u0430\u0432\u0435\u0441\u0442\u0438 \u0431\u0435\u043d\u0447\u043c\u0430\u0440\u043a\u0438 \u043f\u043e\u0434 BenchmarkDotNet, \u0442\u0430\u043a \u043a\u0430\u043a \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u0431\u0435\u0437 \u043a\u043e\u0441\u0442\u044b\u043b\u0435\u0439 \u043d\u0435 \u0445\u043e\u0447\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441\u043e \u0432\u0441\u0435\u043c, \u0447\u0442\u043e \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0441\u044f \u043a \u043c\u043d\u043e\u0433\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u043e\u0441\u0442\u0438 \u0438 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0441\u0442\u0438. \u0425\u043e\u0442\u044f \u044f \u0432\u0438\u0434\u0435\u043b \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u0444\u043e\u0440\u043a, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u0431\u0435\u043d\u0447\u043c\u0430\u0440\u043a\u0438 \u0441 \u043c\u043d\u043e\u0433\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u043e\u0441\u0442\u044c\u044e \u0438 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0441\u0442\u044c\u044e. \u041d\u043e \u0437\u0430\u0447\u0435\u043c \u043d\u0430\u043c \u043e\u043d, \u043a\u043e\u0433\u0434\u0430 \u0435\u0441\u0442\u044c \u0441\u0442\u0430\u0440\u044b\u0439-\u0434\u043e\u0431\u0440\u044b\u0439 Stopwatch?<\/p>\n<pre><code class=\"cs\">using System.Diagnostics;  namespace FluentAPI;  public class Program {     public static void Main(string[] args) {         foreach (var count in new int[] { 1, 10, 50, 100 })         {             Console.WriteLine($\"Count ops: {count} {{\");              var nonAsyncStopwatch = Stopwatch.StartNew();              Enumerable.Range(0, count)                 .Select(_ => FluentSQLQuery())                 .ToArray();                          Console.WriteLine($\"\\tNon-async: {nonAsyncStopwatch.ElapsedMilliseconds}ms\");              var syncInAsyncStopwatch = Stopwatch.StartNew();              var tasks = Enumerable.Range(0, count)                 .Select(_ => Task.Run(() => FluentSQLQuery()))                 .ToArray();             Task.WaitAll(tasks);              Console.WriteLine($\"\\tSync in async: {syncInAsyncStopwatch.ElapsedMilliseconds}ms\");              var asyncStopwatch = Stopwatch.StartNew();              var asyncTasks = Enumerable.Range(0, count)                 .Select(_ => FluentSQLQueryAsync())                 .ToArray();             Task.WaitAll(asyncTasks);              Console.WriteLine($\"\\tAsync: {asyncStopwatch.ElapsedMilliseconds}ms\\n}}\");         }     }     static List&lt;int> FluentSQLQuery() => FluentSQLConnection&lt;int>         .CreateConnection(builder => {             builder.ConnectionString = \"Data Source=.;Initial Catalog=FluentAPI;Integrated Security=True\";             builder.Data = Enumerable.Range(0, 10_000).ToList();         })         .Query(\"SELECT * FROM Numbers\")         .Where(n => n % 5 == 0)         .ToList();      static async Task&lt;List&lt;int>> FluentSQLQueryAsync() => await FluentSQLConnectionAsync&lt;int>         .CreateConnection(builder => {             builder.ConnectionString = \"Data Source=.;Initial Catalog=FluentAPI;Integrated Security=True\";             builder.Data = Enumerable.Range(0, 10_000).ToList();         })         .Query(\"SELECT * FROM Numbers\")         .Where(n => n % 5 == 0)         .ToListAsync(); }<\/code><\/pre>\n<\/p>\n<\/div>\n<\/details>\n<p><a class=\"anchor\" name=\"Optional_pattern\" id=\"Optional_pattern\"><\/a><\/p>\n<h3>Optional pattern<\/h3>\n<p>Optional pattern \u2014 \u043f\u0430\u0442\u0442\u0435\u0440\u043d, \u0441\u043e\u0433\u043b\u0430\u0441\u043d\u043e \u043a\u043e\u0442\u043e\u0440\u043e\u043c\u0443 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0443\u043f\u0430\u043a\u043e\u0432\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 Some&lt;T>; \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 \u043e\u0448\u0438\u0431\u043a\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0432\u0430\u0440\u0438\u0430\u043d\u0442 Some&lt;T, Error>, \u0430 \u043f\u0440\u0438 \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0438\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0432\u043e\u0432\u0441\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 None&lt;T>. <\/p>\n<p>\u0414\u0430\u043d\u043d\u044b\u0439 \u043f\u0430\u0442\u0442\u0435\u0440\u043d \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u044c try\\catch \u0438\u043b\u0438, \u0432 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u043f\u0438\u0441\u0430\u0442\u044c \u0431\u0435\u0437 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u043e\u043a \u043d\u0430 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u043a\u043e\u0434 \u0432 Fluent-\u0441\u0442\u0438\u043b\u0435. \u041d\u0435\u0442, \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u0431\u0443\u0434\u0443\u0442, \u043d\u043e \u043e\u043d\u0438 \u0431\u0443\u0434\u0443\u0442 \u043b\u0430\u043a\u043e\u043d\u0438\u0447\u043d\u043e \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u044b \u0433\u0434\u0435-\u0442\u043e \u043f\u043e\u0441\u0435\u0440\u0435\u0434\u0438\u043d\u0435 \u0432\u044b\u0437\u043e\u0432\u043e\u0432 \u0434\u0440\u0443\u0433\u0438\u0445 \u043c\u0435\u0442\u043e\u0434\u043e\u0432.<\/p>\n<p>\u0411\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 <a href=\"https:\/\/github.com\/nlkl\/Optional\" rel=\"noopener noreferrer nofollow\">Optional <\/a>\u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0432 C# \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c Optional pattern. \u0412 \u0442\u0430\u043a\u0438\u0445 \u044f\u0437\u044b\u043a\u0430\u0445, \u043a\u0430\u043a Rust \u0438 Swift, \u0434\u0430\u043d\u043d\u044b\u0439 \u043f\u0430\u0442\u0442\u0435\u0440\u043d \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043f\u043e-\u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e. \u041d\u0430 \u0441\u0447\u0451\u0442 Swift \u043d\u0435 \u0443\u0432\u0435\u0440\u0435\u043d, \u043d\u043e \u0432 Rust \u0438\u0437-\u0437\u0430 \u044d\u0442\u043e\u0433\u043e \u043f\u0440\u043e\u0441\u0442\u043e-\u043d\u0430\u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u044e\u0442 \u0441\u0442\u0435\u0439\u0442\u043c\u0435\u043d\u0442\u044b try\\catch.<\/p>\n<p>\u041d\u0438\u0436\u0435 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u043f\u0440\u0438\u043c\u0435\u0440 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f Optional pattern \u0441 Fluent API:<\/p>\n<pre><code class=\"cs\">using Microsoft.Data.SqlClient; using Optional;  namespace FluentAPI.Optional;  public record FluentSQLConnectionBuilder&lt;TData> {     public string ConnectionString { get; set; }     public List&lt;TData> Data { get; set; } }  public sealed class FluentSQLConnection&lt;TData> {     IEnumerable&lt;TData> _data;     SqlConnection _connection;      FluentSQLConnection(string connectionString, IEnumerable&lt;TData> data)     {         _connection = new SqlConnection(connectionString);         _data = data;     }      public static FluentSQLConnection&lt;TData> CreateConnection(Action&lt;FluentSQLConnectionBuilder&lt;TData>> configureConnection = null!)     {         var builder = new FluentSQLConnectionBuilder&lt;TData>() {              ConnectionString = String.Empty,             Data = new List&lt;TData>()          };         configureConnection?.Invoke(builder);         return new FluentSQLConnection&lt;TData>(builder.ConnectionString, builder.Data);     }      public Option&lt;IEnumerable&lt;TData>,QueryError> Query(string sql)     {         Task.Delay(1000).Wait();          return Option.Some&lt;IEnumerable&lt;TData>,QueryError>(_data);     }      public Option&lt;IEnumerable&lt;TData>,QueryError> QueryWithoutResult(string sql)     {         Task.Delay(1000).Wait();          return Option.None&lt;IEnumerable&lt;TData>,QueryError>(new QueryError());     }      public record struct QueryError(string Message = \"Query Error\"); }<\/code><\/pre>\n<pre><code class=\"cs\">using Optional.Unsafe;  namespace FluentAPI;  public class Program {     public static void Main(string[] args) {         var data = FluentAPI.Optional.FluentSQLConnection&lt;int>             .CreateConnection()             .Query(\"SELECT * FROM Table\")             .ValueOr(new int[] { 1, 2, 3, 4, 5 })             .Where(n => n % 5 == 0)             .ToList();          PrintList(data);          var data1 = FluentAPI.Optional.FluentSQLConnection&lt;int>             .CreateConnection()             .QueryWithoutResult(\"SELECT * FROM Table\")             .ValueOrFailure()             .Where(n => n % 2 == 0)             .ToList();          PrintList(data1);     }     static void PrintList&lt;T>(IEnumerable&lt;T> data)     {         Console.WriteLine(\"Data: [\");         foreach (var item in data)         {             Console.WriteLine($\"\\t{item}\");         }         Console.WriteLine(\"]\");     } }<\/code><\/pre>\n<p>\u041e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u043c\u0435\u0442\u043e\u0434\u044b <code>ValueOr<\/code> \u0438 <code>ValueOrFailure<\/code>, \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0435 \u043d\u0430 10 \u0438 19 \u0441\u0442\u0440\u043e\u043a\u0430\u0445 \u0432\u0442\u043e\u0440\u043e\u0433\u043e \u043b\u0438\u0441\u0442\u0438\u043d\u0433\u0430. \u041f\u0435\u0440\u0432\u044b\u0439 \u043c\u0435\u0442\u043e\u0434, \u0435\u0441\u043b\u0438 \u043e\u0431\u043d\u0430\u0440\u0443\u0436\u0438\u0432\u0430\u0435\u0442, \u0447\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0435\u043d <code>None<\/code>, \u0442\u043e \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u043e\u0431\u044a\u0435\u043a\u0442, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u044b\u043b \u0435\u043c\u0443 \u043f\u0435\u0440\u0435\u0434\u0430\u043d \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430, \u0438\u043d\u0430\u0447\u0435 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u043e\u0431\u044a\u0435\u043a\u0442 \u0438\u0437 <code>Option<\/code>. \u0412\u0442\u043e\u0440\u043e\u0439 \u0436\u0435 \u043c\u0435\u0442\u043e\u0434 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0432\u044b\u043a\u0438\u043d\u0443\u0442\u044c \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435, \u0435\u0441\u043b\u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u043b <code>None<\/code>. <\/p>\n<p>\u041c\u0438\u043d\u0443\u0441 \u0432\u0442\u043e\u0440\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043d\u0435\u043b\u044c\u0437\u044f \u043d\u0430\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u043f\u043e\u0434 \u0441\u0435\u0431\u044f \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u044d\u0442\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u043a\u0430\u043a\u0443\u044e-\u043b\u0438\u0431\u043e \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u043e\u0431 \u043e\u0448\u0438\u0431\u043a\u0430\u0445. \u041e\u0434\u043d\u0430\u043a\u043e \u044d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u0440\u0430\u0432\u0438\u0442\u044c, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u043c\u0435\u0442\u043e\u0434 <code>Match<\/code>. \u0421 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 \u043c\u043e\u0436\u043d\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u043f\u0440\u0438 \u0442\u043e\u043c \u0438\u043b\u0438 \u0438\u043d\u043e\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0435. \u0412\u043e\u0442 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0439 \u043f\u0440\u0438\u043c\u0435\u0440:<\/p>\n<pre><code class=\"cs\">var data1 = FluentAPI.Optional.FluentSQLConnection&lt;int>             .CreateConnection()             .QueryWithoutResult(\"SELECT * FROM Table\")             .Match(                 some: d => d,                 none: e => throw new Exception(e.Message)             )             .Where(n => n % 2 == 0)             .ToList();    PrintList(data1);<\/code><\/pre>\n<p>\u041a\u0430\u043a \u0432\u0438\u0434\u043d\u043e \u0438\u0437 \u043a\u043e\u0434\u0430, \u043c\u0435\u0442\u043e\u0434 <code>Match<\/code> \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u044b. \u0414\u0435\u043b\u0435\u0433\u0430\u0442 <code>some<\/code> \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 \u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u0435\u0441\u043b\u0438 <code>Option<\/code> \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f <code>Some<\/code>, \u0438 \u0435\u043c\u0443 \u043f\u0435\u0440\u0435\u0434\u0430\u0451\u0442\u0441\u044f \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430 \u0443\u043f\u0430\u043a\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0432 \u0432\u044b\u0448\u0435\u0443\u043f\u043e\u043c\u044f\u043d\u0443\u0442\u0443\u044e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 \u043e\u0431\u044a\u0435\u043a\u0442. \u041d\u0430\u0434 \u043d\u0438\u043c \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0441\u0442\u0438 \u043a\u0430\u043a\u0438\u0435-\u0442\u043e \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f, \u043d\u043e, \u0447\u0430\u0449\u0435 \u0432\u0441\u0435\u0433\u043e, \u0435\u0433\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u044e\u0442. \u0412\u0442\u043e\u0440\u043e\u0439 \u0434\u0435\u043b\u0435\u0433\u0430\u0442 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0438\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f, \u043e\u0431\u043e\u0437\u043d\u0430\u0447\u0435\u043d\u043d\u043e\u0435 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043e\u0439 <code>None<\/code>. \u0422\u0430\u043c \u043c\u043e\u0436\u043d\u043e \u0432\u0435\u0440\u043d\u0443\u0442\u044c \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0438\u043b\u0438 \u0432\u044b\u043a\u0438\u043d\u0443\u0442\u044c \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0435 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435, \u043a\u0430\u043a \u044d\u0442\u043e \u0438 \u0441\u0434\u0435\u043b\u0430\u043d\u043e \u0432 \u043f\u0440\u0438\u043c\u0435\u0440\u0435 \u0432\u044b\u0448\u0435.<\/p>\n<p>\u0422\u0430\u043a\u0436\u0435 \u043c\u043e\u0436\u043d\u043e \u0441\u043a\u0430\u0437\u0430\u0442\u044c \u043f\u0440\u043e \u043c\u0435\u0442\u043e\u0434 <code>ValueOrDefault<\/code>, \u043e\u0434\u043d\u0430\u043a\u043e \u043e\u043d \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0432 \u043d\u0435\u0439\u043c\u0441\u043f\u0435\u0439\u0441\u0435 <code>Optional.Unsafe<\/code>, \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0433\u043e\u0432\u043e\u0440\u0438\u0442 \u0441\u0430\u043c\u043e \u0437\u0430 \u0441\u0435\u0431\u044f. \u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u044d\u0442\u043e\u0442 \u0438\u043b\u0438 \u0434\u0440\u0443\u0433\u0438\u0435 \u043c\u0435\u0442\u043e\u0434\u044b \u0438\u0437 \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0430 \u0438\u043c\u0451\u043d \u043d\u0435 \u0436\u0435\u043b\u0430\u0442\u0435\u043b\u044c\u043d\u043e. \u041b\u0443\u0447\u0448\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0442\u0441\u044f \u0442\u0435\u043c\u0438, \u0447\u0442\u043e \u043d\u0430\u0445\u043e\u0434\u044f\u0442\u0441\u044f \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u043c \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435 \u0438\u043c\u0451\u043d \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438.<\/p>\n<p><a class=\"anchor\" name=\"%D0%98%D1%82%D0%BE%D0%B3%D0%BE\" id=\"\u0418\u0442\u043e\u0433\u043e\"><\/a><\/p>\n<h2>\u0418\u0442\u043e\u0433\u043e<\/h2>\n<p>\u0418\u0437 \u0432\u0441\u0435\u0433\u043e \u0432\u044b\u0448\u0435\u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u043e\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432\u044b\u0432\u043e\u0434\u044b, \u0447\u0442\u043e Fluent API \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043f\u043e\u043b\u0435\u0437\u043d\u0430\u044f \u0434\u0438\u0437\u0430\u0439\u043d-\u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0441 \u043b\u0451\u0433\u043a\u043e\u0441\u0442\u044c\u044e \u0440\u0443\u043a\u043e\u0432\u043e\u0434\u0438\u0442\u044c \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0441\u0432\u043e\u0439\u0441\u0442\u0432 \u043a\u043e\u043d\u0435\u0447\u043d\u043e\u0433\u043e \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0430 \u0438 \u0440\u0430\u0431\u043e\u0442\u044b \u043c\u0435\u0442\u043e\u0434\u043e\u0432, \u0430 \u0442\u0430\u043a\u0436\u0435 \u043a\u0430\u043a \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0443 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0433\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043a\u043e\u0434\u0430. \u0422\u0430\u043a\u0436\u0435 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0432\u044b\u0448\u0435\u043e\u0431\u043e\u0437\u043d\u0430\u0447\u0435\u043d\u043d\u043e\u0433\u043e Optional pattern \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u0443\u044e \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0439 \u0438 \u043e\u0448\u0438\u0431\u043e\u043a, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044f \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u0438\u0445, \u043d\u0435 \u0432\u044b\u0445\u043e\u0434\u044f \u0438\u0437 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 Fluent API.<\/p>\n<p>\u0421\u0442\u043e\u0438\u0442 \u0442\u0430\u043a\u0436\u0435 \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u0447\u0442\u043e \u0434\u0430\u043d\u043d\u044b\u0439 API-\u0434\u0438\u0437\u0430\u0439\u043d \u043d\u0435 \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u044b\u0439, \u0438 \u043d\u0443\u0436\u043d\u043e \u043f\u043e\u0434\u0443\u043c\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u0434 \u0442\u0435\u043c, \u043a\u0430\u043a \u0435\u0433\u043e \u0441\u0443\u0432\u0430\u0442\u044c \u0432\u0435\u0437\u0434\u0435, \u043a\u0443\u0434\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u043c\u043e\u0436\u043d\u043e. \u0412\u0435\u0434\u044c \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043d\u0430\u0438\u0431\u043e\u043b\u0435\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u044b\u043c \u0438\u043b\u0438 \u0431\u043e\u043b\u0435\u0435 \u043b\u0435\u0433\u043a\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c\u044b\u043c.<\/p>\n<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"v-portal\" style=\"display:none;\"><\/div>\n<\/div>\n<p> <!----> <!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/post\/695966\/\"> https:\/\/habr.com\/ru\/post\/695966\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041d\u0435\u0434\u0430\u0432\u043d\u043e \u044f \u0437\u0430\u0445\u043e\u0442\u0435\u043b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0431\u043e\u043b\u0435\u0435 \u0443\u0434\u043e\u0431\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 \u043a\u043e\u0435-\u043a\u0430\u043a\u0438\u043c \u043a\u043b\u0430\u0441\u0441\u043e\u043c \u0432 \u043e\u0434\u043d\u043e\u043c \u0438\u0437 \u043c\u043e\u0434\u0443\u043b\u0435\u0439 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f. \u0422\u043e\u0433\u0434\u0430-\u0442\u043e \u044f \u0432\u0441\u043f\u043e\u043c\u043d\u0438\u043b \u043f\u0440\u043e Fluent API, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432 \u043c\u043e\u0451\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043e\u0447\u0435\u043d\u044c \u0445\u043e\u0440\u043e\u0448\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u043b.<\/p>\n<p>\u042f \u043d\u0430\u0448\u0451\u043b \u043a\u0443\u0447\u0443 \u043e\u0431\u044a\u044f\u0441\u043d\u0435\u043d\u0438\u0439 \u0438 \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u0432 \u043a\u043e\u0434\u0430 \u0434\u043b\u044f \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 Fluent API, \u043e\u0434\u043d\u0430\u043a\u043e \u044f \u043d\u0435 \u043c\u043e\u0433 \u043d\u0430\u0439\u0442\u0438 \u0432\u043d\u044f\u0442\u043d\u044b\u0445 \u043e\u0431\u044a\u044f\u0441\u043d\u0435\u043d\u0438\u0439, \u043a\u0430\u043a \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0432 \u044d\u0442\u043e\u043c \u0436\u0435 Fluent API \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0435 \u043c\u0435\u0442\u043e\u0434\u044b, \u0430\u043a\u0438 \u0434\u0435\u043b\u0430\u0435\u0442 \u044d\u0442\u043e \u043a\u0430\u043a\u043e\u0439-\u043d\u0438\u0431\u0443\u0434\u044c Linq. \u0411\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 \u043a\u0430\u043a\u0443\u044e-\u0442\u043e \u044d\u043b\u044c\u0444\u0438\u0439\u0441\u043a\u0443\u044e \u043c\u0430\u0433\u0438\u044e, \u043d\u043e \u044f \u043d\u0430\u0448\u0451\u043b \u0434\u0440\u0430\u0439\u0432\u0435\u0440 MongoDB, \u043d\u0430 \u0438\u0441\u0445\u043e\u0434\u043d\u043e\u043c \u043a\u043e\u0434\u0435 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u044f \u0438 \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u043b\u0441\u044f, \u043a\u0430\u043a \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 Fluent API.<\/p>\n<h2>\u0421\u043e\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u0435<\/h2>\n<ol>\n<li>\n<p><a href=\"#%D0%A7%D1%82%D0%BE_%D1%82%D0%B0%D0%BA%D0%BE%D0%B5_FluentAPI\" rel=\"noopener noreferrer nofollow\">\u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 Fluent API<\/a>;<\/p>\n<\/li>\n<li>\n<p><a href=\"#%D0%A0%D0%B5%D0%B0%D0%BB%D0%B8%D0%B7%D1%83%D0%B5%D0%BC_%D0%B0%D1%81%D0%B8%D0%BD%D1%85%D1%80%D0%BE%D0%BD%D0%BD%D1%8B%D0%B9_FluentAPI\" rel=\"noopener noreferrer nofollow\">\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 Fluent API<\/a>:<\/p>\n<ol>\n<li>\n<p><a href=\"#%D0%93%D0%BE%D1%82%D0%BE%D0%B2%D0%B8%D0%BC%D1%81%D1%8F_%D1%82%D0%B2%D0%BE%D1%80%D0%B8%D1%82%D1%8C\" rel=\"noopener noreferrer nofollow\">\u0413\u043e\u0442\u043e\u0432\u0438\u043c\u0441\u044f \u0442\u0432\u043e\u0440\u0438\u0442\u044c<\/a>;<\/p>\n<\/li>\n<li>\n<p><a href=\"#%D0%94%D0%B5%D0%BB%D0%B0%D0%B5%D0%BC_%D1%81%D0%BA%D0%B5%D0%BB%D0%B5%D1%82_%D0%BF%D1%80%D0%B8%D0%BB%D0%BE%D0%B6%D0%B5%D0%BD%D0%B8%D1%8F\" rel=\"noopener noreferrer nofollow\">\u0414\u0435\u043b\u0430\u0435\u043c \u0441\u043a\u0435\u043b\u0435\u0442 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f<\/a>:<\/p>\n<ol>\n<li>\n<p><a href=\"#%D0%9F%D0%B5%D1%80%D0%B2%D1%8B%D0%B9_%D1%81%D0%BB%D1%83%D1%87%D0%B0%D0%B9\" rel=\"noopener noreferrer nofollow\">\u041f\u0435\u0440\u0432\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 Fluent API<\/a>;<\/p>\n<\/li>\n<li>\n<p><a href=\"#%D0%92%D1%82%D0%BE%D1%80%D0%BE%D0%B9_%D1%81%D0%BB%D1%83%D1%87%D0%B0%D0%B9\" rel=\"noopener noreferrer nofollow\">\u0412\u0442\u043e\u0440\u043e\u0439 \u0441\u043b\u0443\u0447\u0430\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 Fluent API<\/a>;<\/p>\n<\/li>\n<\/ol>\n<\/li>\n<li>\n<p><a href=\"#%D0%94%D0%BE%D0%B1%D0%B0%D0%B2%D0%BB%D1%8F%D0%B5%D0%BC_%D0%B0%D1%81%D0%B8%D0%BD%D1%85%D1%80%D0%BE%D0%BD%D0%BD%D0%BE%D1%81%D1%82%D1%8C\" rel=\"noopener noreferrer nofollow\">\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0441\u0442\u044c<\/a>;<\/p>\n<\/li>\n<\/ol>\n<\/li>\n<li>\n<p><a href=\"#Optional_pattern\" rel=\"noopener noreferrer nofollow\">Optional pattern<\/a>;<\/p>\n<\/li>\n<li>\n<p><a href=\"#%D0%98%D1%82%D0%BE%D0%B3%D0%BE\" rel=\"noopener noreferrer nofollow\">\u0418\u0442\u043e\u0433\u043e<\/a>.<\/p>\n<\/li>\n<\/ol>\n<p><a class=\"anchor\" name=\"%D0%A7%D1%82%D0%BE_%D1%82%D0%B0%D0%BA%D0%BE%D0%B5_FluentAPI\" id=\"\u0427\u0442\u043e_\u0442\u0430\u043a\u043e\u0435_FluentAPI\">entAPI&#187;><\/a><\/p>\n<h2>\u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 Fluent API<\/h2>\n<p>\u041d\u0435 \u0431\u0443\u0434\u0443 \u043f\u044b\u0442\u0430\u0442\u044c\u0441\u044f \u0441\u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u0435 Fluent API, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u043e\u0431\u0440\u0430\u0442\u0438\u043c\u0441\u044f \u043a \u0441\u0442\u0430\u0440\u043e\u0439-\u0434\u043e\u0431\u0440\u043e\u0439 <a href=\"https:\/\/en.wikipedia.org\/wiki\/Fluent_interface\" rel=\"noopener noreferrer nofollow\">\u0412\u0438\u043a\u0438\u043f\u0435\u0434\u0438\u0438<\/a>:<\/p>\n<blockquote>\n<p>    \u0412 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u043d\u043e\u0439 \u0438\u043d\u0436\u0435\u043d\u0435\u0440\u0438\u0438\u00a0<strong>Fluent API<\/strong>\u00a0\u2014<strong> <\/strong>\u044d\u0442\u043e\u00a0\u043e\u0431\u044a\u0435\u043a\u0442\u043d\u043e-\u043e\u0440\u0438\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439\u00a0API, \u0434\u0438\u0437\u0430\u0439\u043d \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0432 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0439 \u0441\u0442\u0435\u043f\u0435\u043d\u0438 \u0437\u0430\u0432\u0438\u0441\u0438\u0442 \u043e\u0442 \u0446\u0435\u043f\u043e\u0447\u043a\u0438 \u043c\u0435\u0442\u043e\u0434\u043e\u0432.\u00a0\u0415\u0433\u043e \u0446\u0435\u043b\u044c &#8212; \u043f\u043e\u0432\u044b\u0441\u0438\u0442\u044c \u0440\u0430\u0437\u0431\u043e\u0440\u0447\u0438\u0432\u043e\u0441\u0442\u044c \u043a\u043e\u0434\u0430 \u043f\u0443\u0442\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f DSL.\u00a0\u0422\u0435\u0440\u043c\u0438\u043d \u0431\u044b\u043b \u0432\u0432\u0435\u0434\u0435\u043d \u0432 2005 \u0433\u043e\u0434\u0443 \u042d\u0440\u0438\u043a\u043e\u043c \u042d\u0432\u0430\u043d\u0441\u043e\u043c \u0438 \u041c\u0430\u0440\u0442\u0438\u043d\u043e\u043c \u0424\u0430\u0443\u043b\u0435\u0440\u043e\u043c.<\/p>\n<\/blockquote>\n<p>\u0418\u0437 \u043d\u0435\u043f\u043e\u043d\u044f\u0442\u043d\u044b\u0445 \u0441\u043b\u043e\u0432 \u0432 \u044d\u0442\u043e\u043c \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u0438 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043b\u0438\u0448\u044c DSL. <strong>DSL<\/strong> &#8212; \u044d\u0442\u043e, \u0435\u0441\u043b\u0438 \u043f\u043e-\u0436\u0438\u0442\u0435\u0439\u0441\u043a\u0438, \u044f\u0437\u044b\u043a \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f, \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0439 \u0434\u043b\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0438 \u0432 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u043e\u0439 \u043f\u0440\u0435\u0434\u043c\u0435\u0442\u043d\u043e\u0439 \u043e\u0431\u043b\u0430\u0441\u0442\u0438. \u0414\u043b\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u0430, \u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435, \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0438\u0432\u0435\u0441\u0442\u0438 \u0442\u0430\u043a\u0438\u0435 \u044f\u0437\u044b\u043a\u0438, \u043a\u0430\u043a <a href=\"https:\/\/learn.microsoft.com\/en-us\/dotnet\/csharp\/programming-guide\/concepts\/linq\/\" rel=\"noopener noreferrer nofollow\"><em>LINQ<\/em><\/a><em>, <\/em><a href=\"https:\/\/practicum.yandex.ru\/blog\/chto-takoe-sql\/\" rel=\"noopener noreferrer nofollow\"><em>SQL<\/em><\/a><em>, <\/em><a href=\"https:\/\/graphql.org\/\" rel=\"noopener noreferrer nofollow\"><em>GraphQL<\/em><\/a><em>, <\/em><a href=\"https:\/\/metanit.com\/sharp\/tutorial\/7.4.php\" rel=\"noopener noreferrer nofollow\"><em>Regex<\/em><\/a><em>, <\/em><a href=\"https:\/\/habr.com\/ru\/company\/yandex\/blog\/484068\/\" rel=\"noopener noreferrer nofollow\"><em>gRPC<\/em><\/a><em>, <\/em><a href=\"https:\/\/lifehacker.ru\/chto-takoe-markdown\/\" rel=\"noopener noreferrer nofollow\"><em>Markdown<\/em><\/a><em> \u0438 \u0442.\u043f<\/em>, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u0435\u0434\u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d\u044b \u0434\u043b\u044f \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0439 \u0441 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0430\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u0445, \u043f\u043e\u0438\u0441\u043a\u0430 \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u0439 \u0432 \u0442\u0435\u043a\u0441\u0442\u0435 \u043f\u043e \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0430\u043c, \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u0441\u0435\u0442\u0435\u0432\u044b\u0445 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0444\u043e\u0440\u043c\u0430\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e. \u041a\u0441\u0442\u0430\u0442\u0438, \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0435 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0438 \u043f\u043e \u0442\u0438\u043f\u0443 <a href=\"https:\/\/habr.com\/ru\/post\/319270\/\" rel=\"noopener noreferrer nofollow\"><em>React<\/em><\/a> \u0438 <a href=\"https:\/\/specialties.bayt.com\/en\/specialties\/q\/1906\/is-jquery-a-dsl\/\" rel=\"noopener noreferrer nofollow\"><em>JQuery <\/em><\/a>\u0442\u0430\u043a\u0436\u0435 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0432\u043d\u0435\u0448\u043d\u0438\u043c\u0438 DSL \u0438 \u043d\u0430\u0437\u044b\u0432\u0430\u044e\u0442\u0441\u044f <strong>eDSL<\/strong>. \u0418\u0441\u0445\u043e\u0434\u044f \u0438\u0437 \u0432\u0442\u043e\u0440\u043e\u0439 \u0441\u0441\u044b\u043b\u043a\u0438 \u043d\u0430 \u0444\u043e\u0440\u0443\u043c \u043f\u0440\u043e JQuery \u043c\u043e\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432\u044b\u0432\u043e\u0434, \u0447\u0442\u043e \u0434\u0430\u043d\u043d\u044b\u0435 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0438 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f DSL \u0438\u0437-\u0437\u0430 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0431\u043e\u043b\u0435\u0435 \u0443\u0434\u043e\u0431\u043d\u043e\u0439 \u043f\u0440\u043e\u0441\u043b\u043e\u0439\u043a\u043e\u0439, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u043e\u0442\u043e\u043c \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0430 \u0432 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0439 Javascript-\u043a\u043e\u0434. \u041d\u0443, \u0438\u043b\u0438 \u0447\u0442\u043e-\u0442\u043e \u0442\u0430\u043a\u043e\u0435. \u0411\u043e\u043b\u0435\u0435 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u043f\u0440\u043e DSL \u043f\u0440\u043e\u0448\u0443 \u0432 \u044d\u0442\u0443 <a href=\"https:\/\/habr.com\/ru\/post\/94259\/\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u044e<\/a>, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u043e, \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e, DSL, \u0447\u0442\u043e \u0442\u0430\u043a\u043e\u0435 API \u0438 \u0434\u0440.<\/p>\n<p>\u0412 \u044d\u0442\u043e\u0439 <a href=\"https:\/\/dev.to\/mcc_ahmed\/building-your-first-async-fluent-api-using-interface-extension-methods-pattern-266a\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u0435<\/a> (\u0441\u0442\u0430\u0442\u044c\u044f, \u043a\u0441\u0442\u0430\u0442\u0438, \u0442\u043e\u0436\u0435 \u043f\u0440\u043e \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 Fluent API, \u043e\u0434\u043d\u0430\u043a\u043e \u0442\u0430\u043c \u043d\u0438\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e) \u043d\u0430\u0448\u0451\u043b \u043f\u0440\u0438\u043c\u0435\u0440 \u043a\u043e\u0434\u0430 \u0432 Fluent-\u0441\u0442\u0438\u043b\u0435 \u0438 \u0435\u0433\u043e \u0430\u043d\u0430\u043b\u043e\u0433\u0435 \u0432 \u0438\u043c\u043f\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u043e\u043c \u0441\u0442\u0438\u043b\u0435, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u043d\u044f\u0442\u044c, \u0432 \u0447\u0451\u043c \u043f\u0440\u0435\u043b\u0435\u0441\u0442\u044c Fluent API:<\/p>\n<pre><code class=\"cs\">var data = await GetNewsAsync()          .Where(newsList => newsList.Date >= DateTime.Today)          .SelectMany(newsList => newsList.NewsItems)          .ToList();<\/code><\/pre>\n<pre><code class=\"cs\">var newsList = await GetNewsAsync();  if (newsList.Date >= DateTime.Today) {    return newsList.Select(news=>news.NewsItems).ToList(); }  return new List&lt;NewsItem>();<\/code><\/pre>\n<p>\u041a\u0430\u043a \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u0442\u044c \u0438\u0437 \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u0432 \u0432\u044b\u0448\u0435, Fluent API \u0434\u0435\u043b\u0430\u0435\u0442 \u043a\u043e\u0434 \u0431\u043e\u043b\u0435\u0435 \u043a\u043e\u043c\u043f\u0430\u043a\u0442\u043d\u044b\u043c \u0438, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0431\u043e\u043b\u0435\u0435 \u0447\u0438\u0442\u0430\u0435\u043c\u044b\u043c, \u0447\u0442\u043e \u0435\u0441\u0442\u044c \u043e\u0434\u043d\u043e\u0437\u043d\u0430\u0447\u043d\u043e \u0445\u043e\u0440\u043e\u0448\u043e.<\/p>\n<p><a class=\"anchor\" name=\"%D0%A0%D0%B5%D0%B0%D0%BB%D0%B8%D0%B7%D1%83%D0%B5%D0%BC_%D0%B0%D1%81%D0%B8%D0%BD%D1%85%D1%80%D0%BE%D0%BD%D0%BD%D1%8B%D0%B9_FluentAPI\" id=\"\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c_\u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439_FluentAPI\">\u043d\u043d\u044b\u0439_FluentAPI&#187;><\/a><\/p>\n<h2>\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 Fluent API<\/h2>\n<p>\u0414\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430, \u0434\u0443\u043c\u0430\u044e, \u0441\u0442\u043e\u0438\u0442 \u043d\u0430\u0447\u0430\u0442\u044c \u0441 \u043f\u0440\u043e\u0441\u0442\u043e\u0433\u043e \u0438 \u0438\u0434\u0442\u0438 \u0434\u0430\u043b\u044c\u0448\u0435, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0434\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440 SQL-\u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0442\u0430\u043a\u0436\u0435 \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435 \u0438\u0437 \u0411\u0414 (\u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0431\u0443\u0434\u0435\u0442 \u044f\u0432\u043b\u044f\u0442\u044c\u0441\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u043f\u0438\u0441\u043e\u043a).<\/p>\n<p>\u041a\u0441\u0442\u0430\u0442\u0438, \u0434\u043b\u044f \u0442\u0435\u0445, \u043a\u0442\u043e \u043c\u0430\u043b\u043e \u0437\u043d\u0430\u043a\u043e\u043c \u0441 \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u043c \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\u043c, \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0443\u044e \u043a \u043f\u0440\u043e\u0447\u0442\u0435\u043d\u0438\u044e \u0432\u043e\u0442 \u044d\u0442\u0443 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u0443\u044e <a href=\"https:\/\/habr.com\/ru\/post\/470830\/#conception\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u044e<\/a>.<\/p>\n<p><a class=\"anchor\" name=\"%D0%93%D0%BE%D1%82%D0%BE%D0%B2%D0%B8%D0%BC%D1%81%D1%8F_%D1%82%D0%B2%D0%BE%D1%80%D0%B8%D1%82%D1%8C\" id=\"\u0413\u043e\u0442\u043e\u0432\u0438\u043c\u0441\u044f_\u0442\u0432\u043e\u0440\u0438\u0442\u044c\">\u0442\u0432\u043e\u0440\u0438\u0442\u044c&#187;><\/a><\/p>\n<h3>\u0413\u043e\u0442\u043e\u0432\u0438\u043c\u0441\u044f \u0442\u0432\u043e\u0440\u0438\u0442\u044c<\/h3>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0438 \u043f\u0440\u043e\u0435\u043a\u0442 \u0433\u0434\u0435-\u0442\u043e \u043d\u0430 \u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u0435 \u0438 \u043e\u0442\u043a\u0440\u043e\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0432 \u0432\u0441\u0435\u043c\u0438 \u043b\u044e\u0431\u0438\u043c\u043e\u043c <a href=\"https:\/\/visualstudio.microsoft.com\/ru\/\" rel=\"noopener noreferrer nofollow\">Visual Studio Code<\/a> \u0441 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u043c \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u043c <a href=\"https:\/\/marketplace.visualstudio.com\/items?itemName=ms-dotnettools.csharp\" rel=\"noopener noreferrer nofollow\">\u043f\u043b\u0430\u0433\u0438\u043d\u043e\u043c \u0434\u043b\u044f C#<\/a> \u0438 <a href=\"https:\/\/marketplace.visualstudio.com\/items?itemName=GitHub.copilot\" rel=\"noopener noreferrer nofollow\">Github Copilot<\/a> (\u043c\u043e\u0439 \u0440\u0435\u043a\u043e\u043c\u0435\u0434\u043e\u0441\u044c\u0451\u043d), \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b, \u0435\u0441\u043b\u0438 \u043a\u043e\u043c\u0443 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e:<\/p>\n<pre><code class=\"bash\">$ dotnet new sln $ dotnet new console -o .\/src\/FluentAPI $ dotnet sln add .\/src\/FluentAPI $ code .<\/code><\/pre>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0435\u0440\u0435\u0439\u0434\u0451\u043c \u043a \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044e \u043a\u043e\u0434\u0430&#8230;<\/p>\n<figure class=\"full-width\"><figcaption>\u0415\u043d\u043e\u0442\u0438\u043a, \u0433\u043e\u0442\u043e\u0432\u044b\u0439 \u043a\u043e\u0434\u0438\u0442\u044c<\/figcaption><\/figure>\n<p><a class=\"anchor\" name=\"%D0%94%D0%B5%D0%BB%D0%B0%D0%B5%D0%BC_%D1%81%D0%BA%D0%B5%D0%BB%D0%B5%D1%82_%D0%BF%D1%80%D0%B8%D0%BB%D0%BE%D0%B6%D0%B5%D0%BD%D0%B8%D1%8F\" id=\"\u0414\u0435\u043b\u0430\u0435\u043c_\u0441\u043a\u0435\u043b\u0435\u0442_\u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f\">\u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f&#187;><\/a><\/p>\n<h3>\u0414\u0435\u043b\u0430\u0435\u043c \u0441\u043a\u0435\u043b\u0435\u0442 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f<\/h3>\n<p>\u041d\u0430\u0448\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u0438\u0437 \u00ab\u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445\u00bb \u0434\u0430\u043d\u043d\u044b\u0435 (\u043a\u0430\u043a \u044f \u043b\u044e\u0431\u043b\u044e \u0442\u0430\u0432\u0442\u043e\u043b\u043e\u0433\u0438\u044e), \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0443\u0434\u0443\u0442 \u043a\u0430\u043a\u0438\u043c\u0438-\u0442\u043e \u0447\u0438\u0441\u043b\u0430\u043c\u0438, \u0437\u0430\u0442\u0435\u043c \u0432\u044b\u0432\u043e\u0434\u0438\u0442\u044c \u044d\u0442\u0438 \u0447\u0438\u0441\u043b\u0430 \u0432 \u0442\u0435\u0440\u043c\u0438\u043d\u0430\u043b.<\/p>\n<p>\u0421 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435\u043c \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u043b\u0438\u0441\u044c, \u0442\u0435\u043f\u0435\u0440\u044c \u0438\u0434\u0451\u043c \u0432 \u0444\u0430\u0439\u043b <code>Program.cs<\/code>, \u043d\u0430\u0445\u043e\u0434\u044f\u0449\u0438\u0439\u0441\u044f \u0432 \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u043e\u043c \u043f\u043e \u043f\u0443\u0442\u0438 <code>.\/src\/FluentAPI<\/code> \u043f\u0440\u043e\u0435\u043a\u0442\u0435, \u0433\u0434\u0435 \u043c\u0435\u043d\u044f\u0435\u043c \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u0444\u0430\u0439\u043b\u0430 \u043d\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<pre><code class=\"cs\">namespace FluentAPI;  public class Program {     public static void Main(string[] args) {         var numbers = FluentSQLConnection&lt;int>             \/\/  \u0421 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 CreateConnection \u0441\u043e\u0437\u0434\u0430\u0451\u043c \u0438              \/\/  \u043d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u043c \u044d\u043a\u0437\u0435\u043c\u043b\u044f\u0440 \u043a\u043b\u0430\u0441\u0441\u0430 FluentSQLConnection             .CreateConnection(builder => {                 builder.ConnectionString = \"Data Source=.;Initial Catalog=FluentAPI;Integrated Security=True\";                 builder.Data = Enumerable.Range(0, 100).ToList();             })             .Query(\"SELECT * FROM Numbers\") \/\/  \u0412\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u0437\u0430\u043f\u0440\u043e\u0441 \u043a \u0431\u0430\u0437\u0435 \u0434\u0430\u043d\u043d\u044b\u0445             .Where(n => n % 2 == 0) \/\/  \u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u0442\u043e\u043b\u044c\u043a\u043e \u0447\u0451\u0442\u043d\u044b\u0435 \u0447\u0438\u0441\u043b\u0430             .ToList(); \/\/  \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0432 \u0432\u0438\u0434\u0435 \u0441\u043f\u0438\u0441\u043a\u0430          \/\/  \u0412\u044b\u0432\u043e\u0434\u0438\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u044c         foreach (var number in numbers) {             System.Console.WriteLine(number);         }     } }<\/code><\/pre>\n<p>\u0418\u0437 \u043a\u043e\u0434\u0430 \u0432\u044b\u0448\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e, \u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435, \u0447\u0442\u043e \u043a\u043e\u0434 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c\u0441\u044f \u0430\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e. \u0410\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u043e\u0441\u0442\u044c \u0432\u0432\u0435\u0434\u0451\u043c \u043f\u043e\u0437\u0436\u0435. \u041a\u0441\u0442\u0430\u0442\u0438, \u043d\u0435 \u043e\u0431\u0440\u0430\u0449\u0430\u0439\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 <code>builder.Data = Enumerable.Range(0, 100).ToList();<\/code>, \u044d\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0432\u0432\u0435\u0441\u0442\u0438 \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0439 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a \u0434\u0430\u043d\u043d\u044b\u0445, \u0432\u0435\u0434\u044c \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0435\u0442\u0443.<\/p>\n<p>\u0410 \u0441\u0435\u0439\u0447\u0430\u0441 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u043a\u043b\u0430\u0441\u0441 <code>FluentSQLConnection<\/code>. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0444\u0430\u0439\u043b <code>FluentSQLConnection.cs<\/code>. \u041e\u0431\u044b\u0447\u043d\u043e Fluent API \u043b\u0438\u0448\u044c \u043c\u0435\u043d\u044f\u0435\u0442 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043a\u043b\u0430\u0441\u0441\u0430, \u043e\u0434\u043d\u0430\u043a\u043e, \u0432 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435, \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u0437\u0430\u043f\u0440\u0435\u0449\u0430\u0435\u0442 \u0432\u0435\u0440\u043d\u0443\u0442\u044c \u043c\u0435\u0442\u043e\u0434\u043e\u043c <code>Query(string)<\/code> \u0442\u0438\u043f <code>IEnumerable&lt;TData><\/code>. <\/p>\n<p><a class=\"anchor\" name=\"%D0%9F%D0%B5%D1%80%D0%B2%D1%8B%D0%B9_%D1%81%D0%BB%D1%83%D1%87%D0%B0%D0%B9\" id=\"\u041f\u0435\u0440\u0432\u044b\u0439_\u0441\u043b\u0443\u0447\u0430\u0439\">\u043b\u0443\u0447\u0430\u0439&#187;><\/a><\/p>\n<h4>\u041f\u0435\u0440\u0432\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439<\/h4>\n<pre><code class=\"cs\">using Microsoft.Data.SqlClient;  namespace FluentAPI;  public record FluentSQLConnectionBuilder&lt;TData> {     public string ConnectionString { get; set; }     public List&lt;TData> Data { get; set; } }  public interface IFluentSQLQuery&lt;TData> {     IFluentSQLSelection&lt;TData> Query(string sql); }  public interface IFluentSQLQueryResult&lt;TData> {     List&lt;TData> ToList(); }  public interface IFluentSQLSelection&lt;TData> : IFluentSQLQueryResult&lt;TData> {     IFluentSQLSelection&lt;TData> Where(Func&lt;TData, bool> predicate);  }  public sealed class FluentSQLConnection&lt;TData>     : IFluentSQLQuery&lt;TData>, IFluentSQLQueryResult&lt;TData>, IFluentSQLSelection&lt;TData> {     IEnumerable&lt;TData> _data;     IEnumerable&lt;TData> _queredData;     SqlConnection _connection;      FluentSQLConnection(string connectionString, IEnumerable&lt;TData> data)     {         _connection = new SqlConnection(connectionString);         _queredData = new List&lt;TData>();         _data = data;     }      public static IFluentSQLQuery&lt;TData> CreateConnection(Action&lt;FluentSQLConnectionBuilder&lt;TData>> configureConnection)     {         var builder = new FluentSQLConnectionBuilder&lt;TData>() {              ConnectionString = \"\",             Data = new List&lt;TData>()          };         configureConnection(builder);         return new FluentSQLConnection&lt;TData>(builder.ConnectionString, builder.Data);     }       IFluentSQLSelection&lt;TData> IFluentSQLQuery&lt;TData>.Query(string sql)     {         \/\/ _connection.Open();         \/\/ var command = new SqlCommand(sql, _connection);         \/\/ var reader = command.ExecuteReader();         \/\/ var data = new List&lt;TData>();         \/\/ while (reader.Read())         \/\/ {         \/\/     data.Add((TData)reader[0]);         \/\/ }         \/\/ _queredData = data;         \/\/ _connection.Close();          Task.Delay(1000).Wait();         _queredData = _data;          return this;     }      public IFluentSQLSelection&lt;TData> Where(Func&lt;TData, bool> predicate)     {         _queredData = _queredData.Where(predicate);         return this;     }      List&lt;TData> IFluentSQLQueryResult&lt;TData>.ToList() => _queredData.ToList(); }<\/code><\/pre>\n<details class=\"spoiler\">\n<summary>Microsoft.Data.SqlClient<\/summary>\n<div class=\"spoiler__content\">\n<p>\u0414\u043b\u044f \u0442\u0435\u0445, \u043a\u0442\u043e \u043d\u0435 \u0437\u043d\u0430\u0435\u0442, \u0442\u043e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 <code>Microsoft.Data.SqlClient<\/code>, \u043a\u043e\u0442\u043e\u0440\u0430\u044f, \u043f\u043e-\u0438\u0434\u0435\u0435, \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0447\u0430\u0441\u0442\u044c\u044e <a href=\"https:\/\/learn.microsoft.com\/ru-ru\/dotnet\/framework\/data\/adonet\/?redirectedfrom=MSDN\" rel=\"noopener noreferrer nofollow\">ADO.NET<\/a>, \u043d\u0443\u0436\u043d\u043e \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c \u0432 \u043f\u0440\u043e\u0435\u043a\u0442 \u0440\u0443\u0447\u043a\u0430\u043c\u0438. \u0414\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443, \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043e\u0442\u043a\u0440\u044b\u0442\u044c \u0442\u0435\u0440\u043c\u0438\u043d\u0430\u043b \u0432 VS Code \u0438 \u043d\u0430\u0431\u0440\u0430\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u043a\u043e\u043c\u0430\u043d\u0434\u0443:<\/p>\n<pre><code class=\"bash\">$ dotnet add .\/src\/FluentAPI package Microsoft.Data.SqlClient<\/code><\/pre>\n<p>\u041f\u0443\u0442\u044c \u043f\u043e\u0441\u043b\u0435 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0430 <code>add<\/code> \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u043f\u0440\u043e\u0435\u043a\u0442, \u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443, \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0438\u0434\u0451\u0442 \u043f\u043e\u0441\u043b\u0435 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0430 <code>package<\/code>, \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0449\u0438\u0439 \u0442\u0438\u043f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0432 \u043f\u0440\u043e\u0435\u043a\u0442: \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u0440\u043e\u0435\u043a\u0442 \u0438\u043b\u0438 \u043f\u0430\u043a\u0435\u0442 NuGet.<\/p>\n<\/div>\n<\/details>\n<p>\u041f\u043e \u043b\u043e\u0433\u0438\u043a\u0435 \u043d\u0430\u0448 \u043c\u0435\u0442\u043e\u0434 <code>Query(string)<\/code> \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0431\u0438\u0440\u0430\u0442\u044c \u043b\u0438\u0448\u044c \u0440\u0430\u0437, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0430\u0448 \u043a\u043b\u0430\u0441\u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043d\u044b\u0439 \u043f\u043e\u0434\u0445\u043e\u0434, \u0447\u0442\u043e \u0432\u044b\u0440\u0430\u0436\u0430\u0435\u0442\u0441\u044f \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0440\u0430\u043d\u0435\u0435 \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u0442\u044b\u0439 \u043c\u0435\u0442\u043e\u0434 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0442\u0438\u043f, \u043d\u0430\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 <code>IFluentSQLQueryResult&lt;TData><\/code>, \u0442\u043e \u0435\u0441\u0442\u044c \u043d\u0430\u0448 \u043a\u043b\u0430\u0441\u0441 <code>FluentSQLConnection&lt;TData><\/code>. \u0414\u0430\u043d\u043d\u044b\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 \u0442\u0430\u043a\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0442\u043e\u0433\u0434\u0430, \u043a\u043e\u0433\u0434\u0430 \u0432 \u043d\u0430\u0448\u0435\u043c \u043a\u043e\u043d\u0435\u0447\u043d\u043e\u043c \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0435 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0441\u0432\u043e\u0439\u0441\u0442\u0432. \u0413\u0434\u0435-\u0442\u043e \u043d\u0430 \u044d\u0442\u043e\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0432\u0438\u0434\u0435\u043e \u043e\u0431\u044a\u044f\u0441\u043d\u044f\u0435\u0442\u0441\u044f \u043d\u0430\u0433\u043b\u044f\u0434\u043d\u043e \u0442\u043e, \u043e \u0447\u0451\u043c \u044f \u0433\u043e\u0432\u043e\u0440\u044e \u0441\u0435\u0439\u0447\u0430\u0441:<\/p>\n<div class=\"tm-iframe_temp\" data-src=\"https:\/\/embedd.srv.habr.com\/iframe\/63559bdf0c924e8d4165ee8d\" data-style=\"\" id=\"63559bdf0c924e8d4165ee8d\" width=\"\"><\/div>\n<p>\u041a\u043b\u0430\u0441\u0441\u043d\u044b\u0439 \u0432\u0438\u0434\u043e\u0441, \u043a\u0430\u043a \u0438 \u043c\u043d\u043e\u0433\u0438\u0435 \u0434\u0440\u0443\u0433\u0438\u0435 \u0432\u0438\u0434\u0435\u043e \u043d\u0430 <a href=\"https:\/\/www.youtube.com\/watch?v=1JAdZul-aRQ&amp;list=RDCMUCrkPsvLGln62OMZRO6K-llg&amp;start_radio=1\" rel=\"noopener noreferrer nofollow\">\u043a\u0430\u043d\u0430\u043b\u0435 \u041d\u0438\u043a\u0430<\/a>. \u0415\u0441\u043b\u0438 \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e \u0432 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0435, \u0442\u043e \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0443\u044e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0434\u0430\u043d\u043d\u043e\u0435 \u0432\u0438\u0434\u0435\u043e. \u041a\u0441\u0442\u0430\u0442\u0438, \u0438\u043c\u0435\u043d\u043d\u043e \u043f\u0440\u0438\u043c\u0435\u0440 \u041d\u0438\u043a\u0430 \u044f \u0441\u0435\u0439\u0447\u0430\u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e.<\/p>\n<p>\u041a\u0430\u043a \u0440\u0430\u043d\u0435\u0435 \u0443\u043f\u043e\u043c\u0438\u043d\u0430\u043b\u043e\u0441\u044c, \u043d\u0435 \u043e\u0431\u0440\u0430\u0449\u0430\u0435\u043c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0432\u0441\u0451, \u0447\u0442\u043e \u0441\u0432\u044f\u0437\u0430\u043d\u043e \u0441 <code>Data<\/code> \u0438 <code>_data<\/code> \u0432 \u043a\u043b\u0430\u0441\u0441\u0435. \u041a\u0443\u0441\u043e\u043a \u0440\u0430\u0431\u043e\u0442\u044b \u0441 SQL-\u0437\u0430\u043f\u0440\u043e\u0441\u0430\u043c\u0438, \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0439 Github Copilot \u0432 \u043c\u0435\u0442\u043e\u0434\u0435 <code>IFluentSQLQuery.Query(string sql)<\/code>, \u0440\u0435\u0448\u0438\u043b \u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0430. \u041f\u0440\u0430\u0432\u0430, \u043a\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e\u0434\u043e\u0431\u043d\u044b\u0439 \u0432\u0435\u043b\u043e\u0441\u0438\u043f\u0435\u0434, \u043a\u043e\u0433\u0434\u0430 \u0435\u0441\u0442\u044c \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u0439 <a href=\"https:\/\/skillbox.ru\/media\/code\/entity_framework\/\" rel=\"noopener noreferrer nofollow\">Entity Framework<\/a> \u0438 \u043c\u0435\u043d\u0435\u0435 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u0439, \u043d\u043e \u0448\u0443\u0441\u0442\u0440\u044b\u0439 <a href=\"https:\/\/habr.com\/ru\/post\/665836\/\" rel=\"noopener noreferrer nofollow\">Dapper<\/a>? \u041d\u043e \u0432\u0441\u0451 \u0436\u0435.<\/p>\n<p><a class=\"anchor\" name=\"%D0%92%D1%82%D0%BE%D1%80%D0%BE%D0%B9_%D1%81%D0%BB%D1%83%D1%87%D0%B0%D0%B9\" id=\"\u0412\u0442\u043e\u0440\u043e\u0439_\u0441\u043b\u0443\u0447\u0430\u0439\">\u043b\u0443\u0447\u0430\u0439&#187;><\/a><\/p>\n<h4>\u0412\u0442\u043e\u0440\u043e\u0439 \u0441\u043b\u0443\u0447\u0430\u0439<\/h4>\n<pre><code class=\"cs\">using Microsoft.Data.SqlClient;  namespace FluentAPI;  public record FluentSQLConnectionBuilder&lt;TData> {     public string ConnectionString { get; set; }     public List&lt;TData> Data { get; set; } }  public sealed class FluentSQLConnection&lt;TData> {     IEnumerable&lt;TData> _data;     SqlConnection _connection;      FluentSQLConnection(string connectionString, IEnumerable&lt;TData> data)     {         _connection = new SqlConnection(connectionString);         _data = data;     }      public static FluentSQLConnection&lt;TData> CreateConnection(Action&lt;FluentSQLConnectionBuilder&lt;TData>> configureConnection)     {         var builder = new FluentSQLConnectionBuilder&lt;TData>() {              ConnectionString = \"\",             Data = new List&lt;TData>()          };         configureConnection(builder);         return new FluentSQLConnection&lt;TData>(builder<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-340381","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/340381","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=340381"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/340381\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=340381"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=340381"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=340381"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}