{"id":713,"date":"2022-07-28T14:03:59","date_gmt":"2022-07-28T05:03:59","guid":{"rendered":"http:\/\/practical.kr\/?p=713"},"modified":"2022-07-28T14:05:07","modified_gmt":"2022-07-28T05:05:07","slug":"edgedb%ec%99%80-graphql","status":"publish","type":"post","link":"http:\/\/practical.kr\/?p=713","title":{"rendered":"EdgeDB\uc640 GraphQL"},"content":{"rendered":"\n<p>\uc804\uc5d0 GraphQL\uc744 Node.js\uae30\ubc18\uc73c\ub85c \ud14c\uc2a4\ud2b8 \ud574\ubcf4\uace0 \ube14\ub85c\uadf8\ub97c \ud55c\ubc88 \uc37c\uc5c8\ub2e4. \ub298 \uadf8\ub807\uc9c0\ub9cc \uc774\ub7f0 \ud14c\uc2a4\ud2b8\uc758 \ubaa9\uc801\uc740 \uc5b4\ub5bb\uac8c \ud558\uba74 \ucf54\ub4dc\ub97c \uc801\uac8c \uc4f0\uace0 \ubaa9\uc801\uc744 \ub2ec\uc131\ud558\ub824\ub294 \uc758\uc9c0\uc774\ub2e4. \uc88b\uac8c \ub9d0\ud558\uba74 \uc0dd\uc0b0\uc131 \ud5a5\uc0c1.<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\"><a href=\"http:\/\/practical.kr\/?p=62\" target=\"_blank\" rel=\"noreferrer noopener\">http:\/\/practical.kr\/?p=62<\/a><\/pre>\n\n\n\n<p>\uae31\ub274\uc2a4\uc5d0 \uc62c\ub77c\uc628 \ub9c1\ud06c\uc758 \uae00(EdgeDB \uad00\ub828)\uc744 \uc77d\uace0 \ub2e4\uc2dc \ud638\uae30\uc2ec\uc774 \uc0dd\uaca8\uc11c \ud55c\ubc88 \ud14c\uc2a4\ud2b8\ub97c \ud574\ubd24\ub2e4. <\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">EdgeDB 1\ub144 \uc0ac\uc6a9 \ud6c4\uae30 - \"\ub2e4\uc2dc\ub294 SQL\ub85c \ub3cc\uc544\uac00\uc9c0 \uc54a\uc744\uaebc\uc57c\"\n\n<a rel=\"noreferrer noopener\" href=\"https:\/\/news.hada.io\/topic?id=7052\" target=\"_blank\">https:\/\/news.hada.io\/topic?id=7052<\/a><\/pre>\n\n\n\n<p>EdgeDB\ub294 Postgres \uc704\uc5d0 \ub9cc\ub4e0 Graph\/Relational DB \ub77c\uace0 \ud55c\ub2e4. R-DB \uc774\uae30\ub294 \ud558\uc9c0\ub9cc SQL\uc744 \uc0ac\uc6a9\ud558\uc9c0 \uc54a\uace0  EgdeQL\ub77c\ub294 \uc0c8\ub85c \uc815\uc758\ub41c \ucffc\ub9ac\uc5b8\uc5b4(?)\ub97c \uc0ac\uc6a9\ud558\ub294\ub370 SQL\uc744 \uc548\ub2e4\uba74 \uadf8\ub9ac \uc5b4\ub835\uc9c0\ub294 \uc54a\ub2e4.<\/p>\n\n\n\n<p>\uac1c\uc778\uc801\uc73c\ub85c \ucffc\ub9ac\uc5b8\uc5b4\ub97c \ubc14\uafb8\ub294\uac74 \uc0ac\uc2e4\uc0c1 \uac70\uc758 \ubd88\uac00\ub2a5(? &#8211; \ub108\ubb34 \uc624\ub798 \uc368\uc11c) \ud558\ub2e4\uace0 \uc0dd\uac01\ud558\uace0 \uc788\uc9c0\ub9cc \uc758\uc678\ub85c GraphQL\uc744 \uc0ac\uc6a9\ud560 \uc218 \uc788\ub294\ub370 \uad00\uc2ec\uc774 \uc0dd\uacbc\ub2e4. \uc11c\ubc84 \ucf54\ub4dc \uc801\uac8c \uc4f0\uac70\ub098 \uc548\uc368\ub3c4 \ub420\uae4c? \uc774\uac74 \ub298 \uad00\uc2ec\uc0ac\ub2e4. \uadf8\ub798\ub3c4 DB \ubc14\uafb8\ub294 \uc77c\uc740 \uc26c\uc6b4\uc77c\uc774 \uc808\ub300 \uc544\ub2c8\ub2e4. \ud2b9\ud788 SQL\uc740 \ub354\ub354\uc6b1. EdgeDB\uc758 GraphQL \ubd80\ubd84\ub9cc \ud55c\ubc88 \ud14c\uc2a4\ud2b8 \ud574\ubd24\ub2e4. \ub2e4\uc74c \ud504\ub85c\uc81d\ud2b8\uc5d0\uc11c \uc368\uba39\uc744 \uc218 \uc788\uc744\uae4c \uc2f6\uc5b4\uc11c&#8230;<\/p>\n\n\n\n<p class=\"has-x-large-font-size\">\uc124\uce58<\/p>\n\n\n\n<p>\uc124\uce58\ub294 \ub9e4\uc6b0 \uc27d\ub2e4.   \ucee4\ub9e8\ub4dc \ub77c\uc778\uc5d0 \uba85\ub839\uc5b4\ub97c \uc785\ub825\ud558\uba74 \uc790\ub3d9\uc73c\ub85c \uc124\uce58\ub41c\ub2e4. \ub9c1\ud06c\ub97c \ub530\ub77c\uac00\uba74 Windows\uc6a9 \uc124\uce58 \uba85\ub839\uc5b4\ub3c4 \uc788\ub2e4.<\/p>\n\n\n\n<div class=\"wp-block-image\"><figure class=\"aligncenter size-full is-resized\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/practical.kr\/wp-content\/uploads\/2022\/07\/Monosnap-Installation-EdgeDB-2022-07-28-13-25-05.png\" alt=\"\" class=\"wp-image-716\" width=\"596\" height=\"114\"\/><\/figure><\/div>\n\n\n\n<pre class=\"wp-block-preformatted\">EdgeDB \uc124\uce58\n<a rel=\"noreferrer noopener\" href=\"https:\/\/www.edgedb.com\/install\" target=\"_blank\">https:\/\/www.edgedb.com\/install<\/a><\/pre>\n\n\n\n<p class=\"has-x-large-font-size\">\uc2a4\ud0a4\ub9c8 \ub9cc\ub4e4\uae30<\/p>\n\n\n\n<p>\uc124\uce58\uac00 \uc644\ub8cc\ub418\uace0 \ud14c\uc2a4\ud2b8\uc6a9 \uc2a4\ud0a4\ub9c8\ub97c \ub9cc\ub4e4\uc5c8\ub2e4. \uc124\uce58\ub41c \ud3f4\ub354 \uc544\ub798\uc5d0 \\dbschema \ub77c\ub294 \ud3f4\ub354\uac00 \uc788\uace0 \uac70\uae30\uc5d0 default.esdl \ud30c\uc77c\uc774 \uc0dd\uc131\ub418\uc5b4 \uc788\ub2e4. \uc774 \ud30c\uc77c\uc744 \ud14d\uc2a4\ud2b8 \ud3b8\uc9d1\uae30\ub85c \uc5f4\uace0 \uc544\ub798 \uc2a4\ud0a4\ub9c8\ub97c \uc785\ub825\ud558\uace0 \uc800\uc7a5\ud55c\ub2e4.<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">module default {\n  type Person {\n    required property first_name -> str;\n    required property last_name -> str;\n  }\n\n  type Movie {\n    required property title -> str;\n    property year -> int64;\n    link director -> Person;\n    multi link actors -> Person;\n  }\n};<\/pre>\n\n\n\n<p>  \uadf8\ub9ac\uace0 \ub9c8\uc774\uadf8\ub808\uc774\uc158 \uacfc\uc815\uc744 \uac70\uce58\uba74<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">\ub9c8\uc774\uadf8\ub808\uc774\uc158 \uc2e4\ud589\n\n&gt; edgedb migration create\n&gt; edgedb migrate<\/pre>\n\n\n\n<p>\uc2a4\ud0a4\ub9c8\uac00 \uc0dd\uc131\ub418\uace0 \uc785\ub825, \uc218\uc815, \uc0ad\uc81c \ub4f1\uc774 \uac00\ub2a5\ud558\ub2e4. \ud14c\uc2a4\ud2b8\ub97c \uc704\ud574 \uba87\uac1c\uc758 \ub370\uc774\ud130\ub97c \uc0bd\uc785\ud588\ub2e4.<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\"><a href=\"https:\/\/www.edgedb.com\/docs\/guides\/quickstart#insert-data\" target=\"_blank\" rel=\"noreferrer noopener\">https:\/\/www.edgedb.com\/docs\/guides\/quickstart#insert-data<\/a><\/pre>\n\n\n\n<p class=\"has-x-large-font-size\">GraphQL \uc2e4\ud589<\/p>\n\n\n\n<p>\ud14c\uc2a4\ud2b8\uc758 \ubaa9\uc801\uc774 GraphQL\uc744 \ud1b5\ud55c \ub370\uc774\ud130 \ucffc\ub9ac\uc600\uc73c\ub2c8 GraphQL \uae30\ub2a5\uc744 Enable \uc0c1\ud0dc\ub85c \ubc14\uafb8\uc5b4\uc57c \ud55c\ub2e4. \ubc29\ubc95\uc740 \uc704\uc758 default.esd \ud30c\uc77c\uc758 \uccab\uc904\uc5d0 \uc544\ub798 \uba85\ub839\uc5b4\ub97c \ucd94\uac00 \ud574\uc8fc\uace0 \ub9c8\uc774\uadf8\ub808\uc774\uc158 \uba85\ub839\uc744 \ud55c\ubc88 \ub354 \uc2e4\ud589\ud558\ub294 \uac83\uc73c\ub85c \uc644\ub8cc\ub41c\ub2e4.<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">using extension graphql;<\/pre>\n\n\n\n<p>\uc2e4\ud589\ud558\uace0 \ub098\uc11c edgedb instance list \ucee4\ub9e8\ub4dc\ub97c \uc2e4\ud589\ud558\uba74 Name, Port, Status\ub4f1\uc744 \ud655\uc778 \ud560 \uc218 \uc788\ub2e4.<\/p>\n\n\n\n<div class=\"wp-block-image\"><figure class=\"aligncenter size-full is-resized\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/practical.kr\/wp-content\/uploads\/2022\/07\/Monosnap-edgedb-2022-07-28-12-20-22-1.png\" alt=\"\" class=\"wp-image-719\" width=\"632\" height=\"161\"\/><\/figure><\/div>\n\n\n\n<p>\uadf8\ub9ac\uace0 PostMan \uac19\uc740 API Call \ub3c4\uad6c\ub97c \uc774\uc6a9\ud574\uc11c http get\uc744 \ud1b5\ud574\uc11c \uc544\ub798\uc640 \uac19\uc774 Json\ub370\uc774\ud130\ub97c \uc5bb\uc744 \uc218 \uc788\uc5c8\ub2e4.<\/p>\n\n\n\n<div class=\"wp-block-image\"><figure class=\"aligncenter size-full is-resized\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/practical.kr\/wp-content\/uploads\/2022\/07\/Monosnap-Postman-2022-07-28-11-25-54.png\" alt=\"\" class=\"wp-image-720\" width=\"626\" height=\"540\"\/><figcaption>GraphQL \ud638\ucd9c\uacb0\uacfc<\/figcaption><\/figure><\/div>\n\n\n\n<p class=\"has-x-large-font-size\">\uacb0\ub860<\/p>\n\n\n\n<p>GraphQL\uc740 \ub9c8\uce58 \uacfc\uac70\uc5d0 C\/S \ud504\ub85c\uadf8\ub7a8\uc744 \uc5f0\uc0c1 \uc2dc\ud0a4\uc9c0\ub9cc SQL\uc744 \uc0ac\uc6a9\ud558\uc9c0 \uc54a\ub294\ub2e4\ub294 \uc810\uc5d0\uc11c \ubcf4\uc548\uc0c1\uc758 \ud5db\uc810\uc744 \ud574\uacb0\ud55c\ub4ef \ubcf4\uc778\ub2e4. \uadf8\ub7ec\uba74\uc11c\ub3c4 REST \uc11c\ubc84 \ucf54\ub4dc\ub97c \uc904\uc774\uace0 \uc0dd\uc0b0\uc131\uc744 \ub192\uc778\ub2e4\ub294 \uc810\uc5d0\uc11c \ub9e4\ub825\uc801\uc73c\ub85c \ubcf4\uc778\ub2e4. EdgeDB\ub294 SQL\uc744 \ubc84\ub9ac\uba74\uc11c \ub610\ub2e4\ub978 \ubc29\ubc95\uc744 \ubcf4\uc5ec\uc900\uac83 \uac19\uc544\uc11c \uae30\ub300\uac00 \ub41c\ub2e4.<\/p>\n\n\n\n<p>\ub2e4\uc74c \ud504\ub85c\uc81d\ud2b8\uc5d0 \ud55c\ubc88 \uc368\ubcfc\uae4c?  2020.07.28 \ubc15\ubcd1\uc77c<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\uc804\uc5d0 GraphQL\uc744 Node.js\uae30\ubc18\uc73c\ub85c \ud14c\uc2a4\ud2b8 \ud574\ubcf4\uace0 \ube14\ub85c\uadf8\ub97c \ud55c\ubc88 \uc37c\uc5c8\ub2e4. \ub298 \uadf8\ub807\uc9c0\ub9cc \uc774\ub7f0 \ud14c\uc2a4\ud2b8\uc758 \ubaa9\uc801\uc740 \uc5b4\ub5bb\uac8c \ud558\uba74 \ucf54\ub4dc\ub97c \uc801\uac8c \uc4f0\uace0 \ubaa9\uc801\uc744 \ub2ec\uc131\ud558\ub824\ub294 \uc758\uc9c0\uc774\ub2e4. \uc88b\uac8c \ub9d0\ud558\uba74 \uc0dd\uc0b0\uc131 \ud5a5\uc0c1. http:\/\/practical.kr\/?p=62 \uae31\ub274\uc2a4\uc5d0 \uc62c\ub77c\uc628 \ub9c1\ud06c\uc758 \uae00(EdgeDB \uad00\ub828)\uc744 \uc77d\uace0 \ub2e4\uc2dc \ud638\uae30\uc2ec\uc774 \uc0dd\uaca8\uc11c \ud55c\ubc88 \ud14c\uc2a4\ud2b8\ub97c \ud574\ubd24\ub2e4. EdgeDB 1\ub144 \uc0ac\uc6a9 \ud6c4\uae30 &#8211; &#8220;\ub2e4\uc2dc\ub294 SQL\ub85c \ub3cc\uc544\uac00\uc9c0 \uc54a\uc744\uaebc\uc57c&#8221; https:\/\/news.hada.io\/topic?id=7052 EdgeDB\ub294 Postgres \uc704\uc5d0 \ub9cc\ub4e0 Graph\/Relational DB \ub77c\uace0<\/p>\n<div class=\"more-link\">\n\t\t\t\t <a href=\"http:\/\/practical.kr\/?p=713\" class=\"link-btn theme-btn\"><span>Read More <\/span> <i class=\"fa fa-caret-right\"><\/i><\/a>\n\t\t\t<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[17],"tags":[89,90,88],"class_list":["post-713","post","type-post","status-publish","format-standard","hentry","category-graphql","tag-edgedb","tag-graphql","tag-sql"],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"http:\/\/practical.kr\/index.php?rest_route=\/wp\/v2\/posts\/713","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/practical.kr\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/practical.kr\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/practical.kr\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/practical.kr\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=713"}],"version-history":[{"count":8,"href":"http:\/\/practical.kr\/index.php?rest_route=\/wp\/v2\/posts\/713\/revisions"}],"predecessor-version":[{"id":725,"href":"http:\/\/practical.kr\/index.php?rest_route=\/wp\/v2\/posts\/713\/revisions\/725"}],"wp:attachment":[{"href":"http:\/\/practical.kr\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=713"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/practical.kr\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=713"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/practical.kr\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=713"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}