{"id":16650,"date":"2024-01-29T00:11:15","date_gmt":"2024-01-28T20:41:15","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/"},"modified":"2024-01-29T00:11:15","modified_gmt":"2024-01-28T20:41:15","slug":"bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/","title":{"rendered":"Bookshelf.js: \u06cc\u06a9 Node.js ORMON \u06cc\u06a9\u06cc \u0627\u0632 \u0631\u0627\u06cc\u062c\u200c\u062a\u0631\u06cc\u0646 \u0645\u0646\u0627\u0628\u0639\u06cc \u06a9\u0647 \u062f\u0631 \u0632\u0628\u0627\u0646\u06cc \u0645\u0627\u0646\u0646\u062f Node.js (\u0639\u0645\u062f\u062a\u0627\u064b \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u0645\u062a\u0645\u0631\u06a9\u0632 \u0628\u0631 \u0648\u0628) \u0628\u0627 \u0622\u0646 \u062a\u0639\u0627\u0645\u0644 \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0627\u0634\u062a\u060c \u067e\u0627\u06cc\u06af\u0627\u0647\u200c\u0647\u0627\u06cc \u062f\u0627\u062f\u0647 \u0647\u0633\u062a\u0646\u062f.  \u0648 \u0628\u0627 \u062a\u0648\u062c\u0647 \u0628\u0647 \u0627\u06cc\u0646\u06a9\u0647 SQL \u0645\u062a\u062f\u0627\u0648\u0644 \u062a\u0631\u06cc\u0646 \u062f\u0631 \u0628\u06cc\u0646 \u0627\u0646\u0648\u0627\u0639 \u0645\u062e\u062a\u0644\u0641 \u0627\u0633\u062a\u060c \u0628\u0647 \u06cc\u06a9 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u062e\u0648\u0628 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f \u062a\u0627 \u0628\u0647 \u0634\u0645\u0627 \u062f\u0631 \u062a\u0639\u0627\u0645\u0644 \u0628\u0627 \u0622\u0646 \u0648 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0645\u062a\u0639\u062f\u062f \u0622\u0646 \u06a9\u0645\u06a9 \u06a9\u0646\u062f.  Bookshelf.js&#8230;"},"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\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d9%82%d9%81%d8%b3%d9%87_%da%a9%d8%aa%d8%a7%d8%a8_%d8%b1%d8%a7_%d9%86%d8%b5%d8%a8_%da%a9%d9%86%db%8c%d8%af\" >\u0642\u0641\u0633\u0647 \u06a9\u062a\u0627\u0628 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<\/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\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d8%a7%d8%aa%d8%b5%d8%a7%d9%84_%d8%a8%d9%87_%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87_%d8%af%d8%a7%d8%af%d9%87\" >\u0627\u062a\u0635\u0627\u0644 \u0628\u0647 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d8%aa%d9%86%d8%b8%db%8c%d9%85_%d8%ac%d8%af%d8%a7%d9%88%d9%84\" >\u062a\u0646\u0638\u06cc\u0645 \u062c\u062f\u0627\u0648\u0644<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_%d9%85%d8%af%d9%84\" >\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0645\u062f\u0644<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d9%be%d8%b4%d8%aa%db%8c%d8%a8%d8%a7%d9%86%db%8c_es6\" >\u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc ES6<\/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\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d9%85%d8%ac%d9%85%d9%88%d8%b9%d9%87_%d9%87%d8%a7\" >\u0645\u062c\u0645\u0648\u0639\u0647 \u0647\u0627<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d9%85%d8%af%d9%84_%d9%87%d8%a7%db%8c_%d8%ae%d9%88%d8%af_%d8%b1%d8%a7_%da%af%d8%b3%d8%aa%d8%b1%d8%b4_%d8%af%d9%87%db%8c%d8%af\" >\u0645\u062f\u0644 \u0647\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u06af\u0633\u062a\u0631\u0634 \u062f\u0647\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d8%b0%d8%ae%db%8c%d8%b1%d9%87_%d9%88_%d8%a8%d9%87_%d8%b1%d9%88%d8%b2_%d8%b1%d8%b3%d8%a7%d9%86%db%8c_%d9%85%d8%af%d9%84_%d9%87%d8%a7\" >\u0630\u062e\u06cc\u0631\u0647 \u0648 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u0645\u062f\u0644 \u0647\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d8%af%d8%b1_%d8%ad%d8%a7%d9%84_%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d9%85%d8%af%d9%84_%d9%87%d8%a7\" >\u062f\u0631 \u062d\u0627\u0644 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u062f\u0644 \u0647\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d8%b1%d9%88%d8%a7%d8%a8%d8%b7_%d9%85%d8%af%d9%84\" >\u0631\u0648\u0627\u0628\u0637 \u0645\u062f\u0644<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d8%ae%d9%88%d8%a8\" >\u062e\u0648\u0628<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-12\" href=\"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d8%a8%d8%af\" >\u0628\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-13\" href=\"https:\/\/rasanegaar.com\/blog\/bookshelf-js-%db%8c%da%a9-node-js-ormon-%db%8c%da%a9%db%8c-%d8%a7%d8%b2-%d8%b1%d8%a7%db%8c%d8%ac%d8%aa%d8%b1%db%8c%d9%86-%d9%85%d9%86%d8%a7%d8%a8%d8%b9%db%8c-%da%a9%d9%87-%d8%af%d8%b1-%d8%b2\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/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\"> 9<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div class=\"content\"><noscript><\/p>\n<style>.lazyload-placeholder { display: none;  }<\/style>\n<p><\/noscript><\/p>\n<p>\u06cc\u06a9\u06cc \u0627\u0632 \u0631\u0627\u06cc\u062c \u062a\u0631\u06cc\u0646 \u0645\u0646\u0627\u0628\u0639\u06cc \u06a9\u0647 \u062f\u0631 \u0632\u0628\u0627\u0646\u06cc \u0645\u0627\u0646\u0646\u062f Node.js (\u0639\u0645\u062f\u062a\u0627\u064b \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u0645\u062a\u0645\u0631\u06a9\u0632 \u0628\u0631 \u0648\u0628) \u0628\u0627 \u0622\u0646 \u062a\u0639\u0627\u0645\u0644 \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0627\u0634\u062a\u060c \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0647\u0633\u062a\u0646\u062f.  \u0648 \u0628\u0627 \u062a\u0648\u062c\u0647 \u0628\u0647 \u0627\u06cc\u0646\u06a9\u0647 SQL \u0645\u062a\u062f\u0627\u0648\u0644 \u062a\u0631\u06cc\u0646 \u062f\u0631 \u0628\u06cc\u0646 \u0627\u0646\u0648\u0627\u0639 \u0645\u062e\u062a\u0644\u0641 \u0627\u0633\u062a\u060c \u0628\u0647 \u06cc\u06a9 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u062e\u0648\u0628 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f \u062a\u0627 \u0628\u0647 \u0634\u0645\u0627 \u062f\u0631 \u062a\u0639\u0627\u0645\u0644 \u0628\u0627 \u0622\u0646 \u0648 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0645\u062a\u0639\u062f\u062f \u0622\u0646 \u06a9\u0645\u06a9 \u06a9\u0646\u062f.<\/p>\n<p>Bookshelf.js \u06cc\u06a9\u06cc \u0627\u0632 \u0645\u062d\u0628\u0648\u0628\u200c\u062a\u0631\u06cc\u0646 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc ORM Node.js \u0627\u0633\u062a.  \u0627\u0632 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/tgriesser\/knex\">Knex.js<\/a>\u060c \u06a9\u0647 \u06cc\u06a9 \u0633\u0627\u0632\u0646\u062f\u0647 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0627\u0646\u0639\u0637\u0627\u0641 \u067e\u0630\u06cc\u0631 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 PostgreSQL\u060c MySQL \u0648 SQLite3 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f. <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/tgriesser\/bookshelf\/\">Bookshelf.js<\/a> \u0645\u06cc \u0633\u0627\u0632\u062f \u0631\u0648\u06cc \u0628\u0627\u0644\u0627\u062a\u0631 \u0627\u0632 \u0627\u06cc\u0646\u060c \u0628\u0627 \u0627\u0631\u0627\u0626\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u062f\u0644 \u0647\u0627\u06cc \u062f\u0627\u062f\u0647\u060c \u0627\u06cc\u062c\u0627\u062f \u0631\u0648\u0627\u0628\u0637 \u0628\u06cc\u0646 \u0627\u06cc\u0646 \u0645\u062f\u0644 \u0647\u0627\u060c \u0648 \u0633\u0627\u06cc\u0631 \u0648\u0638\u0627\u06cc\u0641 \u0631\u0627\u06cc\u062c \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0647\u0646\u06af\u0627\u0645 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0627\u0632 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647.<\/p>\n<p>\u0642\u0641\u0633\u0647 \u06a9\u062a\u0627\u0628 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0627\u0632 \u0686\u0646\u062f\u06cc\u0646 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f\u060c \u0645\u0627\u0646\u0646\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/en.wikipedia.org\/wiki\/MySQL\">MySQL<\/a>\u060c <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/en.wikipedia.org\/wiki\/PostgreSQL\">PostgreSQL<\/a>\u060c \u0648 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/en.wikipedia.org\/wiki\/SQLite\">SQLite<\/a>.  \u0628\u0647 \u0627\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u062f\u0631 \u0635\u0648\u0631\u062a \u0646\u06cc\u0627\u0632 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u06cc\u062f \u06cc\u0627 \u0627\u0632 \u06cc\u06a9 DB \u06a9\u0648\u0686\u06a9\u062a\u0631 \u0645\u0627\u0646\u0646\u062f SQLite \u062f\u0631 \u0637\u0648\u0644 \u062a\u0648\u0633\u0639\u0647 \u0648 Postgre \u062f\u0631 \u062a\u0648\u0644\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u062f\u0631 \u0637\u0648\u0644 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647 \u0628\u0647 \u0634\u0645\u0627 \u0646\u0634\u0627\u0646 \u062e\u0648\u0627\u0647\u0645 \u062f\u0627\u062f \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0627\u06cc\u0646 Node ORM \u0628\u06cc\u0634\u062a\u0631\u06cc\u0646 \u0628\u0647\u0631\u0647 \u0631\u0627 \u0628\u0628\u0631\u06cc\u062f\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 \u0627\u062a\u0635\u0627\u0644 \u0628\u0647 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647\u060c \u0627\u06cc\u062c\u0627\u062f \u0645\u062f\u0644 \u0647\u0627 \u0648 \u0630\u062e\u06cc\u0631\u0647\/\u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0627\u0634\u06cc\u0627.<\/p>\n<h2 id=\"installbookshelf\"><span class=\"ez-toc-section\" id=\"%d9%82%d9%81%d8%b3%d9%87_%da%a9%d8%aa%d8%a7%d8%a8_%d8%b1%d8%a7_%d9%86%d8%b5%d8%a8_%da%a9%d9%86%db%8c%d8%af\"><\/span>\u0642\u0641\u0633\u0647 \u06a9\u062a\u0627\u0628 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>Bookshelf \u0628\u0627 \u0627\u06a9\u062b\u0631 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc Node \u06a9\u0645\u06cc \u0645\u062a\u0641\u0627\u0648\u062a \u0627\u0633\u062a\u060c \u0632\u06cc\u0631\u0627 \u062a\u0645\u0627\u0645 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c\u0647\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0628\u0631\u0627\u06cc \u0634\u0645\u0627 \u0646\u0635\u0628 \u0646\u0645\u06cc\u200c\u06a9\u0646\u062f.  \u062f\u0631 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a\u060c \u0628\u0627\u06cc\u062f Knex \u0631\u0627 \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 Bookshelf \u0628\u0647 \u0635\u0648\u0631\u062a \u062f\u0633\u062a\u06cc \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\">$ npm install knex --save\n$ npm install bookshelf --save\n<\/code><\/pre>\n<p>\u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0622\u0646\u060c \u0628\u0627\u06cc\u062f \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0628\u0627 \u06a9\u062f\u0627\u0645 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u0627\u0632 Bookshelf \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.  \u0627\u0646\u062a\u062e\u0627\u0628 \u0647\u0627\u06cc \u0634\u0645\u0627 \u0639\u0628\u0627\u0631\u062a\u0646\u062f \u0627\u0632:<\/p>\n<ul>\n<li><a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.npmjs.com\/package\/pg\">\u0635\u0641\u062d\u0647<\/a> (PostgreSQL)<\/li>\n<li><a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.npmjs.com\/package\/mysql\">mysql<\/a><\/li>\n<li><a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.npmjs.com\/package\/mariasql\">mariasql<\/a><\/li>\n<li><a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.npmjs.com\/package\/sqlite3\">sqlite3<\/a><\/li>\n<\/ul>\n<p>\u0627\u06cc\u0646\u0647\u0627 \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0627:<\/p>\n<pre><code class=\"hljs\">$ npm install pg --save\n$ npm install mysql --save\n$ npm install mariasql --save\n$ npm install sqlite3 --save\n<\/code><\/pre>\n<p>\u06cc\u06a9\u06cc \u0627\u0632 \u06a9\u0627\u0631\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u0646 \u062a\u0645\u0627\u06cc\u0644 \u062f\u0627\u0631\u0645 \u0628\u0627 \u067e\u0631\u0648\u0698\u0647 \u0647\u0627\u06cc \u062e\u0648\u062f \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0645\u060c \u0646\u0635\u0628 \u06cc\u06a9 DB \u062f\u0631\u062c\u0647 \u062a\u0648\u0644\u06cc\u062f (\u0645\u0627\u0646\u0646\u062f Postgre) \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a <code>--save<\/code>\u060c \u062f\u0631 \u062d\u06cc\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 <code>--save-dev<\/code> \u0628\u0631\u0627\u06cc \u06cc\u06a9 DB \u06a9\u0648\u0686\u06a9\u062a\u0631 \u0645\u0627\u0646\u0646\u062f SQLite \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062f\u0631 \u0637\u0648\u0644 \u062a\u0648\u0633\u0639\u0647.<\/p>\n<pre><code class=\"hljs\">$ npm install pg --save\n$ npm install sqlite3 --save-dev\n<\/code><\/pre>\n<p>\u0628\u0647 \u0627\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0628\u06cc\u0646 \u067e\u0627\u06cc\u06af\u0627\u0647\u200c\u0647\u0627\u06cc \u062f\u0627\u062f\u0647 \u062f\u0631 \u062a\u0648\u0644\u06cc\u062f \u0648 \u062a\u0648\u0633\u0639\u0647 \u062c\u0627\u0628\u0647\u200c\u062c\u0627 \u0634\u0648\u06cc\u0645\u060c \u0628\u062f\u0648\u0646 \u0627\u06cc\u0646\u06a9\u0647 \u0646\u06af\u0631\u0627\u0646 \u0633\u06cc\u0644 \u0634\u062f\u0646 \u0645\u062d\u06cc\u0637 \u062a\u0648\u0644\u06cc\u062f \u0645\u0646 \u0628\u0627 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c\u0647\u0627\u06cc \u063a\u06cc\u0631 \u0636\u0631\u0648\u0631\u06cc \u0628\u0627\u0634\u06cc\u0645.<\/p>\n<h2 id=\"connectingtoadatabase\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%aa%d8%b5%d8%a7%d9%84_%d8%a8%d9%87_%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87_%d8%af%d8%a7%d8%af%d9%87\"><\/span>\u0627\u062a\u0635\u0627\u0644 \u0628\u0647 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062a\u0645\u0627\u0645 \u062a\u0648\u0627\u0628\u0639 \u0633\u0637\u062d \u067e\u0627\u06cc\u06cc\u0646\u060c \u0645\u0627\u0646\u0646\u062f \u0627\u062a\u0635\u0627\u0644 \u0628\u0647 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647\u060c \u062a\u0648\u0633\u0637 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 Knex \u0632\u06cc\u0631\u06cc\u0646 \u0627\u062f\u0627\u0631\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0628\u0647 \u0637\u0648\u0631 \u0637\u0628\u06cc\u0639\u06cc\u060c \u0628\u0647 \u0645\u0646\u0638\u0648\u0631 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0634\u0645\u0627 <code>bookshelf<\/code> \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u0634\u0645\u0627 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 <code>knex<\/code> \u0628\u0631\u0627\u06cc \u0645\u062b\u0627\u0644 \u0627\u0648\u0644\u060c \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> knex = <span class=\"hljs-built_in\">require<\/span>(<span class=\"hljs-string\">'knex'<\/span>)({\n    <span class=\"hljs-attr\">client<\/span>: <span class=\"hljs-string\">'sqlite3'<\/span>,\n    <span class=\"hljs-attr\">connection<\/span>: {\n        <span class=\"hljs-attr\">filename<\/span>: <span class=\"hljs-string\">'.\/db.sqlite'<\/span>\n    }\n});\n\n<span class=\"hljs-keyword\">var<\/span> bookshelf = <span class=\"hljs-built_in\">require<\/span>(<span class=\"hljs-string\">'bookshelf'<\/span>)(knex);\n<\/code><\/pre>\n<p>\u0648 \u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code>bookshelf<\/code> \u0646\u0645\u0648\u0646\u0647 \u0627\u06cc \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u062f\u0644 \u0647\u0627\u06cc \u062e\u0648\u062f<\/p>\n<h2 id=\"settingupthetables\"><span class=\"ez-toc-section\" id=\"%d8%aa%d9%86%d8%b8%db%8c%d9%85_%d8%ac%d8%af%d8%a7%d9%88%d9%84\"><\/span>\u062a\u0646\u0638\u06cc\u0645 \u062c\u062f\u0627\u0648\u0644<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>Knex\u060c \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0648\u0628 \u0633\u0627\u06cc\u062a \u062e\u0648\u062f \u0628\u06cc\u0627\u0646 \u0645\u06cc \u06a9\u0646\u062f\u060c \u06cc\u06a9 \u0633\u0627\u0632\u0646\u062f\u0647 \u067e\u0631\u0633 \u0648 \u062c\u0648\u06cc SQL &#8220;\u0628\u0627 \u0628\u0627\u062a\u0631\u06cc \u0647\u0627 \u0627\u0633\u062a&#8221; \u0627\u0633\u062a\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062a\u0642\u0631\u06cc\u0628\u0627\u064b \u0647\u0631 \u06a9\u0627\u0631\u06cc \u0631\u0627 \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0627 \u062f\u0633\u062a\u0648\u0631\u0627\u062a SQL \u062e\u0627\u0645 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f \u0627\u0632 \u0637\u0631\u06cc\u0642 Knex \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f.  \u06cc\u06a9\u06cc \u0627\u0632 \u0627\u06cc\u0646 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0645\u0647\u0645 \u062c\u062f\u0648\u0644 \u0633\u0627\u0632\u06cc \u0648 \u062f\u0633\u062a\u06a9\u0627\u0631\u06cc \u0627\u0633\u062a.  Knex \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0645\u0633\u062a\u0642\u06cc\u0645\u0627\u064b \u0628\u0631\u0627\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0637\u0631\u062d\u0648\u0627\u0631\u0647 \u062e\u0648\u062f \u062f\u0631 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0634\u0648\u062f (\u0628\u0647 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647\u060c \u0645\u0647\u0627\u062c\u0631\u062a \u0637\u0631\u062d \u0648 \u063a\u06cc\u0631\u0647 \u0641\u06a9\u0631 \u06a9\u0646\u06cc\u062f).<\/p>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0627\u0648\u0644 \u0627\u0632 \u0647\u0645\u0647\u060c \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u062c\u062f\u0648\u0644 \u062e\u0648\u062f \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f <code>knex.schema.createTable()<\/code>\u060c \u06a9\u0647 \u06cc\u06a9 \u0634\u06cc \u062c\u062f\u0648\u0644 \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f \u06a9\u0647 \u0634\u0627\u0645\u0644 \u06cc\u06a9 \u062f\u0633\u062a\u0647 \u0627\u0632 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/knexjs.org\/#Schema-Building\">\u0637\u0631\u062d\u0648\u0627\u0631\u0647 \u0633\u0627\u0632\u06cc<\/a> \u062a\u0648\u0627\u0628\u0639\u060c \u0645\u0627\u0646\u0646\u062f <code>table.increments()<\/code>\u060c <code>table.string()<\/code>\u060c \u0648 <code>table.date()<\/code>.  \u0628\u0631\u0627\u06cc \u0647\u0631 \u0645\u062f\u0644\u06cc \u06a9\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u062f\u060c \u0628\u0627\u06cc\u062f \u0628\u0631\u0627\u06cc \u0647\u0631 \u06a9\u062f\u0627\u0645 \u06cc\u06a9 \u06a9\u0627\u0631\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 \u0627\u06cc\u0646 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\">knex.schema.createTable(<span class=\"hljs-string\">'users'<\/span>, <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">table<\/span>) <\/span>{\n    table.increments();\n    table.string(<span class=\"hljs-string\">'name'<\/span>);\n    table.string(<span class=\"hljs-string\">'email'<\/span>, <span class=\"hljs-number\">128<\/span>);\n    table.string(<span class=\"hljs-string\">'role'<\/span>).defaultTo(<span class=\"hljs-string\">'admin'<\/span>);\n    table.string(<span class=\"hljs-string\">'password'<\/span>);\n    table.timestamps();\n});\n<\/code><\/pre>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0645\u06cc \u0628\u06cc\u0646\u06cc\u062f \u06a9\u0647 \u0645\u0627 \u062c\u062f\u0648\u0644\u06cc \u0628\u0647 \u0646\u0627\u0645 \u00ab\u06a9\u0627\u0631\u0628\u0631\u0627\u0646\u00bb \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0633\u067e\u0633 \u0628\u0627 \u0633\u062a\u0648\u0646 \u0647\u0627\u06cc \u00ab\u0646\u0627\u0645\u00bb\u060c \u00ab\u0627\u06cc\u0645\u06cc\u0644\u00bb\u060c \u00ab\u0646\u0642\u0634\u00bb \u0648 \u00ab\u0631\u0645\u0632 \u0639\u0628\u0648\u0631\u00bb \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645.  \u062d\u062a\u06cc \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u06cc\u06a9 \u0642\u062f\u0645 \u062c\u0644\u0648\u062a\u0631 \u0628\u0631\u0648\u06cc\u0645 \u0648 \u062d\u062f\u0627\u06a9\u062b\u0631 \u0637\u0648\u0644 \u06cc\u06a9 \u0633\u062a\u0648\u0646 \u0631\u0634\u062a\u0647 (128 \u0628\u0631\u0627\u06cc \u0633\u062a\u0648\u0646 &#8216;\u0627\u06cc\u0645\u06cc\u0644&#8217;) \u06cc\u0627 \u06cc\u06a9 \u0645\u0642\u062f\u0627\u0631 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 (&#8216;admin&#8217; \u0628\u0631\u0627\u06cc \u0633\u062a\u0648\u0646 &#8216;\u0646\u0642\u0634&#8217;) \u0631\u0627 \u0645\u0634\u062e\u0635 \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0628\u0631\u062e\u06cc \u0627\u0632 \u062a\u0648\u0627\u0628\u0639 \u0631\u0627\u062d\u062a\u06cc \u0646\u06cc\u0632 \u0627\u0631\u0627\u0626\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0645\u0627\u0646\u0646\u062f <code>timestamps()<\/code>.  \u0627\u06cc\u0646 \u062a\u0627\u0628\u0639 \u062f\u0648 \u0633\u062a\u0648\u0646 \u0645\u0647\u0631 \u0632\u0645\u0627\u0646 \u0631\u0627 \u0628\u0647 \u062c\u062f\u0648\u0644 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u062f. <code>created_at<\/code> \u0648 <code>updated_at<\/code>.  \u0627\u06af\u0631 \u0627\u0632 \u0627\u06cc\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u062a\u0646\u0638\u06cc\u0645 \u0631\u0627 \u0646\u06cc\u0632 \u062f\u0631 \u0646\u0638\u0631 \u0628\u06af\u06cc\u0631\u06cc\u062f <code>hasTimestamps<\/code> \u062f\u0627\u0631\u0627\u06cc\u06cc \u0628\u0647 <code>true<\/code> \u062f\u0631 \u0645\u062f\u0644 \u062e\u0648\u062f (\u0628\u0647 \u00ab\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0645\u062f\u0644\u00bb \u062f\u0631 \u0632\u06cc\u0631 \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f).<\/p>\n<p>\u0686\u0646\u062f\u06cc\u0646 \u06af\u0632\u06cc\u0646\u0647 \u062f\u06cc\u06af\u0631 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0631\u0627\u06cc \u0647\u0631 \u062c\u062f\u0648\u0644\/\u0633\u062a\u0648\u0646 \u0645\u0634\u062e\u0635 \u06a9\u0646\u06cc\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0646 \u0642\u0637\u0639\u0627\u064b \u062a\u0648\u0635\u06cc\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0645 \u062a\u0645\u0627\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f. <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/knexjs.org\">\u0645\u0633\u062a\u0646\u062f\u0627\u062a Knex<\/a> \u0628\u0631\u0627\u06cc \u062c\u0632\u0626\u06cc\u0627\u062a \u0628\u06cc\u0634\u062a\u0631<\/p>\n<h2 id=\"creatingamodel\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_%d9%85%d8%af%d9%84\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0645\u062f\u0644<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u06cc\u06a9\u06cc \u0627\u0632 \u0627\u0634\u06a9\u0627\u0644\u0627\u062a \u0645\u0646 \u062f\u0631 \u0645\u0648\u0631\u062f Bookshelf \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0634\u0645\u0627 \u0647\u0645\u06cc\u0634\u0647 \u0628\u0647 \u06cc\u06a9 \u0645\u0642\u062f\u0627\u0631 \u0627\u0648\u0644\u06cc\u0647 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f <code>bookshelf<\/code> \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0645\u062f\u0644\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0627\u06af\u0631 \u0647\u0645\u0647 \u0645\u062f\u0644\u200c\u0647\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0646\u06af\u0647 \u062f\u0627\u0631\u06cc\u062f\u060c \u0633\u0627\u062e\u062a\u0627\u0631 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u06a9\u0645\u06cc \u0622\u0634\u0641\u062a\u0647 \u0628\u0627\u0634\u062f.  \u0645\u0646 \u0634\u062e\u0635\u0627 \u062a\u0631\u062c\u06cc\u062d \u0645\u06cc \u062f\u0647\u0645 \u0641\u0642\u0637 \u0628\u0633\u0627\u0632\u0645 <code>bookshelf<\/code> \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062c\u0647\u0627\u0646\u06cc <code>global.bookshelf = bookshelf<\/code>\u060c \u0627\u0645\u0627 \u0627\u06cc\u0646 \u0644\u0632\u0648\u0645\u0627 \u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0627\u0647 \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0622\u0646 \u0646\u06cc\u0633\u062a.<\/p>\n<p>\u0628\u0647 \u0647\u0631 \u062d\u0627\u0644\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0628\u06cc\u0646\u06cc\u0645 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0645\u062f\u0644 \u0633\u0627\u062f\u0647 \u0686\u0647 \u0686\u06cc\u0632\u06cc \u0644\u0627\u0632\u0645 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> User = bookshelf.Model.extend({\n    <span class=\"hljs-attr\">tableName<\/span>: <span class=\"hljs-string\">'users'<\/span>,\n    <span class=\"hljs-attr\">hasTimestamps<\/span>: <span class=\"hljs-literal\">true<\/span>,\n\n    <span class=\"hljs-attr\">verifyPassword<\/span>: <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">password<\/span>) <\/span>{\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.get(<span class=\"hljs-string\">'password'<\/span>) === password;\n    }\n}, {\n    <span class=\"hljs-attr\">byEmail<\/span>: <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">email<\/span>) <\/span>{\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.forge().query({<span class=\"hljs-attr\">where<\/span>:{ <span class=\"hljs-attr\">email<\/span>: email }}).fetch();\n    }\n});\n<\/code><\/pre>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0645\u0627 \u06cc\u06a9 \u0645\u062f\u0644 \u0628\u0633\u06cc\u0627\u0631 \u0633\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0646 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0645\u0648\u062c\u0648\u062f \u062f\u0627\u0631\u06cc\u0645.  \u0627\u0648\u0644 \u0627\u0632 \u0647\u0645\u0647\u060c <em>\u0641\u0642\u0637<\/em> \u0627\u0645\u0648\u0627\u0644 \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0627\u0633\u062a <code>tableName<\/code>\u060c \u06a9\u0647 \u0628\u0647 \u0645\u062f\u0644 \u0645\u06cc \u06af\u0648\u06cc\u062f \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u0627\u0632 \u06a9\u062c\u0627 \u062f\u0631 DB \u0630\u062e\u06cc\u0631\u0647 \u0648 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u06a9\u0646\u062f.  \u0628\u062f\u06cc\u0647\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06cc\u06a9 \u0645\u062f\u0644 \u0628\u0633\u06cc\u0627\u0631 \u06a9\u0645 \u0627\u0633\u062a \u0632\u06cc\u0631\u0627 \u0647\u0645\u0647 \u0627\u0639\u0644\u0627\u0646 \u0637\u0631\u062d \u062f\u0631 \u062c\u0627\u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u062f\u0631 \u0645\u0648\u0631\u062f \u0628\u0642\u06cc\u0647 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\/\u062a\u0648\u0627\u0628\u0639\u060c \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u062e\u0644\u0627\u0635\u0647 \u0627\u06cc \u0633\u0631\u06cc\u0639 \u0627\u0632 \u0686\u0647 \u0686\u06cc\u0632\u06cc \u0627\u0633\u062a <code>User<\/code> \u0634\u0627\u0645\u0644 \u0645\u06cc \u0634\u0648\u062f:<\/p>\n<ul>\n<li><code>tableName<\/code>: \u0631\u0634\u062a\u0647 \u0627\u06cc \u06a9\u0647 \u0628\u0647 \u0645\u062f\u0644 \u0645\u06cc \u06af\u0648\u06cc\u062f \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u0627\u0632 \u06a9\u062c\u0627 \u062f\u0631 DB \u0630\u062e\u06cc\u0631\u0647 \u0648 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u06a9\u0646\u062f (\u0627\u0644\u0632\u0627\u0645\u06cc)<\/li>\n<li><code>hasTimestamps<\/code>: \u06cc\u06a9 \u0645\u0642\u062f\u0627\u0631 \u0628\u0648\u0644\u06cc \u06a9\u0647 \u0628\u0647 \u0645\u062f\u0644 \u0645\u06cc \u06af\u0648\u06cc\u062f \u06a9\u0647 \u0622\u06cc\u0627 \u0645\u0627 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645 \u06cc\u0627 \u062e\u06cc\u0631 <code>created_at<\/code> \u0648 <code>updated_at<\/code> \u0645\u0647\u0631\u0647\u0627\u06cc \u0632\u0645\u0627\u0646\u06cc<\/li>\n<li><code>verifyPassword<\/code>: \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u0646\u0645\u0648\u0646\u0647<\/li>\n<li><code>byEmail<\/code>: \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u06a9\u0644\u0627\u0633 (\u0627\u0633\u062a\u0627\u062a\u06cc\u06a9).<\/li>\n<\/ul>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0628\u0631\u0627\u06cc \u0645\u062b\u0627\u0644\u060c \u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <code>byEmail<\/code> \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0631\u0627\u0647 \u06a9\u0648\u062a\u0627\u0647 \u062a\u0631 \u0628\u0631\u0627\u06cc \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0627\u0632 \u06a9\u0627\u0631\u0628\u0631 \u0628\u0627 \u0622\u062f\u0631\u0633 \u0627\u06cc\u0645\u06cc\u0644 \u0627\u0648:<\/p>\n<pre><code class=\"hljs\">User.byEmail(<span class=\"hljs-string\">'(email\u00a0protected)'<\/span>).then(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">u<\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'Got user:'<\/span>, u.get(<span class=\"hljs-string\">'name'<\/span>));\n});\n<\/code><\/pre>\n<p>\u0628\u0647 \u0631\u0648\u0634 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0645\u062f\u0644 \u062f\u0631 Bookshelf \u062a\u0648\u062c\u0647 \u06a9\u0646\u06cc\u062f.  \u0628\u0647 \u062c\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u0645\u0633\u062a\u0642\u06cc\u0645 (\u0645\u0627\u0646\u0646\u062f <code>u.name<\/code>\u060c \u0628\u0627\u06cc\u062f \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <code>.get()<\/code> \u0631\u0648\u0634.<\/p>\n<h3 id=\"es6support\"><span class=\"ez-toc-section\" id=\"%d9%be%d8%b4%d8%aa%db%8c%d8%a8%d8%a7%d9%86%db%8c_es6\"><\/span>\u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc ES6<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 \u0632\u0645\u0627\u0646 \u0646\u06af\u0627\u0631\u0634 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0628\u0647 \u0646\u0638\u0631 \u0646\u0645\u06cc\u200c\u0631\u0633\u062f \u06a9\u0647 Bookshelf \u0627\u0632 ES6 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u06a9\u0627\u0645\u0644 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f (\u0646\u06af\u0627\u0647 \u06a9\u0646\u06cc\u062f \u0628\u0647 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/tgriesser\/bookshelf\/issues\/756\" class=\"broken_link\">\u0627\u06cc\u0646 \u0645\u0633\u0627\u0644\u0647<\/a>).  \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0647\u0646\u0648\u0632 \u0647\u0645 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u06a9\u062f\u0647\u0627\u06cc \u0645\u062f\u0644 \u062e\u0648\u062f \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06a9\u0644\u0627\u0633 \u0647\u0627\u06cc \u062c\u062f\u06cc\u062f ES6 \u0628\u0646\u0648\u06cc\u0633\u06cc\u062f.  \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0645\u062f\u0644 \u0627\u0632 \u0628\u0627\u0644\u0627\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 new \u062f\u0648\u0628\u0627\u0631\u0647 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>class<\/code> \u0646\u062d\u0648\u06cc \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-class\"><span class=\"hljs-keyword\">class<\/span> <span class=\"hljs-title\">User<\/span> <span class=\"hljs-keyword\">extends<\/span> <span class=\"hljs-title\">bookshelf<\/span>.<span class=\"hljs-title\">Model<\/span> <\/span>{\n    <span class=\"hljs-keyword\">get<\/span> <span class=\"hljs-title\">tableName<\/span>() {\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-string\">'users'<\/span>;\n    }\n\n    <span class=\"hljs-keyword\">get<\/span> <span class=\"hljs-title\">hasTimestamps<\/span>() {\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-literal\">true<\/span>;\n    }\n\n    <span class=\"hljs-function\"><span class=\"hljs-title\">verifyPassword<\/span>(<span class=\"hljs-params\">password<\/span>)<\/span> {\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.get(<span class=\"hljs-string\">'password'<\/span>) === password;\n    }\n\n    <span class=\"hljs-keyword\">static<\/span> <span class=\"hljs-function\"><span class=\"hljs-title\">byEmail<\/span>(<span class=\"hljs-params\">email<\/span>)<\/span> {\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.forge().query({<span class=\"hljs-attr\">where<\/span>:{ <span class=\"hljs-attr\">email<\/span>: email }}).fetch();\n    }\n}\n<\/code><\/pre>\n<p>\u0648 \u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0627\u0632 \u0627\u06cc\u0646 \u0645\u062f\u0644 \u062f\u0642\u06cc\u0642\u0627\u064b \u0645\u0627\u0646\u0646\u062f \u0645\u062f\u0644 \u0642\u0628\u0644\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f.  \u0627\u06cc\u0646 \u0631\u0648\u0634 \u0647\u06cc\u0686 \u0645\u0632\u06cc\u062a \u0639\u0645\u0644\u06a9\u0631\u062f\u06cc \u0628\u0647 \u0634\u0645\u0627 \u0646\u0645\u06cc \u062f\u0647\u062f\u060c \u0627\u0645\u0627 \u0628\u0631\u0627\u06cc \u0628\u0631\u062e\u06cc \u0627\u0641\u0631\u0627\u062f \u0622\u0634\u0646\u0627\u062a\u0631 \u0627\u0633\u062a\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0627\u0632 \u0622\u0646 \u0628\u0647\u0631\u0647 \u0628\u0628\u0631\u06cc\u062f.<\/p>\n<h3 id=\"collections\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%ac%d9%85%d9%88%d8%b9%d9%87_%d9%87%d8%a7\"><\/span>\u0645\u062c\u0645\u0648\u0639\u0647 \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 Bookshelf \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u0634\u06cc \u062c\u062f\u0627\u06af\u0627\u0646\u0647 \u0628\u0631\u0627\u06cc \u0645\u062c\u0645\u0648\u0639\u0647 \u0647\u0627\u06cc \u06cc\u06a9 \u0645\u062f\u0644 \u0645\u0634\u062e\u0635 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0639\u0645\u0644\u06cc\u0627\u062a\u06cc \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f \u0631\u0648\u06cc \u0686\u0646\u062f\u06af\u0627\u0646\u0647 <code>User<\/code>s \u062f\u0631 \u0647\u0645\u0627\u0646 \u0632\u0645\u0627\u0646\u060c \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0634\u0645\u0627 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 <code>Collection<\/code>.<\/p>\n<p>\u062f\u0631 \u0627\u062f\u0627\u0645\u0647 \u0645\u062b\u0627\u0644 \u0645\u0627 \u0627\u0632 \u0628\u0627\u0644\u0627\u060c \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u0622\u0646 \u0627\u0633\u062a <code>Users<\/code> <code>Collection<\/code>  \u0647\u062f\u0641 &#8211; \u0634\u06cc:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> Users = bookshelf.Collection.extend({\n    <span class=\"hljs-attr\">model<\/span>: User\n});\n<\/code><\/pre>\n<p>\u062e\u06cc\u0644\u06cc \u0633\u0627\u062f\u0647\u060c \u062f\u0631\u0633\u062a \u0627\u0633\u062a\u061f  \u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0628\u0631\u0627\u06cc \u0647\u0645\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u06a9\u0646\u06cc\u0645 (\u0627\u06af\u0631\u0686\u0647 \u0627\u06cc\u0646 \u0642\u0628\u0644\u0627\u064b \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0645\u062f\u0644 \u0645\u0645\u06a9\u0646 \u0628\u0648\u062f <code>.fetchAll()<\/code>):<\/p>\n<pre><code class=\"hljs\">Users.forge().fetch().then(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">users<\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'Got a bunch of users!'<\/span>);\n});\n<\/code><\/pre>\n<p>\u062d\u062a\u06cc \u0628\u0647\u062a\u0631 \u0627\u0632 \u0622\u0646\u060c \u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0686\u0646\u062f \u0631\u0648\u0634 \u0645\u062f\u0644 \u062e\u0648\u0628 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 \u0631\u0648\u06cc \u0645\u062c\u0645\u0648\u0639\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u06a9\u0644\u060c \u0628\u0647 \u062c\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0645\u062c\u0628\u0648\u0631 \u0628\u0627\u0634\u06cc\u062f \u0631\u0648\u06cc \u0647\u0631 \u0645\u062f\u0644 \u0628\u0647 \u0637\u0648\u0631 \u062c\u062f\u0627\u06af\u0627\u0646\u0647 \u062a\u06a9\u0631\u0627\u0631 \u06a9\u0646\u06cc\u062f.  \u06cc\u06a9\u06cc \u0627\u0632 \u0627\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627 \u06a9\u0647 \u0628\u0647 \u0646\u0638\u0631 \u0645\u06cc \u0631\u0633\u062f \u062f\u0631 \u0648\u0628 \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0647\u0627 \u0628\u0633\u06cc\u0627\u0631 \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0642\u0631\u0627\u0631 \u0645\u06cc \u06af\u06cc\u0631\u062f\u060c \u0627\u06cc\u0646 \u0627\u0633\u062a <code>.toJSON()<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-built_in\">exports<\/span>.get = <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">req, res<\/span>) <\/span>{\n    Users.forge().fetch().then(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">users<\/span>) <\/span>{\n        res.json(users.toJSON());\n    });\n};\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u06cc\u06a9 \u0634\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0633\u0627\u062f\u0647 \u0627\u0632 \u06a9\u0644 \u0645\u062c\u0645\u0648\u0639\u0647 \u0631\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f.<\/p>\n<h2 id=\"extendingyourmodels\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%af%d9%84_%d9%87%d8%a7%db%8c_%d8%ae%d9%88%d8%af_%d8%b1%d8%a7_%da%af%d8%b3%d8%aa%d8%b1%d8%b4_%d8%af%d9%87%db%8c%d8%af\"><\/span>\u0645\u062f\u0644 \u0647\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u06af\u0633\u062a\u0631\u0634 \u062f\u0647\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647\u060c \u06cc\u06a9\u06cc \u0627\u0632 \u0645\u0647\u0645 \u062a\u0631\u06cc\u0646 \u0627\u0635\u0648\u0644\u06cc \u06a9\u0647 \u0645\u0646 \u0631\u0639\u0627\u06cc\u062a \u06a9\u0631\u062f\u0647 \u0627\u0645 \u0627\u06cc\u0646 \u0627\u0633\u062a <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/en.wikipedia.org\/wiki\/Don&#039;t_repeat_yourself\">\u062e\u0634\u06a9<\/a> \u0627\u0635\u0644 (\u062a\u06a9\u0631\u0627\u0631 \u0646\u06a9\u0646)  \u0627\u06cc\u0646 \u062a\u0646\u0647\u0627 \u06cc\u06a9\u06cc \u0627\u0632 \u062f\u0644\u0627\u06cc\u0644\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0686\u0631\u0627 \u067e\u0633\u0648\u0646\u062f \u0645\u062f\u0644\/\u0634\u0645\u0627 \u0628\u0631\u0627\u06cc \u0637\u0631\u0627\u062d\u06cc \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631 \u0634\u0645\u0627 \u0628\u0633\u06cc\u0627\u0631 \u0645\u0647\u0645 \u0627\u0633\u062a.<\/p>\n<p>\u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0642\u0641\u0633\u0647 \u06a9\u062a\u0627\u0628 <code>.extend()<\/code> \u0645\u062a\u062f\u060c \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062a\u0645\u0627\u0645 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u060c \u0645\u062a\u062f\u0647\u0627\u06cc \u0646\u0645\u0648\u0646\u0647 \u0648 \u0645\u062a\u062f\u0647\u0627\u06cc \u06a9\u0644\u0627\u0633 \u06cc\u06a9 \u0645\u062f\u0644 \u067e\u0627\u06cc\u0647 \u0631\u0627 \u0628\u0647 \u0627\u0631\u062b \u0628\u0628\u0631\u06cc\u062f.  \u0628\u0647 \u0627\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u067e\u0627\u06cc\u0647\u200c\u0627\u06cc \u0631\u0627 \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u0627\u0631\u0627\u0626\u0647 \u0646\u0634\u062f\u0647\u200c\u0627\u0646\u062f\u060c \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u0648 \u0627\u0632 \u0622\u0646\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code>.find()<\/code>\u060c <code>.findOne()<\/code>\u060c \u0648 \u063a\u06cc\u0631\u0647.<\/p>\n<p>\u06cc\u06a9 \u0645\u062b\u0627\u0644 \u0639\u0627\u0644\u06cc \u0627\u0632 \u067e\u0633\u0648\u0646\u062f \u0645\u062f\u0644 \u062f\u0631 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.npmjs.com\/package\/bookshelf-modelbase\">\u0642\u0641\u0633\u0647 \u06a9\u062a\u0627\u0628-\u0645\u062f\u0644 \u067e\u0627\u06cc\u0647<\/a> \u067e\u0631\u0648\u0698\u0647\u060c \u06a9\u0647 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u06af\u0645\u0634\u062f\u0647 \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u0627\u0646\u062a\u0638\u0627\u0631 \u062f\u0627\u0631\u06cc\u062f \u062f\u0631 \u0627\u06a9\u062b\u0631 ORM\u0647\u0627 \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f \u0628\u0627\u0634\u0646\u062f.<\/p>\n<p>\u0627\u06af\u0631 \u0628\u062e\u0648\u0627\u0647\u06cc\u062f \u0645\u062f\u0644 \u067e\u0627\u06cc\u0647 \u0633\u0627\u062f\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0633\u0627\u0632\u06cc\u062f\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0628\u0627\u0634\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> model = bookshelf.Model.extend({\n    <span class=\"hljs-attr\">hasTimestamps<\/span>: (<span class=\"hljs-string\">'created_at'<\/span>, <span class=\"hljs-string\">'updated_at'<\/span>),\n}, {\n    <span class=\"hljs-attr\">findAll<\/span>: <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">filter, options<\/span>) <\/span>{\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.forge().where(filter).fetchAll(options);\n    },\n\n    <span class=\"hljs-attr\">findOne<\/span>: <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">query, options<\/span>) <\/span>{\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.forge(query).fetch(options);\n    },\n\n    <span class=\"hljs-attr\">create<\/span>: <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">data, options<\/span>) <\/span>{\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.forge(data).save(<span class=\"hljs-literal\">null<\/span>, options);\n    },\n});\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0647\u0645\u0647 \u0645\u062f\u0644 \u0647\u0627\u06cc \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0632 \u0627\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627\u06cc \u0645\u0641\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f.<\/p>\n<h2 id=\"savingandupdatingmodels\"><span class=\"ez-toc-section\" id=\"%d8%b0%d8%ae%db%8c%d8%b1%d9%87_%d9%88_%d8%a8%d9%87_%d8%b1%d9%88%d8%b2_%d8%b1%d8%b3%d8%a7%d9%86%db%8c_%d9%85%d8%af%d9%84_%d9%87%d8%a7\"><\/span>\u0630\u062e\u06cc\u0631\u0647 \u0648 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u0645\u062f\u0644 \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0633\u062a\u0647 \u0628\u0647 \u0627\u06cc\u0646\u060c \u0686\u0646\u062f \u0631\u0648\u0634 \u0645\u062e\u062a\u0644\u0641 \u0628\u0631\u0627\u06cc \u0630\u062e\u06cc\u0631\u0647 \u0645\u062f\u0644 \u0647\u0627 \u062f\u0631 Bookshelf \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u0631\u0648\u06cc \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0648 \u0642\u0627\u0644\u0628 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0634\u0645\u0627<\/p>\n<p>\u0627\u0648\u0644\u06cc\u0646 \u0648 \u0648\u0627\u0636\u062d \u062a\u0631\u06cc\u0646 \u0631\u0627\u0647 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0641\u0642\u0637 \u062a\u0645\u0627\u0633 \u0628\u06af\u06cc\u0631\u06cc\u062f <code>.save()<\/code> \u0631\u0648\u06cc  \u06cc\u06a9 \u0646\u0645\u0648\u0646\u0647 \u0645\u062f\u0644<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> user = <span class=\"hljs-keyword\">new<\/span> User();\nuser.set(<span class=\"hljs-string\">'name'<\/span>, <span class=\"hljs-string\">'Joe'<\/span>);\nuser.set(<span class=\"hljs-string\">'email'<\/span>, <span class=\"hljs-string\">'(email\u00a0protected)'<\/span>);\nuser.set(<span class=\"hljs-string\">'age'<\/span>, <span class=\"hljs-number\">28<\/span>);\n\nuser.save().then(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">u<\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'User saved:'<\/span>, u.get(<span class=\"hljs-string\">'name'<\/span>));\n});\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0628\u0631\u0627\u06cc \u0645\u062f\u0644\u06cc \u06a9\u0647 \u062e\u0648\u062f\u062a\u0627\u0646 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u062f (\u0645\u0627\u0646\u0646\u062f \u0645\u062f\u0644 \u0628\u0627\u0644\u0627)\u060c \u06cc\u0627 \u0628\u0627 \u0646\u0645\u0648\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062f\u0644\u06cc \u06a9\u0647 \u0627\u0632 \u06cc\u06a9 \u062a\u0645\u0627\u0633 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u06cc \u0628\u0647 \u0634\u0645\u0627 \u0628\u0627\u0632\u06af\u0631\u062f\u0627\u0646\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f\u060c \u06a9\u0627\u0631 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<p>\u06af\u0632\u06cc\u0646\u0647 \u062f\u06cc\u06af\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>.forge()<\/code> \u0631\u0648\u0634 \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u06a9\u0646\u06cc\u062f.  &#8220;Forge&#8221; \u062f\u0631 \u0648\u0627\u0642\u0639 \u0641\u0642\u0637 \u06cc\u06a9 \u0631\u0627\u0647 \u06a9\u0648\u062a\u0627\u0647 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0645\u062f\u0644 \u062c\u062f\u06cc\u062f \u0627\u0633\u062a (\u0645\u0627\u0646\u0646\u062f <code>new User()<\/code>).  \u0627\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u062f\u0644 \u0642\u0628\u0644 \u0627\u0632 \u0634\u0631\u0648\u0639 \u0631\u0634\u062a\u0647 query\/save \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u062e\u0637 \u0627\u0636\u0627\u0641\u06cc \u0646\u062f\u0627\u0631\u06cc\u062f.<\/p>\n<p>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0646 <code>.forge()<\/code>\u060c \u06a9\u062f \u0628\u0627\u0644\u0627 \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> data = {\n    <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'Joe'<\/span>,\n    <span class=\"hljs-attr\">email<\/span>: <span class=\"hljs-string\">'(email\u00a0protected)'<\/span>,\n    <span class=\"hljs-attr\">age<\/span>: <span class=\"hljs-number\">28<\/span>\n}\n\nUser.forge(data).save().then(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">u<\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'User saved:'<\/span>, u.get(<span class=\"hljs-string\">'name'<\/span>));\n});\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0648\u0627\u0642\u0639\u0627\u064b \u0647\u06cc\u0686 \u062e\u0637 \u06a9\u062f\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0634\u0645\u0627 \u0630\u062e\u06cc\u0631\u0647 \u0646\u0645\u06cc \u06a9\u0646\u062f\u060c \u0627\u0645\u0627 \u0627\u06af\u0631 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0631\u0627\u062d\u062a \u0628\u0627\u0634\u062f <code>data<\/code> \u062f\u0631 \u0648\u0627\u0642\u0639 JSON \u0648\u0631\u0648\u062f\u06cc \u06cc\u0627 \u0686\u06cc\u0632\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 \u0622\u0646 \u0627\u0633\u062a.<\/p>\n<h2 id=\"loadingmodels\"><span class=\"ez-toc-section\" id=\"%d8%af%d8%b1_%d8%ad%d8%a7%d9%84_%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d9%85%d8%af%d9%84_%d9%87%d8%a7\"><\/span>\u062f\u0631 \u062d\u0627\u0644 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u062f\u0644 \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0645\u0646 \u062f\u0631 \u0645\u0648\u0631\u062f \u0631\u0648\u0634 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0645\u062f\u0644 \u0647\u0627 \u0627\u0632 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0628\u0627 Bookshelf \u0635\u062d\u0628\u062a \u062e\u0648\u0627\u0647\u0645 \u06a9\u0631\u062f.<\/p>\n<p>\u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 <code>.forge()<\/code> \u0648\u0627\u0642\u0639\u0627\u064b \u062f\u0631 \u0630\u062e\u06cc\u0631\u0647 \u0627\u0633\u0646\u0627\u062f \u0628\u0647 \u0645\u0627 \u06a9\u0645\u06a9 \u0686\u0646\u062f\u0627\u0646\u06cc \u0646\u06a9\u0631\u062f\u060c \u0645\u0637\u0645\u0626\u0646\u0627\u064b \u062f\u0631 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0622\u0646\u0647\u0627 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0646\u0645\u0648\u0646\u0647 \u0645\u062f\u0644 \u062e\u0627\u0644\u06cc \u0641\u0642\u0637 \u0628\u0631\u0627\u06cc \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u06a9\u0645\u06cc \u0646\u0627\u062e\u0648\u0634\u0627\u06cc\u0646\u062f \u0627\u0633\u062a\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0627\u0632 <code>.forge()<\/code> \u0628\u062c\u0627\u06cc.<\/p>\n<p>\u0633\u0627\u062f\u0647 \u062a\u0631\u06cc\u0646 \u0645\u062b\u0627\u0644 \u0628\u0631\u0627\u06cc \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0641\u0642\u0637 \u06cc\u06a9 \u0645\u062f\u0644 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0648\u0627\u06a9\u0634\u06cc \u06a9\u0646\u06cc\u062f <code>.fetch()<\/code>:<\/p>\n<pre><code class=\"hljs\">User.forge({<span class=\"hljs-attr\">email<\/span>: <span class=\"hljs-string\">'(email\u00a0protected)'<\/span>}).fetch().then(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">user<\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'Got user:'<\/span>, user.get(<span class=\"hljs-string\">'name'<\/span>));\n});\n<\/code><\/pre>\n<p>\u062a\u0646\u0647\u0627 \u06a9\u0627\u0631\u06cc \u06a9\u0647 \u0645\u0627 \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u06cc\u0645 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u0645\u062f\u0644 \u0648\u0627\u062d\u062f \u0631\u0627 \u06a9\u0647 \u0628\u0627 \u067e\u0631\u0633 \u0648 \u062c\u0648\u06cc \u062f\u0627\u062f\u0647 \u0634\u062f\u0647 \u0645\u0637\u0627\u0628\u0642\u062a \u062f\u0627\u0631\u062f\u060c \u0628\u06af\u06cc\u0631\u06cc\u0645.  \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062a\u0635\u0648\u0631 \u06a9\u0646\u06cc\u062f\u060c \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0647 \u0647\u0645\u0627\u0646 \u0627\u0646\u062f\u0627\u0632\u0647 \u06a9\u0647 \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u067e\u06cc\u0686\u06cc\u062f\u0647 \u0628\u0627\u0634\u062f (\u0645\u0627\u0646\u0646\u062f \u0645\u062d\u062f\u0648\u062f\u06cc\u062a \u0631\u0648\u06cc <code>name<\/code>  \u0648 <code>age<\/code> \u0633\u062a\u0648\u0646 \u0647\u0627 \u0646\u06cc\u0632).<\/p>\n<p>\u062f\u0631\u0633\u062a \u0645\u0627\u0646\u0646\u062f SQL \u0633\u0627\u062f\u0647 \u0642\u062f\u06cc\u0645\u06cc\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0648 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0628\u0627\u0632\u06af\u0631\u062f\u0627\u0646\u062f\u0647 \u0634\u062f\u0647 \u0631\u0627 \u062a\u0627 \u062d\u062f \u0632\u06cc\u0627\u062f\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u06a9\u0646\u06cc\u062f.  \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0627\u06cc\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0641\u0642\u0637 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645 \u0628\u0647 \u0645\u0627 \u0645\u06cc \u062f\u0647\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> email = <span class=\"hljs-string\">'...'<\/span>;\n<span class=\"hljs-keyword\">var<\/span> plainTextPassword = <span class=\"hljs-string\">'...'<\/span>;\n\nUser.forge({<span class=\"hljs-attr\">email<\/span>: email}).fetch({<span class=\"hljs-attr\">columns<\/span>: (<span class=\"hljs-string\">'email'<\/span>, <span class=\"hljs-string\">'password_hash'<\/span>, <span class=\"hljs-string\">'salt'<\/span>)})\n.then(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">user<\/span>) <\/span>{\n    <span class=\"hljs-keyword\">if<\/span> (user.verifyPassword(plainTextPassword)) {\n        <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'User logged in!'<\/span>);\n    } <span class=\"hljs-keyword\">else<\/span> {\n        <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'Authentication failed...'<\/span>);\n    }\n});\n<\/code><\/pre>\n<p>\u0628\u0627 \u062f\u0631 \u0646\u0638\u0631 \u06af\u0631\u0641\u062a\u0646 \u0627\u06cc\u0646 \u062d\u062a\u06cc \u0628\u06cc\u0634\u062a\u0631\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <code>withRelations<\/code> \u06af\u0632\u06cc\u0646\u0647 \u0627\u06cc \u0628\u0631\u0627\u06cc \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062e\u0648\u062f\u06a9\u0627\u0631 \u0645\u062f\u0644 \u0647\u0627\u06cc \u0645\u0631\u062a\u0628\u0637 \u06a9\u0647 \u062f\u0631 \u0628\u062e\u0634 \u0628\u0639\u062f\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u06cc\u062f.<\/p>\n<h2 id=\"modelrelations\"><span class=\"ez-toc-section\" id=\"%d8%b1%d9%88%d8%a7%d8%a8%d8%b7_%d9%85%d8%af%d9%84\"><\/span>\u0631\u0648\u0627\u0628\u0637 \u0645\u062f\u0644<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u060c \u0645\u062f\u0644\u200c\u0647\u0627\u06cc \u0634\u0645\u0627 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0627\u0631\u062c\u0627\u0639 \u0628\u0647 \u0645\u062f\u0644\u200c\u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u062f\u0627\u0631\u0646\u062f \u06a9\u0647 \u062f\u0631 SQL \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc \u062e\u0627\u0631\u062c\u06cc \u0628\u0647 \u062f\u0633\u062a \u0645\u06cc\u200c\u0622\u06cc\u062f.  \u06cc\u06a9 \u0646\u0633\u062e\u0647 \u0633\u0627\u062f\u0647 \u0627\u0632 \u0627\u06cc\u0646 \u062f\u0631 Bookshelf \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0631\u0648\u0627\u0628\u0637 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u062f\u0631 \u0645\u062f\u0644 \u062e\u0648\u062f\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 Bookshelf \u0628\u06af\u0648\u06cc\u06cc\u062f \u06a9\u0647 \u0645\u062f\u0644\u200c\u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u062f\u0642\u06cc\u0642\u0627\u064b \u0686\u06af\u0648\u0646\u0647 \u0628\u0627 \u06cc\u06a9\u062f\u06cc\u06af\u0631 \u0645\u0631\u062a\u0628\u0637 \u0647\u0633\u062a\u0646\u062f.  \u0627\u06cc\u0646 \u0627\u0645\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>belongsTo()<\/code>\u060c <code>hasMany()<\/code>\u060c \u0648 <code>hasOne()<\/code> (\u062f\u0631 \u0645\u06cc\u0627\u0646 \u062f\u06cc\u06af\u0631\u0627\u0646) \u0631\u0648\u0634 \u0647\u0627.<\/p>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0641\u0631\u0636 \u06a9\u0646\u06cc\u062f \u0634\u0645\u0627 \u062f\u0648 \u0645\u062f\u0644 \u062f\u0627\u0631\u06cc\u062f\u060c User \u0648 Address.  \u06a9\u0627\u0631\u0628\u0631 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0686\u0646\u062f\u06cc\u0646 \u0622\u062f\u0631\u0633 (\u06cc\u06a9\u06cc \u0628\u0631\u0627\u06cc \u062d\u0645\u0644 \u0648 \u0646\u0642\u0644\u060c \u06cc\u06a9\u06cc \u0628\u0631\u0627\u06cc \u0635\u0648\u0631\u062a\u062d\u0633\u0627\u0628 \u0648 \u063a\u06cc\u0631\u0647) \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0627\u0645\u0627 \u06cc\u06a9 \u0622\u062f\u0631\u0633 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u062a\u0646\u0647\u0627 \u0628\u0647 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u062a\u0639\u0644\u0642 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f.  \u0628\u0627 \u062a\u0648\u062c\u0647 \u0628\u0647 \u0627\u06cc\u0646\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0645\u062f\u0644 \u0647\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> User = bookshelf.Model.extend({\n    <span class=\"hljs-attr\">tableName<\/span>: <span class=\"hljs-string\">'users'<\/span>,\n    \n    <span class=\"hljs-attr\">addresses<\/span>: <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.hasMany(<span class=\"hljs-string\">'Address'<\/span>, <span class=\"hljs-string\">'user_id'<\/span>);\n    },\n});\n\n<span class=\"hljs-keyword\">var<\/span> Address = bookshelf.Model.extend({\n    <span class=\"hljs-attr\">tableName<\/span>: <span class=\"hljs-string\">'addresses'<\/span>,\n    \n    <span class=\"hljs-attr\">user<\/span>: <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.belongsTo(<span class=\"hljs-string\">'User'<\/span>, <span class=\"hljs-string\">'user_id'<\/span>);\n    },\n});\n<\/code><\/pre>\n<p><em>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0645\u0646 \u0627\u0632 <a rel=\"nofollow noopener\" href=\"https:\/\/github.com\/tgriesser\/bookshelf\/wiki\/Plugin:-Model-Registry\" target=\"_blank\">\u0627\u0641\u0632\u0648\u0646\u0647 \u0631\u062c\u06cc\u0633\u062a\u0631\u06cc<\/a> \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627\u060c \u06a9\u0647 \u0628\u0647 \u0645\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0628\u0627 \u06cc\u06a9 \u0631\u0634\u062a\u0647 \u0628\u0647 \u0645\u062f\u0644 Address \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u0645.<\/em><\/p>\n<p>\u0627\u06cc\u0646 <code>hasMany()<\/code> \u0648 <code>belongsTo()<\/code> Method \u0628\u0647 Bookshelf \u0645\u06cc \u06af\u0648\u06cc\u062f \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0647\u0631 \u0645\u062f\u0644 \u0628\u0627 \u06cc\u06a9\u062f\u06cc\u06af\u0631 \u0645\u0631\u062a\u0628\u0637 \u0627\u0633\u062a.  \u06a9\u0627\u0631\u0628\u0631 \u0622\u062f\u0631\u0633\u200c\u0647\u0627\u06cc \u0632\u06cc\u0627\u062f\u06cc \u062f\u0627\u0631\u062f\u060c \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0622\u062f\u0631\u0633 \u0645\u062a\u0639\u0644\u0642 \u0628\u0647 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0633\u062a.  \u0622\u0631\u06af\u0648\u0645\u0627\u0646 \u062f\u0648\u0645 \u0646\u0627\u0645 \u0633\u062a\u0648\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0645\u06a9\u0627\u0646 \u06a9\u0644\u06cc\u062f \u0645\u062f\u0644 \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f.  \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f\u060c <em>\u0647\u0631 \u062f\u0648<\/em> \u0645\u062f\u0644 \u0647\u0627 \u0628\u0647 <code>user_id<\/code> \u0633\u062a\u0648\u0646 \u062f\u0631 \u062c\u062f\u0648\u0644 \u0622\u062f\u0631\u0633<\/p>\n<p>\u062d\u0627\u0644 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u06cc\u0646 \u0627\u0632 \u0627\u06cc\u0646 \u0631\u0627\u0628\u0637\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <code>withRelated<\/code> \u06af\u0632\u06cc\u0646\u0647 \u0631\u0648\u06cc <code>.fetch()<\/code>  \u0645\u0648\u0627\u062f \u0648 \u0631\u0648\u0634 \u0647\u0627.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0627\u06af\u0631 \u0645\u0646 \u0645\u06cc \u062e\u0648\u0627\u0633\u062a\u0645 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u06a9\u0646\u0645 <em>\u0648<\/em> \u0647\u0645\u0647 \u0622\u062f\u0631\u0633 \u0647\u0627\u06cc \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u062a\u0645\u0627\u0633 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0645:<\/p>\n<pre><code class=\"hljs\">User.forge({<span class=\"hljs-attr\">email<\/span>: <span class=\"hljs-string\">'(email\u00a0protected)'<\/span>}).fetch({<span class=\"hljs-attr\">withRelated<\/span>: (<span class=\"hljs-string\">'addresses'<\/span>)})\n.then(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\">user<\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'Got user:'<\/span>, user.get(<span class=\"hljs-string\">'name'<\/span>));\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'Got addresses:'<\/span>, user.related(<span class=\"hljs-string\">'addresses'<\/span>));\n});\n<\/code><\/pre>\n<p>\u0627\u06af\u0631 \u0628\u062e\u0648\u0627\u0647\u06cc\u0645 \u0645\u062f\u0644 User \u0631\u0627 \u0648\u0627\u06a9\u0634\u06cc \u06a9\u0646\u06cc\u0645 <em>\u0628\u062f\u0648\u0646<\/em> \u0631\u0627 <code>withRelated<\/code> \u0633\u067e\u0633 \u06af\u0632\u06cc\u0646\u0647 <code>user.related('addresses')<\/code> \u0641\u0642\u0637 \u06cc\u06a9 \u0634\u06cc \u0645\u062c\u0645\u0648\u0639\u0647 \u062e\u0627\u0644\u06cc \u0631\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f.<\/p>\n<p>\u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0627\u0632 \u0627\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627\u06cc \u0627\u0631\u062a\u0628\u0627\u0637\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646\u0647\u0627 \u0628\u0633\u06cc\u0627\u0631 \u0633\u0627\u062f\u0647 \u062a\u0631 \u0627\u0632 \u0627\u06cc\u062c\u0627\u062f SQL JOIN \u0647\u0627\u06cc \u062e\u0648\u062f\u062a\u0627\u0646 \u0627\u0633\u062a \ud83d\ude42<\/p>\n<h2 id=\"thegood\"><span class=\"ez-toc-section\" id=\"%d8%ae%d9%88%d8%a8\"><\/span>\u062e\u0648\u0628<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0642\u0641\u0633\u0647 \u06a9\u062a\u0627\u0628 \u06cc\u06a9\u06cc \u0627\u0632 \u0622\u0646 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u0646\u0638\u0631 \u0645\u06cc \u0631\u0633\u062f \u0633\u0639\u06cc \u0645\u06cc \u06a9\u0646\u062f \u0628\u06cc\u0634 \u0627\u0632 \u062d\u062f \u067e\u0641 \u0646\u06a9\u0646\u062f \u0648 \u0641\u0642\u0637 \u0628\u0647 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0627\u0635\u0644\u06cc \u067e\u0627\u06cc\u0628\u0646\u062f \u0628\u0627\u0634\u062f.  \u0627\u06cc\u0646 \u0639\u0627\u0644\u06cc \u0627\u0633\u062a \u0632\u06cc\u0631\u0627 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0622\u0646 <em>\u0647\u0633\u062a\u0646\u062f<\/em> \u062e\u06cc\u0644\u06cc \u062e\u0648\u0628 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u0646\u062f<\/p>\n<p>Bookshelf \u0647\u0645\u0686\u0646\u06cc\u0646 \u062f\u0627\u0631\u0627\u06cc \u06cc\u06a9 API \u0632\u06cc\u0628\u0627 \u0648 \u0642\u062f\u0631\u062a\u0645\u0646\u062f \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u0634\u0645\u0627 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0633\u0627\u0632\u06cc\u062f \u0631\u0648\u06cc \u0628\u0627\u0644\u0627\u06cc \u0622\u0646  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u062c\u0628\u0648\u0631 \u0646\u06cc\u0633\u062a\u06cc\u062f \u0628\u0627 \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u0633\u0637\u062d \u0628\u0627\u0644\u0627\u06cc\u06cc \u06a9\u0647 \u0641\u0631\u0636\u06cc\u0627\u062a \u0636\u0639\u06cc\u0641\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f \u062f\u0633\u062a \u0648 \u067e\u0646\u062c\u0647 \u0646\u0631\u0645 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0686\u06af\u0648\u0646\u0647 \u0627\u0632 \u0622\u0646\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f<\/p>\n<h2 id=\"thebad\"><span class=\"ez-toc-section\" id=\"%d8%a8%d8%af\"><\/span>\u0628\u062f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u06af\u0631\u0686\u0647 \u0645\u0646 \u0641\u06a9\u0631 \u0645\u06cc\u200c\u06a9\u0646\u0645 \u062e\u0648\u0628 \u0627\u0633\u062a \u06a9\u0647 Bookshelf\/Knex \u0628\u0631\u062e\u06cc \u0627\u0632 \u0639\u0645\u0644\u06a9\u0631\u062f\u0647\u0627\u06cc \u0633\u0637\u062d \u067e\u0627\u06cc\u06cc\u0646\u200c\u062a\u0631 \u0631\u0627 \u062f\u0631 \u0627\u062e\u062a\u06cc\u0627\u0631 \u0634\u0645\u0627 \u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u062f\u0647\u062f\u060c \u0647\u0646\u0648\u0632 \u0647\u0645 \u0641\u06a9\u0631 \u0645\u06cc\u200c\u06a9\u0646\u0645 \u062c\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u0628\u0647\u0628\u0648\u062f \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f.  \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u062a\u0645\u0627\u0645 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u062c\u062f\u0648\u0644\/\u0634\u0645\u0627 \u0628\u0647 \u0634\u0645\u0627 \u0648\u0627\u06af\u0630\u0627\u0631 \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0648 \u0631\u0627\u0647 \u0622\u0633\u0627\u0646\u06cc \u0628\u0631\u0627\u06cc \u062a\u0639\u06cc\u06cc\u0646 \u0637\u0631\u062d \u0634\u0645\u0627 (\u0645\u0627\u0646\u0646\u062f \u06cc\u06a9 \u0634\u06cc\u0621 JS \u0633\u0627\u062f\u0647) \u062f\u0631 \u0645\u062f\u0644 \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f.  \u062a\u0646\u0638\u06cc\u0645 \u062c\u062f\u0648\u0644\/\u0637\u0631\u062d\u0648\u0627\u0631\u0647 \u0628\u0627\u06cc\u062f \u062f\u0631 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0647\u0627\u06cc API \u0645\u0634\u062e\u0635 \u0634\u0648\u062f\u060c \u06a9\u0647 \u062e\u0648\u0627\u0646\u062f\u0646 \u0648 \u0627\u0634\u06a9\u0627\u0644 \u0632\u062f\u0627\u06cc\u06cc \u0622\u0646 \u0686\u0646\u062f\u0627\u0646 \u0622\u0633\u0627\u0646 \u0646\u06cc\u0633\u062a.<\/p>\n<p>\u06cc\u06a9\u06cc \u062f\u06cc\u06af\u0631 \u0627\u0632 \u0645\u0634\u06a9\u0644\u0627\u062a \u0645\u0646 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0622\u0646\u0647\u0627 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0631\u0648\u0634 \u0647\u0627\u06cc \u06a9\u0645\u06a9\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0627 \u0645\u062f\u0644 \u067e\u0627\u06cc\u0647 \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f \u0628\u0627\u0634\u062f\u060c \u06a9\u0646\u0627\u0631 \u06af\u0630\u0627\u0634\u062a\u0646\u062f <code>.create()<\/code>\u060c <code>.findOne()<\/code>\u060c <code>.upsert()<\/code>\u0648 \u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627  \u062f\u0642\u06cc\u0642\u0627\u064b \u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u0622\u0646 \u0627\u0634\u0627\u0631\u0647 \u06a9\u0631\u062f\u0645 <code>bookshelf-modelbase<\/code> \u067e\u0631\u0648\u0698\u0647 \u0631\u0627 \u0632\u0648\u062f\u062a\u0631 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f \u0632\u06cc\u0631\u0627 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0627\u06cc\u0646 \u0634\u06a9\u0627\u0641 \u0647\u0627 \u0631\u0627 \u067e\u0631 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0647 \u0637\u0648\u0631 \u06a9\u0644\u06cc\u060c \u0645\u0646 \u06a9\u0627\u0645\u0644\u0627\u064b \u0637\u0631\u0641\u062f\u0627\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Bookshelf\/Knex \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0647\u0627\u06cc SQL \u0634\u062f\u0647\u200c\u0627\u0645\u060c \u0627\u06af\u0631\u0686\u0647 \u0641\u06a9\u0631 \u0645\u06cc\u200c\u06a9\u0646\u0645 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u0634\u06a9\u0644\u0627\u062a\u06cc \u06a9\u0647 \u0628\u0647 \u0622\u0646 \u0627\u0634\u0627\u0631\u0647 \u06a9\u0631\u062f\u0645 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0631\u0627\u06cc \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646\u06cc \u0628\u0627\u0634\u062f \u06a9\u0647 \u0628\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 ORM\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u062a\u0642\u0631\u06cc\u0628\u0627\u064b \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u062f\u0647\u0646\u062f\u060c \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u0628\u0627\u0634\u062f. \u0622\u0646\u0647\u0627 \u0631\u0627 \u062e\u0627\u0631\u062c \u0627\u0632 \u062c\u0639\u0628\u0647  \u0627\u0632 \u0633\u0648\u06cc \u062f\u06cc\u06af\u0631\u060c \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u062f\u06cc\u06af\u0631\u06cc \u06a9\u0647 \u062f\u0648\u0633\u062a \u062f\u0627\u0631\u0646\u062f \u06a9\u0646\u062a\u0631\u0644 \u0632\u06cc\u0627\u062f\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f\u060c \u0627\u06cc\u0646 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0639\u0627\u0644\u06cc \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0633\u0639\u06cc \u06a9\u0631\u062f\u0645 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647 \u062a\u0627 \u062d\u062f \u0627\u0645\u06a9\u0627\u0646 \u0627\u0632 API \u0627\u0635\u0644\u06cc \u0631\u0627 \u067e\u0648\u0634\u0634 \u062f\u0647\u0645\u060c \u0647\u0646\u0648\u0632 \u0686\u0646\u062f \u0648\u06cc\u0698\u06af\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0646\u062a\u0648\u0627\u0646\u0633\u062a\u0645 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0644\u0645\u0633 \u06a9\u0646\u0645. \u0631\u0648\u06cc\u060c \u067e\u0633 \u062d\u062a\u0645\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/bookshelfjs.org\/\">\u0645\u0633\u062a\u0646\u062f\u0627\u062a \u067e\u0631\u0648\u0698\u0647<\/a> \u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631.<\/p>\n<p><em>\u0622\u06cc\u0627 \u0627\u0632 Bookshelf.js \u06cc\u0627 Knex.js \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u062f\u061f  \u0634\u0645\u0627 \u0686\u06cc \u0641\u06a9\u0631 \u0645\u06cc\u06a9\u0646\u06cc\u062f\u061f  \u062f\u0631 \u0646\u0638\u0631\u0627\u062a \u0628\u0647 \u0645\u0627 \u0627\u0637\u0644\u0627\u0639 \u062f\u0647\u06cc\u062f!<\/em><\/p>\n<\/div>\n<p>    (\u0628\u0631\u0686\u0633\u0628\u200c\u0647\u0627 \u0628\u0631\u0627\u06cc \u062a\u0631\u062c\u0645\u0647)# \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<br \/>\n<br \/><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-29 00:11:04<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;16650&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;Bookshelf.js: \u06cc\u06a9 Node.js ORMON \u06cc\u06a9\u06cc \u0627\u0632 \u0631\u0627\u06cc\u062c\u200c\u062a\u0631\u06cc\u0646 \u0645\u0646\u0627\u0628\u0639\u06cc \u06a9\u0647 \u062f\u0631 \u0632\u0628\u0627\u0646\u06cc \u0645\u0627\u0646\u0646\u062f Node.js (\u0639\u0645\u062f\u062a\u0627\u064b \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u0645\u062a\u0645\u0631\u06a9\u0632 \u0628\u0631 \u0648\u0628) \u0628\u0627 \u0622\u0646 \u062a\u0639\u0627\u0645\u0644 \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0627\u0634\u062a\u060c \u067e\u0627\u06cc\u06af\u0627\u0647\u200c\u0647\u0627\u06cc \u062f\u0627\u062f\u0647 \u0647\u0633\u062a\u0646\u062f.  \u0648 \u0628\u0627 \u062a\u0648\u062c\u0647 \u0628\u0647 \u0627\u06cc\u0646\u06a9\u0647 SQL \u0645\u062a\u062f\u0627\u0648\u0644 \u062a\u0631\u06cc\u0646 \u062f\u0631 \u0628\u06cc\u0646 \u0627\u0646\u0648\u0627\u0639 \u0645\u062e\u062a\u0644\u0641 \u0627\u0633\u062a\u060c \u0628\u0647 \u06cc\u06a9 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u062e\u0648\u0628 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f \u062a\u0627 \u0628\u0647 \u0634\u0645\u0627 \u062f\u0631 \u062a\u0639\u0627\u0645\u0644 \u0628\u0627 \u0622\u0646 \u0648 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0645\u062a\u0639\u062f\u062f \u0622\u0646 \u06a9\u0645\u06a9 \u06a9\u0646\u062f.  Bookshelf.js...&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\"> 9<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u06cc\u06a9\u06cc \u0627\u0632 \u0631\u0627\u06cc\u062c \u062a\u0631\u06cc\u0646 \u0645\u0646\u0627\u0628\u0639\u06cc \u06a9\u0647 \u062f\u0631 \u0632\u0628\u0627\u0646\u06cc \u0645\u0627\u0646\u0646\u062f Node.js (\u0639\u0645\u062f\u062a\u0627\u064b \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u0645\u062a\u0645\u0631\u06a9\u0632 \u0628\u0631 \u0648\u0628) \u0628\u0627 \u0622\u0646 \u062a\u0639\u0627\u0645\u0644 \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0627\u0634\u062a\u060c \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0647\u0633\u062a\u0646\u062f. \u0648 \u0628\u0627 \u062a\u0648\u062c\u0647 \u0628\u0647 \u0627\u06cc\u0646\u06a9\u0647 SQL \u0645\u062a\u062f\u0627\u0648\u0644 \u062a\u0631\u06cc\u0646 \u062f\u0631 \u0628\u06cc\u0646 \u0627\u0646\u0648\u0627\u0639 \u0645\u062e\u062a\u0644\u0641 \u0627\u0633\u062a\u060c \u0628\u0647 \u06cc\u06a9 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u062e\u0648\u0628 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f \u062a\u0627 \u0628\u0647 \u0634\u0645\u0627 \u062f\u0631 \u062a\u0639\u0627\u0645\u0644 \u0628\u0627 \u0622\u0646 \u0648 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0645\u062a\u0639\u062f\u062f [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":16651,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[],"class_list":["post-16650","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16650","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\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=16650"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16650\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/16651"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=16650"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=16650"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=16650"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}