{"id":9136,"date":"2023-12-26T04:52:54","date_gmt":"2023-12-26T01:22:54","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%b2%d8%a8%d8%a7%d9%86%db%8c-%d8%b4%d8%a8%db%8c%d9%87-%d8%a8%d9%87-sql-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88\/"},"modified":"2023-12-26T04:52:54","modified_gmt":"2023-12-26T01:22:54","slug":"%da%86%da%af%d9%88%d9%86%d9%87-%d8%b2%d8%a8%d8%a7%d9%86%db%8c-%d8%b4%d8%a8%db%8c%d9%87-%d8%a8%d9%87-sql-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%b2%d8%a8%d8%a7%d9%86%db%8c-%d8%b4%d8%a8%db%8c%d9%87-%d8%a8%d9%87-sql-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88\/","title":{"rendered":"\u0686\u06af\u0648\u0646\u0647 \u0632\u0628\u0627\u0646\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 SQL \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627 \u062f\u0631 \u0645\u062e\u0627\u0632\u0646 \u0645\u062d\u0644\u06cc Git \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0645"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%b2%d8%a8%d8%a7%d9%86%db%8c-%d8%b4%d8%a8%db%8c%d9%87-%d8%a8%d9%87-sql-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88\/#%da%86%da%af%d9%88%d9%86%d9%87_%d9%85%db%8c_%d8%aa%d9%88%d8%a7%d9%86%db%8c%d8%af_%db%8c%da%a9_%d9%be%d8%b1%d8%b3_%d9%88_%d8%ac%d9%88%db%8c_%d8%b4%d8%a8%db%8c%d9%87_%d8%a8%d9%87_sql_%d8%a8%da%af%db%8c%d8%b1%db%8c%d8%af_%d9%88_%d8%a2%d9%86_%d8%b1%d8%a7_%d8%af%d8%b1_%d9%81%d8%a7%db%8c%d9%84_%d9%87%d8%a7%db%8c_git_%d8%a7%d8%ac%d8%b1%d8%a7_%da%a9%d9%86%db%8c%d8%af%d8%9f\" >\u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9 \u067e\u0631\u0633 \u0648 \u062c\u0648\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 SQL \u0628\u06af\u06cc\u0631\u06cc\u062f \u0648 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc git. \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f\u061f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%b2%d8%a8%d8%a7%d9%86%db%8c-%d8%b4%d8%a8%db%8c%d9%87-%d8%a8%d9%87-sql-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88\/#%da%86%da%af%d9%88%d9%86%d9%87_%db%8c%da%a9_%d8%b2%d8%a8%d8%a7%d9%86_%d9%be%d8%b1%d8%b3_%d9%88_%d8%ac%d9%88_%d8%b1%d8%a7_%d8%a7%d8%b2_%d8%a7%d8%a8%d8%aa%d8%af%d8%a7_%d8%b7%d8%b1%d8%a7%d8%ad%db%8c_%d9%88_%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%da%a9%d8%b1%d8%af%d9%85\" >\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0631\u0627 \u0627\u0632 \u0627\u0628\u062a\u062f\u0627 \u0637\u0631\u0627\u062d\u06cc \u0648 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0631\u062f\u0645<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%b2%d8%a8%d8%a7%d9%86%db%8c-%d8%b4%d8%a8%db%8c%d9%87-%d8%a8%d9%87-sql-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88\/#%d8%a7%d9%86%d8%aa%d8%ae%d8%a7%d8%a8_%db%8c%da%a9_%d8%b3%d8%a7%d8%ae%d8%aa%d8%a7%d8%b1_%d8%af%d8%a7%d8%af%d9%87_%d8%a8%d8%b1%d8%a7%db%8c_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87\" >\u0627\u0646\u062a\u062e\u0627\u0628 \u06cc\u06a9 \u0633\u0627\u062e\u062a\u0627\u0631 \u062f\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%b2%d8%a8%d8%a7%d9%86%db%8c-%d8%b4%d8%a8%db%8c%d9%87-%d8%a8%d9%87-sql-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88\/#%d8%aa%d8%b5%d9%85%db%8c%d9%85_%da%af%db%8c%d8%b1%db%8c_%d8%a8%d8%b1%d8%a7%db%8c_%d8%a7%d9%86%d8%ac%d8%a7%d9%85_%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c\" >\u062a\u0635\u0645\u06cc\u0645 \u06af\u06cc\u0631\u06cc \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%b2%d8%a8%d8%a7%d9%86%db%8c-%d8%b4%d8%a8%db%8c%d9%87-%d8%a8%d9%87-sql-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88\/#%d9%be%d8%b3_%d8%a7%d8%b2_%d8%aa%d8%a3%db%8c%db%8c%d8%af_%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1_%d8%af%d8%b1%d8%ae%d8%aa_%d9%86%d8%ad%d9%88_%d8%a7%d9%86%d8%aa%d8%b2%d8%a7%d8%b9%db%8c_%da%86%d9%87_%d8%a7%d8%aa%d9%81%d8%a7%d9%82%db%8c_%d9%85%db%8c_%d8%a7%d9%81%d8%aa%d8%af%d8%9f\" >\u067e\u0633 \u0627\u0632 \u062a\u0623\u06cc\u06cc\u062f \u0627\u0639\u062a\u0628\u0627\u0631 \u062f\u0631\u062e\u062a \u0646\u062d\u0648 \u0627\u0646\u062a\u0632\u0627\u0639\u06cc \u0686\u0647 \u0627\u062a\u0641\u0627\u0642\u06cc \u0645\u06cc \u0627\u0641\u062a\u062f\u061f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%b2%d8%a8%d8%a7%d9%86%db%8c-%d8%b4%d8%a8%db%8c%d9%87-%d8%a8%d9%87-sql-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88\/#%da%86%da%af%d9%88%d9%86%d9%87_%d8%a7%d8%b2_%d8%a7%d8%ac%d8%b1%d8%a7%db%8c_%d9%87%d9%85%d8%b2%d9%85%d8%a7%d9%86_%d8%a8%d8%b1_%d8%b1%d9%88%db%8c_%da%86%d9%86%d8%af%db%8c%d9%86_%d9%85%d8%ae%d8%b2%d9%86_%d9%be%d8%b4%d8%aa%db%8c%d8%a8%d8%a7%d9%86%db%8c_%da%a9%d9%86%db%8c%d9%85\" >\u0686\u06af\u0648\u0646\u0647 \u0627\u0632 \u0627\u062c\u0631\u0627\u06cc \u0647\u0645\u0632\u0645\u0627\u0646 \u0628\u0631 \u0631\u0648\u06cc \u0686\u0646\u062f\u06cc\u0646 \u0645\u062e\u0632\u0646 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u06a9\u0646\u06cc\u0645<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%b2%d8%a8%d8%a7%d9%86%db%8c-%d8%b4%d8%a8%db%8c%d9%87-%d8%a8%d9%87-sql-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ac%d8%b1%d8%a7%db%8c-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88\/#%d8%a8%d8%a7_%d8%aa%d8%b4%da%a9%d8%b1_%d8%a8%d8%b1%d8%a7%db%8c_%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86\" >\u0628\u0627 \u062a\u0634\u06a9\u0631 \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646!<\/a><\/li><\/ul><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 7<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<section class=\"post-content \" data-test-label=\"post-content\">\n<p>\u0633\u0644\u0627\u0645 \u0628\u0647 \u0647\u0645\u0647!  \u0645\u0646 \u06cc\u06a9 \u0645\u0647\u0646\u062f\u0633 \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631 \u0647\u0633\u062a\u0645 \u06a9\u0647 \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc \u0633\u0637\u062d \u067e\u0627\u06cc\u06cc\u0646\u060c \u06a9\u0627\u0645\u067e\u0627\u06cc\u0644\u0631\u0647\u0627 \u0648 \u062a\u0648\u0633\u0639\u0647 \u0627\u0628\u0632\u0627\u0631 \u0639\u0644\u0627\u0642\u0647 \u0645\u0646\u062f \u0647\u0633\u062a\u0645. <\/p>\n<p>\u0633\u0647 \u0645\u0627\u0647 \u067e\u06cc\u0634 \u062a\u0635\u0645\u06cc\u0645 \u06af\u0631\u0641\u062a\u0645 \u0632\u0628\u0627\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc Rust \u0631\u0627 \u06cc\u0627\u062f \u0628\u06af\u06cc\u0631\u0645 \u0648 \u06cc\u06a9 \u06a9\u0644\u0627\u06cc\u0646\u062a Git \u0628\u0633\u0627\u0632\u0645 \u06a9\u0647 \u0628\u0631 \u0633\u0627\u062f\u06af\u06cc \u0648 \u0628\u0647\u0631\u0647 \u0648\u0631\u06cc \u062a\u0645\u0631\u06a9\u0632 \u062f\u0627\u0631\u062f.<\/p>\n<p>\u0634\u0631\u0648\u0639 \u06a9\u0631\u062f\u0645 \u0628\u0647 \u0641\u06a9\u0631 \u06a9\u0631\u062f\u0646 \u062f\u0631 \u0645\u0648\u0631\u062f \u0627\u06cc\u0646\u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u06a9\u0644\u0627\u06cc\u0646\u062a Git \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u0631\u0627\u0626\u0647 \u0628\u0631\u062e\u06cc \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0645\u0646\u062d\u0635\u0631 \u0628\u0647 \u0641\u0631\u062f \u0648 \u0645\u0641\u06cc\u062f \u0628\u0633\u0627\u0632\u0645. <\/p>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0645\u0646 \u0635\u0641\u062d\u0647 \u062a\u062c\u0632\u06cc\u0647 \u0648 \u062a\u062d\u0644\u06cc\u0644 \u062f\u0631 GitHub \u0631\u0627 \u062f\u0648\u0633\u062a \u062f\u0627\u0631\u0645 \u06a9\u0647 \u0628\u0647 \u0634\u0645\u0627 \u0645\u06cc \u06af\u0648\u06cc\u062f \u0647\u0631 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u0686\u0646\u062f commit \u0627\u0646\u062c\u0627\u0645 \u062f\u0627\u062f\u0647 \u0627\u0633\u062a \u0648 \u0686\u0646\u062f \u062e\u0637 \u062f\u0631\u062c \u06cc\u0627 \u062d\u0630\u0641 \u06a9\u0631\u062f\u0647 \u0627\u0633\u062a.  \u0627\u0645\u0627 \u0627\u06af\u0631 \u0628\u062e\u0648\u0627\u0647\u0645 \u0627\u06cc\u0646 \u062a\u062d\u0644\u06cc\u0644 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0645\u062f\u062a\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u0645\u060c \u06cc\u0627 \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0631\u0627 \u0628\u0627 \u062e\u0637\u0648\u0637 \u062f\u0631\u062c \u0634\u062f\u0647 \u0648 \u0646\u0647 \u062a\u0639\u062f\u0627\u062f commit \u0647\u0627 \u0633\u0641\u0627\u0631\u0634 \u062f\u0647\u0645\u060c \u0686\u0647\u061f  \u06cc\u0627 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0631 \u0627\u0633\u0627\u0633 \u0686\u0646\u062f commit \u062f\u0631 \u0647\u0641\u062a\u0647 \u06cc\u0627 \u0645\u0627\u0647 \u0633\u0641\u0627\u0631\u0634 \u062f\u0647\u06cc\u062f\u061f <\/p>\n<p>\u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9 \u06af\u0632\u06cc\u0646\u0647 \u0645\u0631\u062a\u0628 \u0633\u0627\u0632\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u0628\u0631\u0627\u06cc \u0645\u0634\u062a\u0631\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f\u060c \u062f\u0631\u0633\u062a \u0627\u0633\u062a\u061f  \u0627\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0641\u06a9\u0631 \u06a9\u0631\u062f\u0645 \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0622\u0646 \u0631\u0627 \u067e\u0648\u06cc\u0627\u062a\u0631 \u06a9\u0646\u0645.  \u0627\u06cc\u0646 \u0628\u0647 \u0645\u0646 \u0627\u0646\u06af\u06cc\u0632\u0647 \u062f\u0627\u062f \u062a\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0641\u06a9\u0631 \u06a9\u0646\u0645 \u06a9\u0647 \u0622\u06cc\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 SQL \u0631\u0627 \u062f\u0631 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc .git \u0645\u062d\u0644\u06cc \u0627\u062c\u0631\u0627 \u06a9\u0646\u0645 \u062a\u0627 \u0628\u062a\u0648\u0627\u0646\u0645 \u0647\u0631 \u0627\u0637\u0644\u0627\u0639\u0627\u062a\u06cc \u0631\u0627 \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u0645 \u062c\u0633\u062a\u062c\u0648 \u06a9\u0646\u0645.<\/p>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u062a\u0635\u0648\u0631 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u067e\u0631\u0633 \u0648 \u062c\u0648\u06cc \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646 \u0631\u0627 \u062f\u0631 \u0645\u062e\u0627\u0632\u0646 git \u0645\u062d\u0644\u06cc \u062e\u0648\u062f \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"language-SQL\">SELECT name, COUNT(name) AS commit_num FROM commits GROUP BY name ORDER BY commit_num DESC LIMIT 10\n<\/code><\/pre>\n<p>\u0645\u0646 \u0627\u06cc\u0646 \u0627\u06cc\u062f\u0647 \u0631\u0627 \u0628\u0627 \u067e\u0631\u0648\u0698\u0647 \u0627\u06cc \u06a9\u0647 \u0633\u0627\u062e\u062a\u0645 \u0628\u0647 \u0646\u0627\u0645 \u0627\u062c\u0631\u0627 \u06a9\u0631\u062f\u0645 <strong>GQL<\/strong> (Git Query Language).  \u0648 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0645\u0646 \u0642\u0635\u062f \u062f\u0627\u0631\u0645 \u0628\u0647 \u0634\u0645\u0627 \u0646\u0634\u0627\u0646 \u062f\u0647\u0645 \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0627\u06cc\u0646 \u0639\u0645\u0644\u06a9\u0631\u062f \u0631\u0627 \u0637\u0631\u0627\u062d\u06cc \u0648 \u0627\u062c\u0631\u0627 \u06a9\u0631\u062f\u0645.<\/p>\n<h2 id=\"how-can-you-take-a-sql-like-query-and-run-it-on-git-files\"><span class=\"ez-toc-section\" id=\"%da%86%da%af%d9%88%d9%86%d9%87_%d9%85%db%8c_%d8%aa%d9%88%d8%a7%d9%86%db%8c%d8%af_%db%8c%da%a9_%d9%be%d8%b1%d8%b3_%d9%88_%d8%ac%d9%88%db%8c_%d8%b4%d8%a8%db%8c%d9%87_%d8%a8%d9%87_sql_%d8%a8%da%af%db%8c%d8%b1%db%8c%d8%af_%d9%88_%d8%a2%d9%86_%d8%b1%d8%a7_%d8%af%d8%b1_%d9%81%d8%a7%db%8c%d9%84_%d9%87%d8%a7%db%8c_git_%d8%a7%d8%ac%d8%b1%d8%a7_%da%a9%d9%86%db%8c%d8%af%d8%9f\"><\/span>\u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9 \u067e\u0631\u0633 \u0648 \u062c\u0648\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 SQL \u0628\u06af\u06cc\u0631\u06cc\u062f \u0648 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc git. \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f\u061f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0648\u0644\u06cc\u0646 \u0627\u06cc\u062f\u0647 \u0627\u06cc \u06a9\u0647 \u062f\u0627\u0634\u062a\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 SQLite \u0628\u0648\u062f.  \u0627\u0645\u0627 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u0634\u06a9\u0644\u0627\u062a \u0648\u062c\u0648\u062f \u062f\u0627\u0634\u062a \u06a9\u0647 \u0646\u062a\u0648\u0627\u0646\u0633\u062a\u0645 \u062d\u0644 \u06a9\u0646\u0645. <\/p>\n<p>\u0628\u0631\u0627\u06cc \u0645\u062b\u0627\u0644\u060c \u0645\u0646 \u0646\u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0633\u062a\u0645 \u0646\u062d\u0648 \u0631\u0627 \u0633\u0641\u0627\u0631\u0634\u06cc \u06a9\u0646\u0645\u060c \u0648 \u0646\u0645\u06cc\u200c\u062e\u0648\u0627\u0633\u062a\u0645 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc .git \u0631\u0627 \u0628\u062e\u0648\u0627\u0646\u0645 \u0648 \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 SQLite \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u0645 \u0648 \u0633\u067e\u0633 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0645.  \u0645\u06cc \u062e\u0648\u0627\u0633\u062a\u0645 \u0647\u0645\u0647 \u0686\u06cc\u0632 \u062f\u0631 \u062d\u0627\u0644 \u0627\u062c\u0631\u0627 \u0628\u0627\u0634\u062f. <\/p>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc\u200c\u062e\u0648\u0627\u0633\u062a\u0645 \u0646\u0647 \u062a\u0646\u0647\u0627 \u0627\u0632 \u062f\u0633\u062a\u0648\u0631\u0627\u062a SELECT\u060c DELETE \u0648 UPDATE \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0645\u060c \u0628\u0644\u06a9\u0647 \u062f\u0633\u062a\u0648\u0631\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 Git \u0631\u0627 \u0646\u06cc\u0632 \u0627\u0631\u0627\u0626\u0647 \u06a9\u0646\u0645. <code>push<\/code>\u060c <code>pull<\/code>\u060c \u0648 \u063a\u06cc\u0631\u0647.<\/p>\n<p>\u0645\u0646 \u0642\u0628\u0644\u0627\u064b \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641\u06cc \u0645\u0627\u0646\u0646\u062f \u06a9\u0627\u0645\u067e\u0627\u06cc\u0644\u0631\u0647\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647\u200c\u0627\u0645\u060c \u067e\u0633 \u0686\u0631\u0627 \u0632\u0628\u0627\u0646\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 SQL \u0631\u0627 \u0627\u0632 \u0627\u0628\u062a\u062f\u0627 \u0627\u06cc\u062c\u0627\u062f \u0646\u06a9\u0646\u0645 \u0648 \u0622\u0646 \u0631\u0627 \u0648\u0627\u062f\u0627\u0631 \u0646\u06a9\u0646\u0645 \u06a9\u0647 \u0628\u0647 \u0633\u0631\u0639\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u062f \u0648 \u0628\u0628\u06cc\u0646\u062f \u0622\u06cc\u0627 \u06a9\u0627\u0631 \u0645\u06cc\u200c\u06a9\u0646\u062f\u061f<\/p>\n<h2 id=\"how-i-designed-and-implemented-a-query-language-from-scratch\"><span class=\"ez-toc-section\" id=\"%da%86%da%af%d9%88%d9%86%d9%87_%db%8c%da%a9_%d8%b2%d8%a8%d8%a7%d9%86_%d9%be%d8%b1%d8%b3_%d9%88_%d8%ac%d9%88_%d8%b1%d8%a7_%d8%a7%d8%b2_%d8%a7%d8%a8%d8%aa%d8%af%d8%a7_%d8%b7%d8%b1%d8%a7%d8%ad%db%8c_%d9%88_%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%da%a9%d8%b1%d8%af%d9%85\"><\/span>\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0631\u0627 \u0627\u0632 \u0627\u0628\u062a\u062f\u0627 \u0637\u0631\u0627\u062d\u06cc \u0648 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0631\u062f\u0645<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0645\u0646 \u0645\u06cc\u200c\u062e\u0648\u0627\u0633\u062a\u0645 \u0627\u0632 \u06a9\u0648\u0686\u06a9 \u0634\u0631\u0648\u0639 \u06a9\u0646\u0645 \u0641\u0642\u0637 \u0628\u0627 \u062d\u0645\u0627\u06cc\u062a \u0627\u0632 <code>SELECT<\/code> \u062f\u0633\u062a\u0648\u0631 \u0628\u062f\u0648\u0646 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u067e\u06cc\u0634\u0631\u0641\u062a\u0647 \u0645\u0627\u0646\u0646\u062f \u062a\u062c\u0645\u06cc\u0639\u060c \u06af\u0631\u0648\u0647 \u0628\u0646\u062f\u06cc\u060c \u067e\u06cc\u0648\u0633\u062a\u0646 \u0648 \u063a\u06cc\u0631\u0647. <\/p>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0646 \u0642\u0635\u062f \u062f\u0627\u0634\u062a\u0645 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u0633\u0627\u062e\u062a\u0627\u0631 \u062f\u0627\u062f\u0647 \u062a\u062c\u0632\u06cc\u0647 \u06a9\u0646\u0645 \u06a9\u0647 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0648 \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u0622\u0646 \u0631\u0627 \u0622\u0633\u0627\u0646 \u06a9\u0646\u062f (\u0645\u0627\u0646\u0646\u062f \u0628\u0631\u0631\u0633\u06cc \u0646\u0648\u0639 \u0648 \u0646\u0645\u0627\u06cc\u0634 \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u062e\u0637\u0627\u06cc \u0645\u0641\u06cc\u062f \u062f\u0631 \u0635\u0648\u0631\u062a \u0628\u0631\u0648\u0632 \u0645\u0634\u06a9\u0644).  \u067e\u0633 \u0627\u0632 \u0622\u0646\u060c \u0645\u0646 \u0627\u06cc\u0646 \u0633\u0627\u062e\u062a\u0627\u0631 \u062f\u0627\u062f\u0647 \u0631\u0627 \u0628\u0647 \u0627\u0631\u0632\u06cc\u0627\u0628 \u0645\u0646\u062a\u0642\u0644 \u0645\u06cc \u06a9\u0646\u0645 \u06a9\u0647 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0631\u0627 \u062f\u0631 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc .git \u0645\u0646 \u0627\u0639\u0645\u0627\u0644 \u06a9\u0646\u062f.<\/p>\n<h3 id=\"choosing-a-data-structure-to-use\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%86%d8%aa%d8%ae%d8%a7%d8%a8_%db%8c%da%a9_%d8%b3%d8%a7%d8%ae%d8%aa%d8%a7%d8%b1_%d8%af%d8%a7%d8%af%d9%87_%d8%a8%d8%b1%d8%a7%db%8c_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87\"><\/span>\u0627\u0646\u062a\u062e\u0627\u0628 \u06cc\u06a9 \u0633\u0627\u062e\u062a\u0627\u0631 \u062f\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0647\u062a\u0631\u06cc\u0646 \u0633\u0627\u062e\u062a\u0627\u0631 \u062f\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f\u060c \u0646\u0645\u0627\u06cc\u0634 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 an \u0627\u0633\u062a<strong> \u0622<\/strong><strong>\u0627\u0646\u062a\u0632\u0627\u0639\u06cc \u062f\u0631\u062e\u062a \u0646\u062d\u0648<\/strong> (AST).  \u0627\u06cc\u0646 \u06cc\u06a9 \u0633\u0627\u062e\u062a\u0627\u0631 \u062f\u0627\u062f\u0647 \u0628\u0633\u06cc\u0627\u0631 \u0645\u062a\u062f\u0627\u0648\u0644 \u0627\u0633\u062a \u06a9\u0647 \u062f\u0631 \u06a9\u0627\u0645\u067e\u0627\u06cc\u0644\u0631\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u0632\u06cc\u0631\u0627 \u0642\u0627\u0628\u0644 \u062a\u0639\u0645\u06cc\u0631 \u0627\u0633\u062a \u0648 \u0639\u0628\u0648\u0631 \u0648 \u0646\u0648\u0634\u062a\u0646 \u06af\u0631\u0647 \u0647\u0627 \u0631\u0627 \u062f\u0631 \u0633\u0627\u06cc\u0631\u06cc\u0646 \u0622\u0633\u0627\u0646 \u0645\u06cc \u06a9\u0646\u062f. <\/p>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f\u060c \u0645\u0646 \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0646 \u062a\u0645\u0627\u0645 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0646\u062f\u0627\u0634\u062a\u0645\u060c \u0641\u0642\u0637 \u0627\u0637\u0644\u0627\u0639\u0627\u062a\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0645\u0631\u0627\u062d\u0644 \u0628\u0639\u062f\u06cc \u0644\u0627\u0632\u0645 \u0628\u0648\u062f \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0645 (\u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0628\u0647 \u0622\u0646 Abstract \u0645\u06cc \u06af\u0648\u06cc\u0646\u062f).<\/p>\n<h3 id=\"deciding-what-validation-to-perform\"><span class=\"ez-toc-section\" id=\"%d8%aa%d8%b5%d9%85%db%8c%d9%85_%da%af%db%8c%d8%b1%db%8c_%d8%a8%d8%b1%d8%a7%db%8c_%d8%a7%d9%86%d8%ac%d8%a7%d9%85_%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c\"><\/span>\u062a\u0635\u0645\u06cc\u0645 \u06af\u06cc\u0631\u06cc \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0645\u0647\u0645\u062a\u0631\u06cc\u0646 \u0627\u0639\u062a\u0628\u0627\u0631 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f\u060c \u0628\u0631\u0631\u0633\u06cc \u0646\u0648\u0639 \u0628\u0631\u0627\u06cc \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0645\u0639\u062a\u0628\u0631 \u0628\u0648\u062f\u0646 \u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0647\u0631 \u0645\u0642\u062f\u0627\u0631 \u062f\u0631 \u0645\u06a9\u0627\u0646 \u0635\u062d\u06cc\u062d \u0627\u0633\u062a.<\/p>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0627\u06af\u0631 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0628\u062e\u0648\u0627\u0647\u062f \u0645\u062a\u0646 \u0631\u0627 \u062f\u0631 \u0645\u062a\u0646 \u062f\u06cc\u06af\u0631\u06cc \u0636\u0631\u0628 \u06a9\u0646\u062f\u060c \u0686\u0647 \u0645\u06cc \u0634\u0648\u062f &#8211; \u0622\u06cc\u0627 \u0627\u06cc\u0646 \u0645\u0639\u062a\u0628\u0631 \u0627\u0633\u062a\u061f<\/p>\n<pre><code class=\"language-SQL\">SELECT \"ONE\" * \"TWO\"<\/code><\/pre>\n<p>\u0639\u0645\u0644\u06af\u0631 \u0636\u0631\u0628 \u0627\u0646\u062a\u0638\u0627\u0631 \u062f\u0627\u0631\u062f \u06a9\u0647 \u0647\u0631 \u062f\u0648 \u0637\u0631\u0641 \u06cc\u06a9 \u0639\u062f\u062f \u0628\u0627\u0634\u0646\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f\u060c \u0645\u0646 \u0645\u06cc \u062e\u0648\u0627\u0633\u062a\u0645 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0637\u0644\u0627\u0639 \u062f\u0647\u0645 \u06a9\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0622\u0646\u0647\u0627 \u0646\u0627\u0645\u0639\u062a\u0628\u0631 \u0627\u0633\u062a \u0648 \u0633\u0639\u06cc \u0645\u06cc \u06a9\u0646\u0645 \u062a\u0627 \u062d\u062f \u0627\u0645\u06a9\u0627\u0646 \u0628\u0647 \u0627\u0648 \u06a9\u0645\u06a9 \u06a9\u0646\u0645 \u062a\u0627 \u0645\u0634\u06a9\u0644 \u0631\u0627 \u062f\u0631\u06a9 \u06a9\u0646\u062f.<\/p>\n<p>\u067e\u0633 \u0686\u06af\u0648\u0646\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f\u061f  \u0648\u0642\u062a\u06cc \u0645\u06cc \u0628\u06cc\u0646\u0645 \u06cc\u06a9 \u0627\u067e\u0631\u0627\u062a\u0648\u0631 \u0645\u0627\u0646\u0646\u062f <code>*<\/code>\u060c \u0628\u0627\u06cc\u062f \u0647\u0631 \u062f\u0648 \u0637\u0631\u0641 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0628\u0628\u06cc\u0646\u06cc\u062f \u0622\u06cc\u0627 \u0645\u0642\u0627\u062f\u06cc\u0631 \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0639\u0645\u0644\u06af\u0631 \u0645\u0639\u062a\u0628\u0631 \u0647\u0633\u062a\u0646\u062f \u06cc\u0627 \u062e\u06cc\u0631.  \u0627\u06af\u0631 \u0646\u0647 \u067e\u0633\u060c \u067e\u06cc\u0627\u0645\u06cc \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646 \u0631\u0627 \u06af\u0632\u0627\u0631\u0634 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"language-SQL\">SELECT \"ONE\" * \"TWO\"\n-------------^\n\nERROR: Operator `*` expects both sides to be Number type but got Text.<\/code><\/pre>\n<p>\u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0639\u0645\u0644\u06af\u0631\u0647\u0627\u060c \u0645\u06cc \u062f\u0627\u0646\u0633\u062a\u0645 \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u0645 \u06a9\u0647 \u0622\u06cc\u0627 \u0647\u0631 \u0634\u0646\u0627\u0633\u0647 \u06cc\u06a9 \u062c\u062f\u0648\u0644\u060c \u0641\u06cc\u0644\u062f\u060c \u0646\u0627\u0645 \u0645\u0633\u062a\u0639\u0627\u0631 \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u0627\u0633\u062a \u06cc\u0627 \u0627\u06cc\u0646\u06a9\u0647 \u0628\u0627\u06cc\u062f \u062a\u0639\u0631\u06cc\u0641 \u0646\u0634\u062f\u0647 \u0628\u0627\u0634\u062f.  \u0645\u0646 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u062e\u0637\u0627 \u0631\u0627 \u06af\u0632\u0627\u0631\u0634 \u06a9\u0646\u0645\u060c \u0628\u0631\u0627\u06cc \u0645\u062b\u0627\u0644\u060c \u0627\u06af\u0631 \u06cc\u06a9 \u062c\u062f\u0648\u0644 \u0634\u0627\u062e\u0647 \u0647\u0627 \u0641\u0642\u0637 \u0634\u0627\u0645\u0644 2 \u0641\u06cc\u0644\u062f \u0645\u0627\u0646\u0646\u062f \u0645\u062b\u0627\u0644 \u0632\u06cc\u0631 \u0628\u0627\u0634\u062f:<\/p>\n<pre><code class=\"language-SQL\">Branches {\n   Text name,\n   Number commit_count,\n}<\/code><\/pre>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0646 \u062c\u062f\u0648\u0644\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0645 \u06a9\u0647 \u062d\u0627\u0648\u06cc \u0646\u0645\u0627\u06cc\u0634 \u0647\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u0647\u0645\u0647 \u062c\u062f\u0627\u0648\u0644 \u0648 \u0641\u06cc\u0644\u062f\u0647\u0627 \u0628\u0648\u062f \u062a\u0627 \u0628\u062a\u0648\u0627\u0646\u0645 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0646\u0648\u0639 \u0628\u0631\u0631\u0633\u06cc \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0645.  \u0627\u06af\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0633\u0639\u06cc \u06a9\u0631\u062f \u0641\u06cc\u0644\u062f\u06cc \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u062f \u06a9\u0647 \u062f\u0631 \u0627\u06cc\u0646 \u0637\u0631\u062d \u062a\u0639\u0631\u06cc\u0641 \u0646\u0634\u062f\u0647 \u0628\u0648\u062f\u060c \u062e\u0637\u0627 \u0631\u0627 \u06af\u0632\u0627\u0631\u0634 \u06a9\u0631\u062f:<\/p>\n<pre><code class=\"language-SQL\">SELECT invalid_field_name FROM branches\n-------------^\n\nError: Field `invalid_field_name` is not defined in branches table.<\/code><\/pre>\n<p>\u0645\u0646 \u0628\u0627\u06cc\u062f \u0645\u0637\u0645\u0626\u0646 \u0645\u06cc \u0634\u062f\u0645 \u06a9\u0647 \u0647\u0645\u06cc\u0646 \u0628\u0631\u0631\u0633\u06cc \u0647\u0627 \u0631\u0648\u06cc \u0634\u0631\u0627\u06cc\u0637\u060c \u0646\u0627\u0645 \u062a\u0648\u0627\u0628\u0639 \u0648 \u0622\u0631\u06af\u0648\u0645\u0627\u0646 \u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f.  \u0633\u067e\u0633 \u0627\u06af\u0631 \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u062a\u0639\u0631\u06cc\u0641 \u0634\u062f\u0647 \u0628\u0648\u062f \u0648 \u0627\u0646\u0648\u0627\u0639 \u062f\u0631\u0633\u062a\u06cc \u062f\u0627\u0634\u062a\u060c AST \u0645\u0639\u062a\u0628\u0631 \u0628\u0648\u062f \u0648 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0633\u062a\u06cc\u0645 \u0628\u0647 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f \u0628\u0631\u0648\u06cc\u0645.<\/p>\n<h3 id=\"what-happens-after-validating-the-abstract-syntax-tree\"><span class=\"ez-toc-section\" id=\"%d9%be%d8%b3_%d8%a7%d8%b2_%d8%aa%d8%a3%db%8c%db%8c%d8%af_%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1_%d8%af%d8%b1%d8%ae%d8%aa_%d9%86%d8%ad%d9%88_%d8%a7%d9%86%d8%aa%d8%b2%d8%a7%d8%b9%db%8c_%da%86%d9%87_%d8%a7%d8%aa%d9%81%d8%a7%d9%82%db%8c_%d9%85%db%8c_%d8%a7%d9%81%d8%aa%d8%af%d8%9f\"><\/span>\u067e\u0633 \u0627\u0632 \u062a\u0623\u06cc\u06cc\u062f \u0627\u0639\u062a\u0628\u0627\u0631 \u062f\u0631\u062e\u062a \u0646\u062d\u0648 \u0627\u0646\u062a\u0632\u0627\u0639\u06cc \u0686\u0647 \u0627\u062a\u0641\u0627\u0642\u06cc \u0645\u06cc \u0627\u0641\u062a\u062f\u061f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u067e\u0633 \u0627\u0632 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0645\u0639\u062a\u0628\u0631 \u0628\u0648\u062f\u0646 \u0647\u0645\u0647 \u0686\u06cc\u0632\u060c \u0646\u0648\u0628\u062a \u0628\u0647 \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0648 \u0646\u062d\u0648\u0647 \u0648\u0627\u06a9\u0634\u06cc \u0646\u062a\u06cc\u062c\u0647 \u0631\u0633\u06cc\u062f. <\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0645\u0646 \u0641\u0642\u0637 \u062f\u0631\u062e\u062a \u0646\u062d\u0648 \u0631\u0627 \u0637\u06cc \u06a9\u0631\u062f\u0645 \u0648 \u0647\u0631 \u06af\u0631\u0647 \u0631\u0627 \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u06a9\u0631\u062f\u0645.  \u067e\u0633 \u0627\u0632 \u0627\u062a\u0645\u0627\u0645\u060c \u0628\u0627\u06cc\u062f \u0646\u062a\u06cc\u062c\u0647 \u0635\u062d\u06cc\u062d \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u0644\u06cc\u0633\u062a \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0645.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u06cc\u0646 \u0641\u0631\u0622\u06cc\u0646\u062f \u0631\u0627 \u0645\u0631\u062d\u0644\u0647 \u0628\u0647 \u0645\u0631\u062d\u0644\u0647 \u0637\u06cc \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0628\u0628\u06cc\u0646\u06cc\u0645 \u0686\u06af\u0648\u0646\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u062f\u0631 \u06cc\u06a9 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646:<\/p>\n<pre><code class=\"language-SQL\">SELECT * FROM branches WHEER name LIKE \"%\/main\" ORDER BY commit_count LIMIE BY 5<\/code><\/pre>\n<p>\u0646\u0645\u0627\u06cc\u0634 AST \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<pre><code>AbstractSyntaxTree {\n  Select(*, \"branches\") \n  Where(Like(name, \"%\/main\"))\n  OrderBy(commit_count)\n  Limit(5) \n}<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0628\u0627\u06cc\u062f \u0647\u0631 \u06af\u0631\u0647 \u0631\u0627 \u0628\u0647 \u062a\u0631\u062a\u06cc\u0628 \u062e\u0627\u0635 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0648 \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u06a9\u0646\u06cc\u0645.  \u0645\u0627 \u0641\u0642\u0637 \u0634\u0631\u0648\u0639 \u0628\u0647 \u067e\u0627\u06cc\u0627\u0646 \u06cc\u0627 \u067e\u0627\u06cc\u0627\u0646 \u0628\u0647 \u0634\u0631\u0648\u0639 \u0646\u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0632\u06cc\u0631\u0627 \u0628\u0627\u06cc\u062f \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0628\u0647 \u0647\u0645\u0627\u0646 \u062a\u0631\u062a\u06cc\u0628\u06cc \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645 \u06a9\u0647 SQL \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0647\u0645\u0627\u0646 \u0646\u062a\u06cc\u062c\u0647 \u0631\u0627 \u0628\u062f\u0633\u062a \u0622\u0648\u0631\u06cc\u0645. <\/p>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u062f\u0631 SQL\u060c <code>WHERE<\/code> \u0628\u06cc\u0627\u0646\u06cc\u0647 \u0628\u0627\u06cc\u062f \u0642\u0628\u0644 \u0627\u0632 \u0622\u0646 \u0627\u062c\u0631\u0627 \u0634\u0648\u062f <code>GROUP BY<\/code>\u060c \u0648 <code>HAVING<\/code> \u0628\u0627\u06cc\u062f \u067e\u0633 \u0627\u0632 \u0622\u0646 \u0627\u062c\u0631\u0627 \u0634\u0648\u062f.<\/p>\n<p>\u062f\u0631 \u0645\u062b\u0627\u0644 \u0628\u0627\u0644\u0627\u060c \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0628\u0647 \u062a\u0631\u062a\u06cc\u0628 \u062f\u0631\u0633\u062a \u0627\u062c\u0631\u0627 \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0628\u06cc\u0646\u06cc\u0645 \u0647\u0631 \u062f\u0633\u062a\u0648\u0631 \u0686\u0647 \u06a9\u0627\u0631\u06cc \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<ul>\n<li><code>Select(*, \"branches\")<\/code><\/li>\n<\/ul>\n<p>\u0628\u0627 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u062a\u0645\u0627\u0645 \u0641\u06cc\u0644\u062f\u0647\u0627 \u0627\u0632 \u062c\u062f\u0648\u0644 \u0628\u0627 \u0646\u0627\u0645 \u0627\u0646\u062a\u062e\u0627\u0628 \u0645\u06cc \u0634\u0648\u0646\u062f <code>branches<\/code> \u0648 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0647 \u06cc\u06a9 \u0644\u06cc\u0633\u062a \u0641\u0634\u0627\u0631 \u062f\u0647\u06cc\u062f &#8211; \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0635\u062f\u0627 \u06a9\u0646\u06cc\u0645 <code>objects<\/code>.  \u0627\u0645\u0627 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0627\u0632 \u0645\u062e\u0632\u0646 \u0645\u062d\u0644\u06cc \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u0645\u061f<\/p>\n<p>\u062a\u0645\u0627\u0645 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 commit \u0647\u0627\u060c \u0634\u0627\u062e\u0647 \u0647\u0627\u060c \u062a\u06af \u0647\u0627 \u0648 \u063a\u06cc\u0631\u0647 \u062a\u0648\u0633\u0637 Git \u062f\u0631 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u062f\u0627\u062e\u0644 \u067e\u0648\u0634\u0647 \u0627\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u0634\u0648\u062f. <code>.git<\/code> \u062f\u0631 \u0647\u0631 \u0645\u062e\u0632\u0646  \u06cc\u06a9\u06cc \u0627\u0632 \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627 \u0646\u0648\u0634\u062a\u0646 \u06cc\u06a9 \u062a\u062c\u0632\u06cc\u0647 \u06a9\u0646\u0646\u062f\u0647 \u06a9\u0627\u0645\u0644 \u0627\u0632 \u0627\u0628\u062a\u062f\u0627 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u062e\u0631\u0627\u062c \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0627\u0633\u062a.  \u0627\u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u062f\u0631 \u0639\u0648\u0636 \u0628\u0631\u0627\u06cc \u0645\u0646 \u06a9\u0627\u0631\u0633\u0627\u0632 \u0628\u0648\u062f.<\/p>\n<p>\u062a\u0635\u0645\u06cc\u0645 \u06af\u0631\u0641\u062a\u0645 \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 libgit2 \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0645.  \u0627\u06cc\u0646 \u06cc\u06a9 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc C \u062e\u0627\u0644\u0635 \u0627\u0632 \u0631\u0648\u0634 \u0647\u0627\u06cc \u0647\u0633\u062a\u0647 Git \u0627\u0633\u062a\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062a\u0645\u0627\u0645 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u062e\u0648\u062f \u0631\u0627 \u0628\u062e\u0648\u0627\u0646\u06cc\u062f \u0648 \u0627\u0632 Rust \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.  \u06cc\u06a9 \u062c\u0639\u0628\u0647 (\u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0632\u0646\u06af) \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u062a\u0648\u0633\u0637 \u062a\u06cc\u0645 \u0631\u0633\u0645\u06cc Rust \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0628\u0647 \u0646\u0627\u0645 <code>git2<\/code>\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0634\u0639\u0628\u0647 \u0631\u0627 \u0628\u0647 \u0634\u0631\u062d \u0632\u06cc\u0631 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"language-rust\">let local_branches = repo.branches(Some(BranchType::Local));\nlet remote_branches = repo.branches(Some(BranchType::Remote));\nlet local_and_remote_branches = repository.branches(None);\n<\/code><\/pre>\n<p>\u0648 \u0633\u067e\u0633 \u0631\u0648\u06cc \u0647\u0631 \u0634\u0627\u062e\u0647 \u062a\u06a9\u0631\u0627\u0631 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0646 \u0631\u0627 \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u06cc\u062f \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"language-rust\">for branch in local_and_remote_branches {\n   \/\/ Extract information from branch and store it\n}<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0641\u0647\u0631\u0633\u062a\u06cc \u0627\u0632 \u062a\u0645\u0627\u0645 \u0634\u0627\u062e\u0647 \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0631 \u0645\u0631\u0627\u062d\u0644 \u0628\u0639\u062f\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f \u0628\u0647 \u067e\u0627\u06cc\u0627\u0646 \u0645\u06cc \u0631\u0633\u06cc\u0645.<\/p>\n<ul>\n<li><code>Where(Like(name, \"%\/main\"))<\/code><\/li>\n<\/ul>\n<p>\u0627\u06cc\u0646 \u0641\u0647\u0631\u0633\u062a \u0627\u0634\u06cc\u0627\u0621 \u0631\u0627 \u0641\u06cc\u0644\u062a\u0631 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0647\u0645\u0647 \u0645\u0648\u0627\u0631\u062f\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0627 \u0634\u0631\u0627\u06cc\u0637 \u0645\u0637\u0627\u0628\u0642\u062a \u0646\u062f\u0627\u0631\u0646\u062f \u062d\u0630\u0641 \u0645\u06cc \u06a9\u0646\u062f &#8211; \u062f\u0631 \u0645\u0648\u0631\u062f \u0645\u0627\u060c \u0645\u0648\u0627\u0631\u062f\u06cc \u06a9\u0647 \u0628\u0627 &#8220;\/main&#8221; \u062e\u062a\u0645 \u0645\u06cc \u0634\u0648\u0646\u062f.<\/p>\n<ul>\n<li><code>OrderBy(commit_count)<\/code><\/li>\n<\/ul>\n<p>\u0627\u06cc\u0646 \u0644\u06cc\u0633\u062a \u0627\u0634\u06cc\u0627\u0621 \u0631\u0627 \u0628\u0631 \u0627\u0633\u0627\u0633 \u0645\u0642\u062f\u0627\u0631 \u0641\u06cc\u0644\u062f \u0645\u0631\u062a\u0628 \u0645\u06cc \u06a9\u0646\u062f <code>commit_count<\/code>.<\/p>\n<ul>\n<li><code>Limit(5)<\/code><\/li>\n<\/ul>\n<p>\u0627\u06cc\u0646 \u0641\u0642\u0637 \u067e\u0646\u062c \u0645\u0648\u0631\u062f \u0627\u0648\u0644 \u0631\u0627 \u0645\u06cc \u06af\u06cc\u0631\u062f \u0648 \u0628\u0642\u06cc\u0647 \u0631\u0627 \u0627\u0632 \u0644\u06cc\u0633\u062a \u0627\u0634\u06cc\u0627\u0621 \u062d\u0630\u0641 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062e\u0648\u062f\u0634\u0647!  \u0648 \u0627\u06a9\u0646\u0648\u0646 \u0628\u0647 \u06cc\u06a9 \u0646\u062a\u06cc\u062c\u0647 \u0645\u0639\u062a\u0628\u0631 \u0645\u06cc \u0631\u0633\u06cc\u0645 \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0632\u06cc\u0631 \u0645\u0634\u0627\u0647\u062f\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<figure class=\"kg-card kg-image-card kg-width-wide\"><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2023\/12\/gql_demo.gif\" class=\"kg-image\" alt=\"gql_demo\" width=\"1536\" height=\"836\" loading=\"lazy\" title=\"\"><\/figure>\n<p>\u0645\u062b\u0627\u0644 \u0647\u0627\u06cc \u0632\u06cc\u0631 \u0645\u0639\u062a\u0628\u0631 \u0647\u0633\u062a\u0646\u062f \u0648 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u0646\u062f:<\/p>\n<pre><code class=\"language-SQL\">SELECT 1\nSELECT 1 + 2\nSELECT LEN(\"Git Query Language\")\nSELECT \"One\" IN (\"One\", \"Two\", \"Three\")\nSELECT \"Git Query Language\" LIKE \"%Query%\"\n\nSELECT commit_count FROM branches WHERE commit_count BETWEEN 0 .. 10\n\nSELECT * FROM refs WHERE type = \"branch\"\nSELECT * FROM refs ORDER BY type\n\nSELECT * FROM commits\nSELECT name, email FROM commits\nSELECT name, email FROM commits ORDER BY name DESC\nSELECT name, email FROM commits WHERE name LIKE \"%gmail%\" ORDER BY name\nSELECT * FROM commits WHERE LOWER(name) = \"amrdeveloper\"\nSELECT name FROM commits GROUP By name\nSELECT name FROM commits GROUP By name having name = \"AmrDeveloper\"\n\nSELECT * FROM branches\nSELECT * FROM branches WHERE is_head = true\nSELECT name, LEN(name) FROM branches\n\nSELECT * FROM tags\nSELECT * FROM tags OFFSET 1 LIMIT 1<\/code><\/pre>\n<h3 id=\"how-to-support-running-on-multiple-repositories-at-the-same-time\"><span class=\"ez-toc-section\" id=\"%da%86%da%af%d9%88%d9%86%d9%87_%d8%a7%d8%b2_%d8%a7%d8%ac%d8%b1%d8%a7%db%8c_%d9%87%d9%85%d8%b2%d9%85%d8%a7%d9%86_%d8%a8%d8%b1_%d8%b1%d9%88%db%8c_%da%86%d9%86%d8%af%db%8c%d9%86_%d9%85%d8%ae%d8%b2%d9%86_%d9%be%d8%b4%d8%aa%db%8c%d8%a8%d8%a7%d9%86%db%8c_%da%a9%d9%86%db%8c%d9%85\"><\/span>\u0686\u06af\u0648\u0646\u0647 \u0627\u0632 \u0627\u062c\u0631\u0627\u06cc \u0647\u0645\u0632\u0645\u0627\u0646 \u0628\u0631 \u0631\u0648\u06cc \u0686\u0646\u062f\u06cc\u0646 \u0645\u062e\u0632\u0646 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u06a9\u0646\u06cc\u0645<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u067e\u0633 \u0627\u0632 \u0627\u0646\u062a\u0634\u0627\u0631 GQL\u060c \u0628\u0627\u0632\u062e\u0648\u0631\u062f \u0634\u06af\u0641\u062a \u0627\u0646\u06af\u06cc\u0632\u06cc \u0627\u0632 \u0645\u0631\u062f\u0645 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0631\u062f\u0645.  \u0645\u0646 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0631\u062e\u06cc \u0627\u0632 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc \u0648\u06cc\u0698\u06af\u06cc \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0631\u062f\u0645\u060c \u0645\u0627\u0646\u0646\u062f \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0627\u0632 \u0686\u0646\u062f\u06cc\u0646 \u0645\u062e\u0632\u0646 \u0648 \u0641\u06cc\u0644\u062a\u0631 \u06a9\u0631\u062f\u0646 \u0628\u0631 \u0627\u0633\u0627\u0633 \u0645\u0633\u06cc\u0631 \u0645\u062e\u0632\u0646.<\/p>\n<p>\u0628\u0647 \u0646\u0638\u0631 \u0645\u0646 \u0627\u06cc\u0646 \u06cc\u06a9 \u0627\u06cc\u062f\u0647 \u0639\u0627\u0644\u06cc \u0628\u0648\u062f\u060c \u0632\u06cc\u0631\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0633\u062a\u0645 \u0622\u0646\u0627\u0644\u06cc\u0632 \u0628\u0631\u0627\u06cc \u067e\u0631\u0648\u0698\u0647\u200c\u0647\u0627\u06cc \u0645\u062a\u0639\u062f\u062f \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0647 \u0627\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0645 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0686\u0646\u062f\u06cc\u0646 \u0631\u0634\u062a\u0647 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0645.  \u0628\u0647 \u0646\u0638\u0631 \u0646\u0645\u06cc \u0631\u0633\u06cc\u062f \u06a9\u0647 \u0627\u062c\u0631\u0627\u06cc \u0622\u0646 \u062e\u06cc\u0644\u06cc \u0633\u062e\u062a \u0628\u0627\u0634\u062f.<\/p>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u067e\u0633 \u0627\u0632 \u0627\u062a\u0645\u0627\u0645 \u0645\u0631\u062d\u0644\u0647 \u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u0628\u0631\u0627\u06cc AST\u060c \u0646\u0648\u0628\u062a \u0628\u0647 \u0645\u0631\u062d\u0644\u0647 \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u0645\u06cc \u0631\u0633\u062f \u0627\u0645\u0627 \u0628\u0647 \u062c\u0627\u06cc \u06cc\u06a9 \u0628\u0627\u0631 \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc\u060c \u0628\u0631\u0627\u06cc \u0647\u0631 \u0645\u062e\u0632\u0646 \u06cc\u06a9 \u0628\u0627\u0631 \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u0645\u06cc \u0634\u0648\u062f \u0648 \u0633\u067e\u0633 \u0647\u0645\u0647 \u0646\u062a\u0627\u06cc\u062c \u062f\u0631 \u06cc\u06a9 \u0644\u06cc\u0633\u062a \u0627\u062f\u063a\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0627\u0645\u0627 \u062f\u0631 \u0645\u0648\u0631\u062f \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0627\u0632 \u0642\u0627\u0628\u0644\u06cc\u062a \u0641\u06cc\u0644\u062a\u0631 \u06a9\u0631\u062f\u0646 \u0628\u0631 \u0627\u0633\u0627\u0633 \u0645\u0633\u06cc\u0631 \u0645\u062e\u0632\u0646 \u0686\u0637\u0648\u0631\u061f<\/p>\n<p>\u0627\u06cc\u0646 \u062e\u06cc\u0644\u06cc \u0622\u0633\u0627\u0646 \u0628\u0648\u062f.  \u0622\u06cc\u0627 \u0637\u0631\u062d \u062c\u062f\u0648\u0644 \u0634\u0627\u062e\u0647 \u0647\u0627 \u0631\u0627 \u0628\u0647 \u062e\u0627\u0637\u0631 \u062f\u0627\u0631\u06cc\u062f\u061f  \u062a\u0646\u0647\u0627 \u06a9\u0627\u0631\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0627\u062f\u0645 \u0627\u06cc\u0646 \u0628\u0648\u062f \u06a9\u0647 \u06cc\u06a9 \u0641\u06cc\u0644\u062f \u062c\u062f\u06cc\u062f \u0628\u0627 \u0646\u0627\u0645 \u0645\u0639\u0631\u0641\u06cc \u06a9\u0646\u0645 <code>repository_path<\/code> \u062a\u0627 \u0645\u0633\u06cc\u0631 \u0645\u062d\u0644\u06cc \u0645\u062e\u0632\u0646 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0634\u0639\u0628\u0647 \u0646\u0634\u0627\u0646 \u062f\u0647\u062f \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u062c\u062f\u0627\u0648\u0644 \u062f\u06cc\u06af\u0631 \u0646\u06cc\u0632 \u0645\u0639\u0631\u0641\u06cc \u06a9\u0646\u062f. <\/p>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0637\u0631\u062d \u0646\u0647\u0627\u06cc\u06cc \u0628\u0647 \u0635\u0648\u0631\u062a \u0632\u06cc\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<pre><code class=\"language-SQL\">Branches {\n   Text name,\n   Number commit_count,\n   Text repository_path,\n}<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u067e\u0631\u0633 \u0648 \u062c\u0648\u06cc \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0627\u0632 \u0627\u06cc\u0646 \u0641\u06cc\u0644\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<pre><code class=\"language-SQL\">SELECT * FROM branches WHERE repository_path LIKE \"%GQL\"<\/code><\/pre>\n<p>\u0648 \u0628\u0633!  \ud83d\ude09<\/p>\n<h3 id=\"thanks-for-reading-\"><span class=\"ez-toc-section\" id=\"%d8%a8%d8%a7_%d8%aa%d8%b4%da%a9%d8%b1_%d8%a8%d8%b1%d8%a7%db%8c_%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86\"><\/span>\u0628\u0627 \u062a\u0634\u06a9\u0631 \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646!<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0627\u06af\u0631 \u067e\u0631\u0648\u0698\u0647 \u0631\u0627 \u062f\u0648\u0633\u062a \u062f\u0627\u0634\u062a\u06cc\u062f\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 \u0622\u0646 \u0633\u062a\u0627\u0631\u0647 \u0628\u062f\u0647\u06cc\u062f \u2b50 \u062f\u0631 github.com\/AmrDeveloper\/GQL.<\/p>\n<p>\u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0648\u0628 \u0633\u0627\u06cc\u062a \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f <strong>github.io\/GQL<\/strong> \u0628\u0631\u0627\u06cc \u0646\u062d\u0648\u0647 \u062f\u0627\u0646\u0644\u0648\u062f \u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u0631\u0648\u0698\u0647 \u062f\u0631 \u0633\u06cc\u0633\u062a\u0645 \u0639\u0627\u0645\u0644 \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641.<\/p>\n<p>\u0627\u06cc\u0646 \u067e\u0631\u0648\u0698\u0647 \u0647\u0646\u0648\u0632 \u0627\u0646\u062c\u0627\u0645 \u0646\u0634\u062f\u0647 \u0627\u0633\u062a &#8211; \u0627\u06cc\u0646 \u0641\u0642\u0637 \u0634\u0631\u0648\u0639 \u0627\u0633\u062a.  \u0647\u0645\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0627\u06cc\u0646 \u067e\u0631\u0648\u0698\u0647 \u0628\u067e\u06cc\u0648\u0646\u062f\u0646\u062f \u0648 \u0628\u0647 \u067e\u0631\u0648\u0698\u0647 \u06a9\u0645\u06a9 \u06a9\u0646\u0646\u062f \u0648 \u0627\u06cc\u062f\u0647 \u0647\u0627\u06cc\u06cc \u0631\u0627 \u067e\u06cc\u0634\u0646\u0647\u0627\u062f \u06a9\u0646\u0646\u062f \u06cc\u0627 \u0627\u0634\u06a9\u0627\u0644\u0627\u062a \u0631\u0627 \u06af\u0632\u0627\u0631\u0634 \u06a9\u0646\u0646\u062f.<\/p>\n<\/section>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1402-12-26 04:52:44<br \/>\n<\/p>\n\n\n<div class=\"kk-star-ratings kksr-auto kksr-align-center kksr-valign-bottom\"\n    data-payload='{&quot;align&quot;:&quot;center&quot;,&quot;id&quot;:&quot;9136&quot;,&quot;slug&quot;:&quot;default&quot;,&quot;valign&quot;:&quot;bottom&quot;,&quot;ignore&quot;:&quot;&quot;,&quot;reference&quot;:&quot;auto&quot;,&quot;class&quot;:&quot;&quot;,&quot;count&quot;:&quot;0&quot;,&quot;legendonly&quot;:&quot;&quot;,&quot;readonly&quot;:&quot;&quot;,&quot;score&quot;:&quot;0&quot;,&quot;starsonly&quot;:&quot;&quot;,&quot;best&quot;:&quot;5&quot;,&quot;gap&quot;:&quot;5&quot;,&quot;greet&quot;:&quot;\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628&quot;,&quot;legend&quot;:&quot;0\\\/5 (0 \u0631\u0627\u06cc)&quot;,&quot;size&quot;:&quot;30&quot;,&quot;title&quot;:&quot;\u0686\u06af\u0648\u0646\u0647 \u0632\u0628\u0627\u0646\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 SQL \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627 \u062f\u0631 \u0645\u062e\u0627\u0632\u0646 \u0645\u062d\u0644\u06cc Git \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0645&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 7<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0633\u0644\u0627\u0645 \u0628\u0647 \u0647\u0645\u0647! \u0645\u0646 \u06cc\u06a9 \u0645\u0647\u0646\u062f\u0633 \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631 \u0647\u0633\u062a\u0645 \u06a9\u0647 \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc \u0633\u0637\u062d \u067e\u0627\u06cc\u06cc\u0646\u060c \u06a9\u0627\u0645\u067e\u0627\u06cc\u0644\u0631\u0647\u0627 \u0648 \u062a\u0648\u0633\u0639\u0647 \u0627\u0628\u0632\u0627\u0631 \u0639\u0644\u0627\u0642\u0647 \u0645\u0646\u062f \u0647\u0633\u062a\u0645. \u0633\u0647 \u0645\u0627\u0647 \u067e\u06cc\u0634 \u062a\u0635\u0645\u06cc\u0645 \u06af\u0631\u0641\u062a\u0645 \u0632\u0628\u0627\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc Rust \u0631\u0627 \u06cc\u0627\u062f \u0628\u06af\u06cc\u0631\u0645 \u0648 \u06cc\u06a9 \u06a9\u0644\u0627\u06cc\u0646\u062a Git \u0628\u0633\u0627\u0632\u0645 \u06a9\u0647 \u0628\u0631 \u0633\u0627\u062f\u06af\u06cc \u0648 \u0628\u0647\u0631\u0647 \u0648\u0631\u06cc \u062a\u0645\u0631\u06a9\u0632 \u062f\u0627\u0631\u062f. \u0634\u0631\u0648\u0639 \u06a9\u0631\u062f\u0645 \u0628\u0647 \u0641\u06a9\u0631 \u06a9\u0631\u062f\u0646 \u062f\u0631 \u0645\u0648\u0631\u062f \u0627\u06cc\u0646\u06a9\u0647 [&hellip;]<\/p>\n","protected":false},"author":6,"featured_media":9137,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1726,620,206],"tags":[498,1943,1945,535,1931,1944,1936,1814,1807,1932,1933,1822,1929,1942,1930,1937,1935,1934,1941,1940],"class_list":["post-9136","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-devops","category-programming","category-development","tag-git","tag-git-vps","tag-git-","tag-sql","tag-1931","tag----git","tag-1936","tag-1814","tag-1807","tag-1932","tag-1933","tag-1822","tag-1929","tag---gitlab","tag-1930","tag-1937","tag-1935","tag-1934","tag-1941","tag-1940"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/9136","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/users\/6"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=9136"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/9136\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/9137"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=9136"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=9136"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=9136"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}