{"id":116,"date":"2024-09-09T16:48:47","date_gmt":"2024-09-09T07:48:47","guid":{"rendered":"https:\/\/dexall.co.jp\/articles\/?p=116"},"modified":"2025-03-24T08:55:04","modified_gmt":"2025-03-23T23:55:04","slug":"ruby-on-rails%e3%81%a7graphql%e3%82%92%e6%b4%bb%e7%94%a8%e3%81%99%e3%82%8b%e6%96%b9%e6%b3%95%ef%bc%9a%e5%ae%9f%e8%b7%b5%e7%9a%84%e3%82%ac%e3%82%a4%e3%83%89%e3%81%a8%e5%a4%a7%e8%a6%8f%e6%a8%a1%e3%83%97","status":"publish","type":"post","link":"https:\/\/dexall.co.jp\/articles\/?p=116","title":{"rendered":"Ruby on Rails\u3067GraphQL\u3092\u6d3b\u7528\u3059\u308b\u65b9\u6cd5\uff1a\u5b9f\u8df5\u7684\u30ac\u30a4\u30c9\u3068\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306e\u904b\u7528\u306e\u30b3\u30c4"},"content":{"rendered":"\n<p>Ruby on Rails\u3068GraphQL\u306e\u7d44\u307f\u5408\u308f\u305b\u306f\u3001\u73fe\u4ee3\u306eWeb\u958b\u767a\u306b\u304a\u3051\u308b\u5f37\u529b\u306a\u30bd\u30ea\u30e5\u30fc\u30b7\u30e7\u30f3\u3068\u3057\u3066\u6ce8\u76ee\u3092\u96c6\u3081\u3066\u3044\u307e\u3059\u3002<br>\u3053\u306e\u8a18\u4e8b\u3067\u306f\u3001GraphQL\u3092Ruby on Rails\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u7d71\u5408\u3059\u308b\u65b9\u6cd5\u304b\u3089\u3001\u5927\u898f\u6a21\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3067\u306e\u6d3b\u7528\u4e8b\u4f8b\u3001\u305d\u3057\u3066\u5c06\u6765\u306e\u5c55\u671b\u307e\u3067\u3001\u5305\u62ec\u7684\u306b\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">\u3053\u306e\u8a18\u4e8b\u3092\u901a\u3057\u3066\u7406\u89e3\u3067\u304d\u308b8\u3064\u306e\u3053\u3068<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ul class=\"wp-block-list\">\n<li>GraphQL\u306e\u57fa\u672c\u6982\u5ff5\u3068Ruby on Rails\u3067\u306e\u5b9f\u88c5\u65b9\u6cd5<\/li>\n\n\n\n<li>Ruby on Rails\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306eGraphQL\u74b0\u5883\u69cb\u7bc9\u30b9\u30c6\u30c3\u30d7<\/li>\n\n\n\n<li>GraphQL\u3092\u4f7f\u7528\u3057\u305f\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af<\/li>\n\n\n\n<li>GraphQL\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u8a8d\u8a3c\u30fb\u8a8d\u53ef\u306e\u5b9f\u88c5<\/li>\n\n\n\n<li>\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306eGraphQL\u6d3b\u7528\u4e8b\u4f8b\u3068 best practices<\/li>\n\n\n\n<li>REST\u304b\u3089GraphQL\u3078\u306e\u79fb\u884c\u6226\u7565<\/li>\n\n\n\n<li>GraphQL\u3092\u4f7f\u7528\u3057\u305fRuby on Rails\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30c7\u30d7\u30ed\u30a4\u3068\u904b\u7528\u65b9\u6cd5<\/li>\n\n\n\n<li>Ruby on Rails\u3068GraphQL\u306e\u5c06\u6765\u306e\u5c55\u671b\u3068\u5b66\u7fd2\u30ea\u30bd\u30fc\u30b9<\/li>\n<\/ul>\n<\/div><\/div>\n\n\n\n<div class=\"toc\"><br \/>\n<b>Warning<\/b>:  Undefined array key \"is_admin\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>116<\/b><br \/>\n<br \/>\n<b>Warning<\/b>:  Undefined array key \"is_category_top\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>121<\/b><br \/>\n<br \/>\n<b>Warning<\/b>:  Undefined array key \"is_top\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>128<\/b><br \/>\n    <div id=\"toc_container\" class=\"sgb-toc--bullets js-smooth-scroll\" data-dialog-title=\"\u76ee\u6b21\">\n      <p class=\"toc_title\">\u76ee\u6b21 <\/p>\n      <ul class=\"toc_list\">  <li class=\"first\">    <a href=\"#i-0\">\u306f\u3058\u3081\u306b\uff1aRuby on Rails\u3068GraphQL\u306e\u76f8\u6027\u306e\u826f\u3055<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-1\">\u306a\u305cRuby on Rails\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067GraphQL\u3092\u9078\u3076\u3079\u304d\u304b<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-2\">GraphQL\u304c\u3082\u305f\u3089\u3059\u958b\u767a\u52b9\u7387\u3068\u67d4\u8edf\u6027\u306e\u5411\u4e0a<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-3\">GraphQL\u306e\u57fa\u672c\u6982\u5ff5\u3068Ruby on Rails\u3067\u306e\u5b9f\u88c5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-4\">GraphQL\u30b9\u30ad\u30fc\u30de\u306e\u5b9a\u7fa9\u65b9\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-5\">\u30af\u30a8\u30ea\u3068\u30df\u30e5\u30fc\u30c6\u30fc\u30b7\u30e7\u30f3\u306e\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-6\">Resolver\u306e\u52b9\u7387\u7684\u306a\u66f8\u304d\u65b9<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-7\">Ruby on Rails\u3067\u306eGraphQL\u74b0\u5883\u69cb\u7bc9\u30b9\u30c6\u30c3\u30d7<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-8\">\u5fc5\u8981\u306aGem\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3068\u8a2d\u5b9a<\/a>      <\/li>      <li>        <a href=\"#i-9\">GraphQL\u578b\u306e\u5b9a\u7fa9\u3068\u30e2\u30c7\u30eb\u3068\u306e\u9023\u643a<\/a>      <\/li>      <li>        <a href=\"#i-10\">GraphiQL\u3092\u4f7f\u7528\u3057\u305fAPI\u30c6\u30b9\u30c8\u74b0\u5883\u306e\u6e96\u5099<\/a>      <\/li>      <li>        <a href=\"#i-11\">\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-17\">\u767a\u5c55\u7684\u306a\u8a2d\u5b9a<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-21\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-22\">N+1\u554f\u984c\u306e\u89e3\u6c7a\u7b56\u3068\u5b9f\u88c5\u4f8b<\/a>      <\/li>      <li>        <a href=\"#i-25\">\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u6d3b\u7528\u3057\u305f\u30af\u30a8\u30ea\u306e\u52b9\u7387\u5316<\/a>      <\/li>      <li>        <a href=\"#i-26\">\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u3068\u305d\u306e\u5b9f\u88c5\u65b9\u6cd5<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-30\">\u307e\u3068\u3081<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-31\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u8a8d\u8a3c\u30fb\u8a8d\u53ef\u306e\u5b9f\u88c5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-32\">GraphQL\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u306e\u4fdd\u8b77\u65b9\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-37\">\u30af\u30a8\u30ea\u306e\u8907\u96d1\u3055\u5236\u9650\u3068\u30ec\u30fc\u30c8\u5236\u9650\u306e\u8a2d\u5b9a<\/a>      <\/li>      <li>        <a href=\"#i-40\">\u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u3068\u30a2\u30af\u30bb\u30b9\u5236\u5fa1\u306e\u5b9f\u88c5\u4f8b<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-49\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-54\">\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306eGraphQL\u6d3b\u7528\u4e8b\u4f8b<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-55\">\u30de\u30a4\u30af\u30ed\u30b5\u30fc\u30d3\u30b9\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u3068GraphQL\u306e\u7d71\u5408<\/a>      <\/li>      <li>        <a href=\"#i-57\">\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u958b\u767a\u8005\u3068\u306e\u5354\u696d\u306b\u3088\u308bAPI\u8a2d\u8a08\u306e\u6700\u9069\u5316<\/a>      <\/li>      <li>        <a href=\"#i-60\">GraphQL\u30b9\u30ad\u30fc\u30de\u8a2d\u8a08\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3068\u9032\u5316\u306e\u7ba1\u7406<\/a>      <\/li>      <li>        <a href=\"#i-71\">\u5b9f\u969b\u306e\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306e\u6d3b\u7528\u4e8b\u4f8b<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-72\">\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306eGraphQL\u6d3b\u7528\u306b\u304a\u3051\u308b\u8ab2\u984c\u3068\u89e3\u6c7a\u7b56<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-73\">REST\u304b\u3089GraphQL\u3078\u306e\u79fb\u884c\u6226\u7565<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-74\">\u6bb5\u968e\u7684\u306a\u79fb\u884c\u30d7\u30ed\u30bb\u30b9\u306e\u8a2d\u8a08\u3068\u5b9f\u88c5<\/a>      <\/li>      <li>        <a href=\"#i-80\">\u65e2\u5b58\u306eREST\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3068GraphQL\u306e\u5171\u5b58\u30c6\u30af\u30cb\u30c3\u30af<\/a>      <\/li>      <li>        <a href=\"#i-84\">\u79fb\u884c\u5f8c\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6539\u5584\u3068\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u65b9\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-88\">\u79fb\u884c\u4e8b\u4f8b\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>      <\/li>      <li>        <a href=\"#i-89\">\u672c\u756a\u74b0\u5883\u3067\u306eGraphQL\u306e\u6700\u9069\u5316\u8a2d\u5b9a<\/a>      <\/li>      <li>        <a href=\"#i-93\">\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u30c4\u30fc\u30eb\u306e\u5c0e\u5165\u3068\u7570\u5e38\u691c\u77e5\u306e\u4ed5\u7d44\u307f<\/a>      <\/li>      <li>        <a href=\"#i-98\">\u7d99\u7d9a\u7684\u306a\u30b9\u30ad\u30fc\u30de\u6539\u5584\u3068\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u6226\u7565<\/a>      <\/li>      <li>        <a href=\"#i-102\">\u30c7\u30d7\u30ed\u30a4\u3068\u904b\u7528\u306e\u6210\u529f\u4e8b\u4f8b<\/a>      <\/li>      <li>        <a href=\"#i-103\">\u30c7\u30d7\u30ed\u30a4\u3068\u904b\u7528\u306b\u304a\u3051\u308b\u4e00\u822c\u7684\u306a\u8ab2\u984c\u3068\u89e3\u6c7a\u7b56<\/a>      <\/li>      <li>        <a href=\"#i-108\">\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3068Tips<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-114\">\u7d50\u8ad6<\/a>      <\/li>    <\/ul>  <\/li>  <li class=\"last\">    <a href=\"#i-115\">\u307e\u3068\u3081\uff1aRuby on Rails\u3068GraphQL\u306e\u672a\u6765<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-116\">GraphQL\u304c\u3082\u305f\u3089\u3059Ruby on Rails\u958b\u767a\u306e\u9769\u65b0<\/a>      <\/li>      <li>        <a href=\"#i-117\">\u6b21\u306e\u30b9\u30c6\u30c3\u30d7\uff1a\u3055\u3089\u306a\u308b\u5b66\u7fd2\u30ea\u30bd\u30fc\u30b9\u3068\u5b9f\u8df5\u7684\u306a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30a2\u30a4\u30c7\u30a2<\/a>      <\/li>      <li>        <a href=\"#i-120\">\u5c55\u671b<\/a>      <\/li>      <li>        <a href=\"#i-121\">\u4eca\u5f8c\u306e\u30c8\u30ec\u30f3\u30c9\u3068\u53ef\u80fd\u6027<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-122\">\u6700\u5f8c\u306b<\/a>      <\/li>    <\/ul>  <\/li><\/ul>\n      <a href=\"#\" class=\"sgb-toc-button js-toc-button\" rel=\"nofollow\" data-open-dialog=\"true\"><i class=\"fa fa-list\"><\/i><span class=\"sgb-toc-button__text\">\u76ee\u6b21\u3078<\/span><\/a>\n    <\/div><\/div><h2 class=\"wp-block-heading\" id=\"i-0\">\u306f\u3058\u3081\u306b\uff1aRuby on Rails\u3068GraphQL\u306e\u76f8\u6027\u306e\u826f\u3055<\/h2>\n\n\n\n<p>Web\u958b\u767a\u306e\u4e16\u754c\u3067\u306f\u3001\u52b9\u7387\u7684\u3067\u67d4\u8edf\u306aAPI\u306e\u69cb\u7bc9\u304c\u5e38\u306b\u6c42\u3081\u3089\u308c\u3066\u3044\u307e\u3059\u3002<br>\u305d\u3093\u306a\u4e2d\u3001Ruby on Rails\u3068GraphQL\u306e\u7d44\u307f\u5408\u308f\u305b\u304c\u6ce8\u76ee\u3092\u96c6\u3081\u3066\u3044\u307e\u3059\u3002<br>\u3053\u306e\u7d44\u307f\u5408\u308f\u305b\u306f\u3001\u9ad8\u3044\u751f\u7523\u6027\u3068\u67d4\u8edf\u306a\u30c7\u30fc\u30bf\u53d6\u5f97\u3092\u4e21\u7acb\u3055\u305b\u3001\u30e2\u30c0\u30f3\u306aWeb\u958b\u767a\u306e\u30cb\u30fc\u30ba\u306b\u5fdc\u3048\u308b\u30bd\u30ea\u30e5\u30fc\u30b7\u30e7\u30f3\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-1\">\u306a\u305cRuby on Rails\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067GraphQL\u3092\u9078\u3076\u3079\u304d\u304b<\/h3>\n\n\n\n<p>Ruby on Rails\u306f\u3001\u305d\u306e\u300cConvention over Configuration\uff08CoC\uff09\u300d\u306e\u539f\u5247\u3068\u8c4a\u5bcc\u306a\u30a8\u30b3\u30b7\u30b9\u30c6\u30e0\u306b\u3088\u308a\u3001\u9ad8\u901f\u306a\u958b\u767a\u3092\u53ef\u80fd\u306b\u3059\u308b\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3068\u3057\u3066\u77e5\u3089\u308c\u3066\u3044\u307e\u3059\u3002<br>\u4e00\u65b9\u3001GraphQL\u306f\u67d4\u8edf\u306a\u30c7\u30fc\u30bf\u53d6\u5f97\u3068\u578b\u5b89\u5168\u6027\u3092\u63d0\u4f9b\u3059\u308bAPI\u30af\u30a8\u30ea\u8a00\u8a9e\u3067\u3059\u3002<br>\u3053\u306e2\u3064\u3092\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u30e1\u30ea\u30c3\u30c8\u304c\u5f97\u3089\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">Rails x GraphQL\u306e\u7d44\u307f\u5408\u308f\u305b\u306e\u30e1\u30ea\u30c3\u30c84\u9078<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ol class=\"wp-block-list\">\n<li><strong>\u67d4\u8edf\u306aAPI\u8a2d\u8a08<\/strong>: GraphQL\u306e\u5358\u4e00\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3068\u578b\u30b7\u30b9\u30c6\u30e0\u306b\u3088\u308a\u3001\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u304c\u5fc5\u8981\u306a\u30c7\u30fc\u30bf\u306e\u307f\u3092\u53d6\u5f97\u3067\u304d\u307e\u3059\u3002<br>\u3053\u308c\u306f\u3001Ruby on Rails\u306e\u5f37\u529b\u306aORM\u3067\u3042\u308bActiveRecord\u3068\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u3088\u308a\u52b9\u7387\u7684\u306a\u30c7\u30fc\u30bf\u30a2\u30af\u30bb\u30b9\u3092\u5b9f\u73fe\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u958b\u767a\u3068\u306e\u9023\u643a<\/strong>: GraphQL\u306e\u30b9\u30ad\u30fc\u30de\u99c6\u52d5\u958b\u767a\u306b\u3088\u308a\u3001\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u3068\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u306e\u30c1\u30fc\u30e0\u9593\u306e\u30b3\u30df\u30e5\u30cb\u30b1\u30fc\u30b7\u30e7\u30f3\u304c\u6539\u5584\u3055\u308c\u307e\u3059\u3002\u3053\u308c\u306f\u3001Ruby on Rails\u306e\u9ad8\u3044\u751f\u7523\u6027\u3068\u76f8\u307e\u3063\u3066\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u5168\u4f53\u306e\u958b\u767a\u901f\u5ea6\u3092\u5411\u4e0a\u3055\u305b\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u6700\u9069\u5316<\/strong>: GraphQL\u306e\u30aa\u30fc\u30d0\u30fc\u30d5\u30a7\u30c3\u30c1\u3068\u30a2\u30f3\u30c0\u30fc\u30d5\u30a7\u30c3\u30c1\u306e\u89e3\u6d88\u306f\u3001Ruby on Rails\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u5411\u4e0a\u306b\u76f4\u7d50\u3057\u307e\u3059\u3002\u5fc5\u8981\u306a\u30c7\u30fc\u30bf\u306e\u307f\u3092\u52b9\u7387\u7684\u306b\u53d6\u5f97\u3059\u308b\u3053\u3068\u3067\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u5fdc\u7b54\u6027\u304c\u5411\u4e0a\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u306e\u7c21\u7d20\u5316<\/strong>: GraphQL\u306e\u30b9\u30ad\u30fc\u30de\u9032\u5316\u306b\u3088\u308a\u3001\u5f93\u6765\u306eRESTful API\u3067\u983b\u7e41\u306b\u767a\u751f\u3057\u3066\u3044\u305f\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u306e\u554f\u984c\u304c\u8efd\u6e1b\u3055\u308c\u307e\u3059\u3002\u3053\u308c\u306f\u3001Ruby on Rails\u306e\u300c\u5c0f\u3055\u306a\u5909\u66f4\u3092\u983b\u7e41\u306b\u30c7\u30d7\u30ed\u30a4\u3059\u308b\u300d\u3068\u3044\u3046\u54f2\u5b66\u3068\u3082\u5408\u81f4\u3057\u307e\u3059\u3002<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-2\">GraphQL\u304c\u3082\u305f\u3089\u3059\u958b\u767a\u52b9\u7387\u3068\u67d4\u8edf\u6027\u306e\u5411\u4e0a<\/h3>\n\n\n\n<p>GraphQL\u3092Ruby on Rails\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u5c0e\u5165\u3059\u308b\u3053\u3068\u3067\u3001\u958b\u767a\u52b9\u7387\u3068\u67d4\u8edf\u6027\u304c\u5927\u5e45\u306b\u5411\u4e0a\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u5fc5\u8981\u306a\u30c7\u30fc\u30bf\u306e\u307f\u3092\u53d6\u5f97<\/strong>: \u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306f\u5fc5\u8981\u306a\u30d5\u30a3\u30fc\u30eb\u30c9\u306e\u307f\u3092\u6307\u5b9a\u3057\u3066\u30c7\u30fc\u30bf\u3092\u53d6\u5f97\u3067\u304d\u308b\u305f\u3081\u3001\u4e0d\u8981\u306a\u30c7\u30fc\u30bf\u8ee2\u9001\u3092\u524a\u6e1b\u3057\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u52b9\u7387\u3092\u9ad8\u3081\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u306e\u8981\u6c42\u306b\u5fdc\u3058\u305f\u67d4\u8edf\u306a\u30c7\u30fc\u30bf\u63d0\u4f9b<\/strong>: \u65b0\u3057\u3044\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u8981\u4ef6\u304c\u767a\u751f\u3057\u305f\u5834\u5408\u3067\u3082\u3001\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u306e\u5909\u66f4\u3092\u6700\u5c0f\u9650\u306b\u6291\u3048\u306a\u304c\u3089\u5bfe\u5fdc\u3067\u304d\u307e\u3059\u3002\u3053\u308c\u306b\u3088\u308a\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u958b\u767a\u8005\u306e\u751f\u7523\u6027\u304c\u5411\u4e0a\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30b9\u30ad\u30fc\u30de\u99c6\u52d5\u958b\u767a<\/strong>: GraphQL\u306e\u30b9\u30ad\u30fc\u30de\u306f\u3001API\u306e\u30b3\u30f3\u30c8\u30e9\u30af\u30c8\u3068\u3057\u3066\u6a5f\u80fd\u3057\u307e\u3059\u3002\u3053\u308c\u306b\u3088\u308a\u3001\u30c1\u30fc\u30e0\u9593\u306e\u9023\u643a\u304c\u30b9\u30e0\u30fc\u30ba\u306b\u306a\u308a\u3001\u958b\u767a\u30d7\u30ed\u30bb\u30b9\u5168\u4f53\u304c\u52b9\u7387\u5316\u3055\u308c\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>API\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306e\u81ea\u52d5\u751f\u6210<\/strong>: GraphQL\u306e\u30a4\u30f3\u30c8\u30ed\u30b9\u30da\u30af\u30b7\u30e7\u30f3\u6a5f\u80fd\u306b\u3088\u308a\u3001\u5e38\u306b\u6700\u65b0\u306eAPI\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3092\u81ea\u52d5\u751f\u6210\u3067\u304d\u307e\u3059\u3002\u3053\u308c\u306f\u3001Ruby on Rails\u306e\u300cDRY\uff08Don\u2019t Repeat Yourself\uff09\u300d\u539f\u5247\u3068\u3082\u5408\u81f4\u3057\u3001\u30c9\u30ad\u30e5\u30e1\u30f3\u30c6\u30fc\u30b7\u30e7\u30f3\u306e\u52b4\u529b\u3092\u8efd\u6e1b\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<p>\u5b9f\u969b\u306b\u3001GitHub\u3001Shopify\u3001Airbnb\u306a\u3069\u306e\u5927\u898f\u6a21\u30b5\u30fc\u30d3\u30b9\u3067\u3082\u3001Ruby on Rails\u3068GraphQL\u306e\u7d44\u307f\u5408\u308f\u305b\u304c\u63a1\u7528\u3055\u308c\u3066\u3044\u307e\u3059\u3002<br>\u3053\u308c\u3089\u306e\u6210\u529f\u4e8b\u4f8b\u306f\u3001\u3053\u306e\u7d44\u307f\u5408\u308f\u305b\u304c\u5358\u306a\u308b\u30c8\u30ec\u30f3\u30c9\u3067\u306f\u306a\u304f\u3001\u5b9f\u7528\u7684\u3067\u52b9\u679c\u7684\u306a\u30bd\u30ea\u30e5\u30fc\u30b7\u30e7\u30f3\u3067\u3042\u308b\u3053\u3068\u3092\u8a3c\u660e\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p>Ruby on Rails\u3068GraphQL\u306e\u7d44\u307f\u5408\u308f\u305b\u306f\u3001\u30e2\u30c0\u30f3\u306aWeb\u958b\u767a\u306e\u30cb\u30fc\u30ba\u306b\u5fdc\u3048\u308b\u5f37\u529b\u306a\u30c4\u30fc\u30eb\u30bb\u30c3\u30c8\u3092\u63d0\u4f9b\u3057\u307e\u3059\u3002<br>\u9ad8\u3044\u751f\u7523\u6027\u3001\u67d4\u8edf\u306a\u30c7\u30fc\u30bf\u53d6\u5f97\u3001\u305d\u3057\u3066\u512a\u308c\u305f\u958b\u767a\u8005\u4f53\u9a13\u3092\u6c42\u3081\u308b\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u3068\u3063\u3066\u3001\u3053\u306e\u7d44\u307f\u5408\u308f\u305b\u306f\u9b45\u529b\u7684\u306a\u9078\u629e\u80a2\u3068\u306a\u308b\u3067\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<p>\u672c\u8a18\u4e8b\u3067\u306f\u3001Ruby on Rails\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306bGraphQL\u3092\u5c0e\u5165\u3059\u308b\u65b9\u6cd5\u3001\u57fa\u672c\u7684\u306a\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3001\u305d\u3057\u3066\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306e\u6d3b\u7528\u4e8b\u4f8b\u307e\u3067\u3001\u5e45\u5e83\u304f\u30ab\u30d0\u30fc\u3057\u3066\u3044\u304d\u307e\u3059\u3002<br>Ruby on Rails\u3068GraphQL\u306e\u529b\u3092\u6700\u5927\u9650\u306b\u5f15\u304d\u51fa\u3057\u3001\u3088\u308a\u52b9\u7387\u7684\u3067\u67d4\u8edf\u306aWeb\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u958b\u767a\u3092\u5b9f\u73fe\u3059\u308b\u305f\u3081\u306e\u77e5\u8b58\u3068\u30c6\u30af\u30cb\u30c3\u30af\u3092\u3001\u4e00\u7dd2\u306b\u5b66\u3093\u3067\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-3\">GraphQL\u306e\u57fa\u672c\u6982\u5ff5\u3068Ruby on Rails\u3067\u306e\u5b9f\u88c5<\/h2>\n\n\n\n<p>GraphQL\u306f\u3001\u67d4\u8edf\u3067\u30d1\u30ef\u30d5\u30eb\u306aAPI\u30af\u30a8\u30ea\u8a00\u8a9e\u3067\u3059\u3002<br>Ruby on Rails\u3068\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u52b9\u7387\u7684\u3067\u62e1\u5f35\u6027\u306e\u9ad8\u3044API\u3092\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002<br>\u3053\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001GraphQL\u306e\u57fa\u672c\u6982\u5ff5\u3068\u3001Ruby on Rails\u3067\u306e\u5b9f\u88c5\u65b9\u6cd5\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-4\">GraphQL\u30b9\u30ad\u30fc\u30de\u306e\u5b9a\u7fa9\u65b9\u6cd5<\/h3>\n\n\n\n<p>GraphQL\u306e\u4e2d\u5fc3\u3068\u306a\u308b\u306e\u306f\u3001\u30b9\u30ad\u30fc\u30de\u3067\u3059\u3002<br>\u30b9\u30ad\u30fc\u30de\u306f\u3001API\u3067\u5229\u7528\u53ef\u80fd\u306a\u30c7\u30fc\u30bf\u578b\u3068\u305d\u306e\u95a2\u4fc2\u3092\u5b9a\u7fa9\u3057\u307e\u3059\u3002<br>Ruby on Rails\u3067GraphQL\u3092\u4f7f\u7528\u3059\u308b\u306b\u306f\u3001\u307e\u305a\u5fc5\u8981\u306agem\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\u3002<\/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=\"\"># Gemfile\ngem 'graphql'<\/pre>\n\n\n\n<p>\u6b21\u306b\u3001GraphQL\u30b9\u30ad\u30fc\u30de\u3092\u5b9a\u7fa9\u3057\u307e\u3059\u3002<br>\u4ee5\u4e0b\u306f\u3001\u7c21\u5358\u306a\u30d6\u30ed\u30b0\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30b9\u30ad\u30fc\u30de\u4f8b\u3067\u3059\u3002<\/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=\"\"># app\/graphql\/types\/query_type.rb\nmodule Types\n  class QueryType &lt; Types::BaseObject\n    field :posts, [Types::PostType], null: false\n\n    def posts\n      Post.all\n    end\n  end\nend\n\n# app\/graphql\/types\/post_type.rb\nmodule Types\n  class PostType &lt; Types::BaseObject\n    field :id, ID, null: false\n    field :title, String, null: false\n    field :content, String, null: false\n    field :author, Types::UserType, null: false\n  end\nend\n\n# app\/graphql\/types\/user_type.rb\nmodule Types\n  class UserType &lt; Types::BaseObject\n    field :id, ID, null: false\n    field :name, String, null: false\n    field :email, String, null: false\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u30b9\u30ad\u30fc\u30de\u3067\u306f\u3001<code>Post<\/code>\u3068<code>User<\/code>\u306e2\u3064\u306e\u578b\u3092\u5b9a\u7fa9\u3057\u3001\u305d\u308c\u3089\u306e\u95a2\u4fc2\u3092\u8868\u73fe\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-5\">\u30af\u30a8\u30ea\u3068\u30df\u30e5\u30fc\u30c6\u30fc\u30b7\u30e7\u30f3\u306e\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af<\/h3>\n\n\n\n<p>GraphQL\u3067\u306f\u3001\u30c7\u30fc\u30bf\u306e\u53d6\u5f97\u306b\u300c\u30af\u30a8\u30ea\u300d\u3001\u30c7\u30fc\u30bf\u306e\u5909\u66f4\u306b\u300c\u30df\u30e5\u30fc\u30c6\u30fc\u30b7\u30e7\u30f3\u300d\u3092\u4f7f\u7528\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#fff9e6;color:#ffb36b\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#ffb36b\"><i class=\"fas fa-pencil-alt\"><\/i><\/span><div class=\"sng-box-msg__title\">\u30af\u30a8\u30ea\u306e\u4f8b<\/div><\/div><div class=\"sng-box-msg__contents\">\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=\"\"># app\/graphql\/types\/query_type.rb\nmodule Types\n  class QueryType &lt; Types::BaseObject\n    field :post, Types::PostType, null: true do\n      argument :id, ID, required: true\n    end\n\n    def post(id:)\n      Post.find(id)\n    end\n  end\nend<\/pre>\n<\/div><\/div><\/div>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#fff9e6;color:#ffb36b\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#ffb36b\"><i class=\"fas fa-pencil-alt\"><\/i><\/span><div class=\"sng-box-msg__title\">\u30df\u30e5\u30fc\u30c6\u30fc\u30b7\u30e7\u30f3\u306e\u4f8b<\/div><\/div><div class=\"sng-box-msg__contents\">\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=\"\"># app\/graphql\/mutations\/create_post.rb\nmodule Mutations\n  class CreatePost &lt; BaseMutation\n    argument :title, String, required: true\n    argument :content, String, required: true\n\n    field :post, Types::PostType, null: true\n    field :errors, [String], null: false\n\n    def resolve(title:, content:)\n      post = Post.new(title: title, content: content)\n      if post.save\n        {\n          post: post,\n          errors: []\n        }\n      else\n        {\n          post: nil,\n          errors: post.errors.full_messages\n        }\n      end\n    end\n  end\nend<\/pre>\n<\/div><\/div><\/div>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u5b9f\u88c5\u306b\u3088\u308a\u3001\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306f\u5fc5\u8981\u306a\u30c7\u30fc\u30bf\u306e\u307f\u3092\u67d4\u8edf\u306b\u53d6\u5f97\u3057\u305f\u308a\u3001\u65b0\u3057\u3044\u30c7\u30fc\u30bf\u3092\u4f5c\u6210\u3057\u305f\u308a\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-6\">Resolver\u306e\u52b9\u7387\u7684\u306a\u66f8\u304d\u65b9<\/h3>\n\n\n\n<p>Resolver\u306f\u3001GraphQL\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\u304c\u3069\u306e\u3088\u3046\u306b\u30c7\u30fc\u30bf\u3092\u53d6\u5f97\u3059\u308b\u304b\u3092\u5b9a\u7fa9\u3059\u308b\u95a2\u6570\u3067\u3059\u3002<br>\u52b9\u7387\u7684\u306aResolver\u3092\u66f8\u304f\u3053\u3068\u3067\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u4ee5\u4e0b\u306f\u3001N+1\u554f\u984c\u3092\u56de\u907f\u3059\u308bResolver\u306e\u4f8b\u3067\u3059\u3002<\/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=\"\"># app\/graphql\/types\/query_type.rb\nmodule Types\n  class QueryType &lt; Types::BaseObject\n    field :posts, [Types::PostType], null: false\n\n    def posts\n      Post.includes(:author).all\n    end\n  end\nend\n\n# app\/graphql\/types\/post_type.rb\nmodule Types\n  class PostType &lt; Types::BaseObject\n    # ... \u4ed6\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\u5b9a\u7fa9\n\n    field :author, Types::UserType, null: false\n\n    def author\n      object.author\n    end\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u4f8b\u3067\u306f\u3001<code>includes(:author)<\/code>\u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u95a2\u9023\u3059\u308bauthor\u30c7\u30fc\u30bf\u3092\u4e8b\u524d\u306b\u30ed\u30fc\u30c9\u3057\u3001N+1\u554f\u984c\u3092\u9632\u3044\u3067\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u3055\u3089\u306b\u3001\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u3001\u3088\u308a\u52b9\u7387\u7684\u306b\u30c7\u30fc\u30bf\u3092\u53d6\u5f97\u3067\u304d\u307e\u3059\u3002<\/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=\"\"># app\/graphql\/loaders\/association_loader.rb\nclass AssociationLoader &lt; GraphQL::Batch::Loader\n  def initialize(model, association_name)\n    @model = model\n    @association_name = association_name\n  end\n\n  def perform(record_ids)\n    records = @model.where(id: record_ids).includes(@association_name)\n    records.each { |record| fulfill(record.id, record) }\n    record_ids.each { |id| fulfill(id, nil) unless fulfilled?(id) }\n  end\nend\n\n# app\/graphql\/types\/post_type.rb\nmodule Types\n  class PostType &lt; Types::BaseObject\n    # ... \u4ed6\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\u5b9a\u7fa9\n\n    field :author, Types::UserType, null: false\n\n    def author\n      AssociationLoader.for(Post, :author).load(object.id)\n    end\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u5b9f\u88c5\u306b\u3088\u308a\u3001\u8907\u6570\u306e\u6295\u7a3f\u306e\u8457\u8005\u3092\u52b9\u7387\u7684\u306b\u4e00\u62ec\u3067\u53d6\u5f97\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>GraphQL\u3068Ruby on Rails\u3092\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u67d4\u8edf\u3067\u52b9\u7387\u7684\u306aAPI\u3092\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002<br>\u30b9\u30ad\u30fc\u30de\u306e\u9069\u5207\u306a\u8a2d\u8a08\u3001\u52b9\u7387\u7684\u306aResolver\u306e\u5b9f\u88c5\u3001\u305d\u3057\u3066\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u306e\u6d3b\u7528\u306b\u3088\u308a\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3068\u4fdd\u5b88\u6027\u306e\u9ad8\u3044API\u3092\u5b9f\u73fe\u3067\u304d\u308b\u3067\u3057\u3087\u3046\u3002<br>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3088\u308a\u8a73\u7d30\u306a\u74b0\u5883\u69cb\u7bc9\u30b9\u30c6\u30c3\u30d7\u306b\u3064\u3044\u3066\u898b\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-7\">Ruby on Rails\u3067\u306eGraphQL\u74b0\u5883\u69cb\u7bc9\u30b9\u30c6\u30c3\u30d7<\/h2>\n\n\n\n<p>Ruby on Rails\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306bGraphQL\u3092\u5c0e\u5165\u3059\u308b\u3053\u3068\u3067\u3001\u67d4\u8edf\u3067\u52b9\u7387\u7684\u306aAPI\u3092\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001GraphQL\u74b0\u5883\u3092\u69cb\u7bc9\u3059\u308b\u305f\u3081\u306e\u5177\u4f53\u7684\u306a\u30b9\u30c6\u30c3\u30d7\u3092\u8aac\u660e\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-8\">\u5fc5\u8981\u306aGem\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3068\u8a2d\u5b9a<\/h3>\n\n\n\n<p>\u307e\u305a\u3001\u5fc5\u8981\u306aGem\u3092\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u8ffd\u52a0\u3057\u307e\u3059\u3002<br>Gemfile\u306b\u4ee5\u4e0b\u306e\u884c\u3092\u8ffd\u52a0\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/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=\"\"># Gemfile\ngem 'graphql'\ngem 'graphiql-rails', group: :development<\/pre>\n\n\n\n<p>\u6b21\u306b\u3001\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057\u3066Gem\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\u3002<\/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=\"\">bundle install<\/pre>\n\n\n\n<p>GraphQL\u306e\u57fa\u672c\u7684\u306a\u30d5\u30a1\u30a4\u30eb\u3092\u751f\u6210\u3059\u308b\u305f\u3081\u306b\u3001\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057\u307e\u3059\u3002<\/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=\"\">rails generate graphql:install<\/pre>\n\n\n\n<p>\u3053\u306e\u30b3\u30de\u30f3\u30c9\u306b\u3088\u308a\u3001\u4ee5\u4e0b\u306e\u30d5\u30a1\u30a4\u30eb\u304c\u751f\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><code>app\/graphql\/types\/query_type.rb<\/code><\/li>\n\n\n\n<li><code>app\/graphql\/types\/mutation_type.rb<\/code><\/li>\n\n\n\n<li><code>app\/graphql\/[your_app_name]_schema.rb<\/code><\/li>\n<\/ul>\n\n\n\n<p>\u307e\u305f\u3001<code>config\/routes.rb<\/code>\u306b\u4ee5\u4e0b\u306e\u884c\u304c\u8ffd\u52a0\u3055\u308c\u307e\u3059\u3002<\/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=\"\">post \"\/graphql\", to: \"graphql#execute\"<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-9\">GraphQL\u578b\u306e\u5b9a\u7fa9\u3068\u30e2\u30c7\u30eb\u3068\u306e\u9023\u643a<\/h3>\n\n\n\n<p>GraphQL\u578b\u3092\u5b9a\u7fa9\u3059\u308b\u969b\u306f\u3001\u65e2\u5b58\u306eRails\u30e2\u30c7\u30eb\u3068\u9023\u643a\u3055\u305b\u308b\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<br>\u4ee5\u4e0b\u306f\u3001<code>User<\/code>\u30e2\u30c7\u30eb\u306b\u5bfe\u5fdc\u3059\u308bGraphQL\u578b\u306e\u4f8b\u3067\u3059\u3002<\/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=\"\"># app\/graphql\/types\/user_type.rb\nmodule Types\n  class UserType &lt; Types::BaseObject\n    field :id, ID, null: false\n    field :name, String, null: false\n    field :email, String, null: false\n    field :posts, [Types::PostType], null: true\n\n    def posts\n      object.posts.includes(:comments)  # N+1\u554f\u984c\u3092\u56de\u907f\n    end\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u4f8b\u3067\u306f\u3001<code>User<\/code>\u30e2\u30c7\u30eb\u306e\u5c5e\u6027\u3092GraphQL\u30d5\u30a3\u30fc\u30eb\u30c9\u3068\u3057\u3066\u5b9a\u7fa9\u3057\u3001\u95a2\u9023\u3059\u308b<code>posts<\/code>\u3082\u53d6\u5f97\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u3066\u3044\u307e\u3059\u3002<br><code>includes(:comments)<\/code>\u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u3067\u3001N+1\u554f\u984c\u3092\u56de\u907f\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30e2\u30c7\u30eb\u9593\u306e\u30a2\u30bd\u30b7\u30a8\u30fc\u30b7\u30e7\u30f3\u3092\u6271\u3046\u969b\u306f\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306b<code>resolve_type<\/code>\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u7528\u3059\u308b\u3068\u4fbf\u5229\u3067\u3059\u3002<\/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=\"\"># app\/graphql\/types\/post_type.rb\nmodule Types\n  class PostType &lt; Types::BaseObject\n    field :id, ID, null: false\n    field :title, String, null: false\n    field :content, String, null: false\n    field :author, Types::UserType, null: false\n\n    def author\n      Loaders::RecordLoader.for(User).load(object.author_id)\n    end\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u4f8b\u3067\u306f\u3001\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u4f7f\u7528\u3057\u3066\u52b9\u7387\u7684\u306b\u30c7\u30fc\u30bf\u3092\u53d6\u5f97\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-10\">GraphiQL\u3092\u4f7f\u7528\u3057\u305fAPI\u30c6\u30b9\u30c8\u74b0\u5883\u306e\u6e96\u5099<\/h3>\n\n\n\n<p>GraphiQL\u306f\u3001GraphQL API\u3092\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306b\u30c6\u30b9\u30c8\u3059\u308b\u305f\u3081\u306e\u30c4\u30fc\u30eb\u3067\u3059\u3002<br>\u958b\u767a\u74b0\u5883\u3067GraphiQL\u3092\u4f7f\u7528\u3067\u304d\u308b\u3088\u3046\u306b\u8a2d\u5b9a\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<p><code>config\/routes.rb<\/code>\u306b\u4ee5\u4e0b\u306e\u884c\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/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=\"\">if Rails.env.development?\n  mount GraphiQL::Rails::Engine, at: \"\/graphiql\", graphql_path: \"\/graphql\"\nend<\/pre>\n\n\n\n<p>\u307e\u305f\u3001<code>app\/assets\/config\/manifest.js<\/code>\u306b\u4ee5\u4e0b\u306e\u884c\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/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=\"\">\/\/= link graphiql\/rails\/application.css\n\/\/= link graphiql\/rails\/application.js<\/pre>\n\n\n\n<p>\u3053\u308c\u3067\u3001\u958b\u767a\u74b0\u5883\u3067<code>http:\/\/localhost:3000\/graphiql<\/code>\u306b\u30a2\u30af\u30bb\u30b9\u3059\u308b\u3068\u3001GraphiQL\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u304c\u8868\u793a\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p>GraphiQL\u3092\u4f7f\u7528\u3057\u3066\u30af\u30a8\u30ea\u3092\u30c6\u30b9\u30c8\u3059\u308b\u4f8b<\/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=\"\">query {\n  user(id: 1) {\n    name\n    email\n    posts {\n      title\n      content\n    }\n  }\n}<\/pre>\n\n\n\n<p>\u3053\u306e\u30af\u30a8\u30ea\u306f\u3001ID 1\u306e\u30e6\u30fc\u30b6\u30fc\u306e\u540d\u524d\u3001\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9\u3001\u304a\u3088\u3073\u95a2\u9023\u3059\u308b\u6295\u7a3f\u306e\u30bf\u30a4\u30c8\u30eb\u3068\u30b3\u30f3\u30c6\u30f3\u30c4\u3092\u53d6\u5f97\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#ffebeb;color:#f88080\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#f88080\"><i class=\"fas fa-exclamation\"><\/i><\/span><div class=\"sng-box-msg__title\">GraphiQL\u3092\u4f7f\u7528\u3059\u308b\u969b\u306e\u6ce8\u610f\u70b9<\/div><\/div><div class=\"sng-box-msg__contents\">\n<ol class=\"wp-block-list\">\n<li>\u958b\u767a\u74b0\u5883\u3067\u306e\u307f\u6709\u52b9\u306b\u3059\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3001\u672c\u756a\u74b0\u5883\u3067\u306f\u7121\u52b9\u5316\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/li>\n\n\n\n<li>\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u8a8d\u8a3c\u3092\u8ffd\u52a0\u3057\u3001API\u306e\u5b89\u5168\u6027\u3092\u78ba\u4fdd\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/li>\n\n\n\n<li>\u8907\u96d1\u306a\u30af\u30a8\u30ea\u3084\u30df\u30e5\u30fc\u30c6\u30fc\u30b7\u30e7\u30f3\u3092\u30c6\u30b9\u30c8\u3059\u308b\u969b\u306f\u3001GraphiQL\u306e\u5909\u6570\u6a5f\u80fd\u3092\u6d3b\u7528\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/li>\n<\/ol>\n<\/div><\/div><\/div>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-11\">\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-12\">1. CORS (Cross-Origin Resource Sharing) \u306e\u8a2d\u5b9a<\/h4>\n\n\n\n<p>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3068\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u304c\u7570\u306a\u308b\u30c9\u30e1\u30a4\u30f3\u306b\u3042\u308b\u5834\u5408\u3001CORS\u8a2d\u5b9a\u304c\u5fc5\u8981\u3067\u3059\u3002<br><code>rack-cors<\/code> gem\u3092\u4f7f\u7528\u3057\u3066\u8a2d\u5b9a\u3067\u304d\u307e\u3059<\/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=\"\">   # config\/initializers\/cors.rb\n   Rails.application.config.middleware.insert_before 0, Rack::Cors do\n     allow do\n       origins 'http:\/\/your-frontend-domain.com'\n       resource '\/graphql', headers: :any, methods: [:post, :options]\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-13\">2. \u30d0\u30fc\u30b8\u30e7\u30f3\u306e\u4e92\u63db\u6027<\/h4>\n\n\n\n<p>GraphQL\u95a2\u9023\u306egem\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u304c\u4e92\u3044\u306b\u4e92\u63db\u6027\u304c\u3042\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002<br>\u554f\u984c\u304c\u767a\u751f\u3057\u305f\u5834\u5408\u306f\u3001\u5404gem\u306e\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3092\u53c2\u7167\u3057\u3001\u9069\u5207\u306a\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u4f7f\u7528\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-14\">3. \u30c7\u30d0\u30c3\u30b0\u65b9\u6cd5<\/h4>\n\n\n\n<p>GraphQL\u30af\u30a8\u30ea\u306e\u30c7\u30d0\u30c3\u30b0\u306b\u306f\u3001<code>GraphQL::Query::Tracer<\/code>\u3092\u4f7f\u7528\u3067\u304d\u307e\u3059<\/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=\"\">   class QueryTracer\n     def trace(key, data)\n       p \"Key: #{key}, Data: #{data}\"\n       yield\n     end\n   end\n\n   # config\/application.rb\n   config.graphql.tracer = QueryTracer.new<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-15\">4. N+1\u554f\u984c\u306e\u56de\u907f<\/h4>\n\n\n\n<p>GraphQL\u3067\u306f\u3001N+1\u554f\u984c\u304c\u767a\u751f\u3057\u3084\u3059\u3044\u305f\u3081\u3001\u4ee5\u4e0b\u306e\u65b9\u6cd5\u3067\u56de\u907f\u3057\u307e\u3057\u3087\u3046<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><code>includes<\/code>\u3084<code>preload<\/code>\u3092\u4f7f\u7528\u3059\u308b<\/li>\n\n\n\n<li>\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u5b9f\u88c5\u3059\u308b\uff08\u4f8b\uff1a<code>graphql-batch<\/code> gem\u3092\u4f7f\u7528\uff09<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-16\">5. \u30d5\u30e9\u30b0\u30e1\u30f3\u30c8\u306e\u6d3b\u7528<\/h4>\n\n\n\n<p>\u5171\u901a\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\u30bb\u30c3\u30c8\u3092\u518d\u5229\u7528\u3059\u308b\u969b\u306f\u3001\u30d5\u30e9\u30b0\u30e1\u30f3\u30c8\u3092\u4f7f\u7528\u3059\u308b\u3068\u52b9\u7387\u7684\u3067\u3059\u3002<\/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=\"\">   fragment UserFields on User {\n     id\n     name\n     email\n   }\n\n   query {\n     user(id: 1) {\n       ...UserFields\n       posts {\n         title\n       }\n     }\n   }<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-17\">\u767a\u5c55\u7684\u306a\u8a2d\u5b9a<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-18\">1. \u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0<\/h4>\n\n\n\n<p><code>graphql-batch<\/code> gem\u3092\u4f7f\u7528\u3057\u3066\u3001\u52b9\u7387\u7684\u306a\u30c7\u30fc\u30bf\u53d6\u5f97\u3092\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/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=\"\">   gem 'graphql-batch'\n\n   # app\/graphql\/loaders\/record_loader.rb\n   class RecordLoader &lt; GraphQL::Batch::Loader\n     def initialize(model)\n       @model = model\n     end\n\n     def perform(ids)\n       @model.where(id: ids).each { |record| fulfill(record.id, record) }\n       ids.each { |id| fulfill(id, nil) unless fulfilled?(id) }\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-19\">2. \u8a8d\u8a3c\u30fb\u8a8d\u53ef\u306e\u5b9f\u88c5<\/h4>\n\n\n\n<p>GraphQL\u306e\u30b3\u30f3\u30c6\u30ad\u30b9\u30c8\u3092\u4f7f\u7528\u3057\u3066\u3001\u8a8d\u8a3c\u30fb\u8a8d\u53ef\u3092\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/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=\"\">   # app\/controllers\/graphql_controller.rb\n   def execute\n     context = {\n       current_user: current_user,\n       # \u305d\u306e\u4ed6\u306e\u8a8d\u8a3c\u60c5\u5831\n     }\n     result = YourAppSchema.execute(params[:query], context: context, variables: params[:variables])\n     render json: result\n   end\n\n   # app\/graphql\/types\/query_type.rb\n   field :protected_data, String, null: false\n\n   def protected_data\n     if context[:current_user].nil?\n       raise GraphQL::ExecutionError, \"\u8a8d\u8a3c\u304c\u5fc5\u8981\u3067\u3059\"\n     end\n     \"\u4fdd\u8b77\u3055\u308c\u305f\u30c7\u30fc\u30bf\"\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-20\">3. \u30ab\u30b9\u30bf\u30e0\u30c7\u30a3\u30ec\u30af\u30c6\u30a3\u30d6\u306e\u4f5c\u6210<\/h4>\n\n\n\n<p>\u7279\u5b9a\u306e\u6761\u4ef6\u4e0b\u3067\u30d5\u30a3\u30fc\u30eb\u30c9\u306e\u89e3\u6c7a\u3092\u30b9\u30ad\u30c3\u30d7\u3059\u308b\u306a\u3069\u3001\u30ab\u30b9\u30bf\u30e0\u30ed\u30b8\u30c3\u30af\u3092\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/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=\"\">   class SkipDirective &lt; GraphQL::Schema::Directive\n     description \"\u6307\u5b9a\u3055\u308c\u305f\u6761\u4ef6\u304c\u771f\u306e\u5834\u5408\u3001\u30d5\u30a3\u30fc\u30eb\u30c9\u306e\u89e3\u6c7a\u3092\u30b9\u30ad\u30c3\u30d7\u3057\u307e\u3059\"\n     argument :if, Boolean, required: true\n\n     def self.resolve(object, arguments, context)\n       yield unless arguments[:if]\n     end\n   end\n\n   # \u30b9\u30ad\u30fc\u30de\u306b\u8ffd\u52a0\n   class YourAppSchema &lt; GraphQL::Schema\n     directive(SkipDirective)\n   end<\/pre>\n\n\n\n<p>Ruby on Rails\u3067\u306eGraphQL\u74b0\u5883\u69cb\u7bc9\u306f\u3001\u521d\u671f\u8a2d\u5b9a\u304b\u3089\u767a\u5c55\u7684\u306a\u6a5f\u80fd\u307e\u3067\u3001\u6bb5\u968e\u7684\u306b\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<br>\u57fa\u672c\u7684\u306a\u8a2d\u5b9a\u3092\u78ba\u5b9f\u306b\u884c\u3044\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u8981\u4ef6\u306b\u5fdc\u3058\u3066\u6a5f\u80fd\u3092\u62e1\u5f35\u3057\u3066\u3044\u304f\u3053\u3068\u3067\u3001\u67d4\u8edf\u3067\u52b9\u7387\u7684\u306aGraphQL API\u3092\u69cb\u7bc9\u3067\u304d\u308b\u3067\u3057\u3087\u3046\u3002<br>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3088\u308a\u5177\u4f53\u7684\u306a\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af\u306b\u3064\u3044\u3066\u6df1\u6398\u308a\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-21\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af<\/h2>\n\n\n\n<p>GraphQL\u3092\u4f7f\u7528\u3057\u305fRuby on Rails\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3067\u306f\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u304c\u6975\u3081\u3066\u91cd\u8981\u3067\u3059\u3002<br>\u9069\u5207\u306a\u6700\u9069\u5316\u306b\u3088\u308a\u3001\u5fdc\u7b54\u6642\u9593\u306e\u77ed\u7e2e\u3001\u30b5\u30fc\u30d0\u30fc\u30ea\u30bd\u30fc\u30b9\u306e\u52b9\u7387\u7684\u306a\u4f7f\u7528\u3001\u30e6\u30fc\u30b6\u30fc\u30a8\u30af\u30b9\u30da\u30ea\u30a8\u30f3\u30b9\u306e\u5411\u4e0a\u3001\u305d\u3057\u3066\u30b9\u30b1\u30fc\u30e9\u30d3\u30ea\u30c6\u30a3\u306e\u78ba\u4fdd\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001\u4e3b\u8981\u306a3\u3064\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-22\">N+1\u554f\u984c\u306e\u89e3\u6c7a\u7b56\u3068\u5b9f\u88c5\u4f8b<\/h3>\n\n\n\n<p>N+1\u554f\u984c\u306f\u3001GraphQL\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3067\u3088\u304f\u906d\u9047\u3059\u308b\u6027\u80fd\u554f\u984c\u3067\u3059\u3002<br>\u3053\u308c\u306f\u30011\u56de\u306e\u30af\u30a8\u30ea\u3067\u53d6\u5f97\u3057\u305f\u30c7\u30fc\u30bf\u306b\u5bfe\u3057\u3066\u3001\u95a2\u9023\u30c7\u30fc\u30bf\u3092\u53d6\u5f97\u3059\u308b\u305f\u3081\u306b\u8907\u6570\u306e\u8ffd\u52a0\u30af\u30a8\u30ea\u304c\u767a\u751f\u3059\u308b\u554f\u984c\u3092\u6307\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-23\">\u89e3\u6c7a\u7b561: Eager Loading<\/h4>\n\n\n\n<p>ActiveRecord\u306e<code>includes<\/code>\u3001<code>preload<\/code>\u3001<code>eager_load<\/code>\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u95a2\u9023\u30c7\u30fc\u30bf\u3092\u4e8b\u524d\u306b\u8aad\u307f\u8fbc\u307f\u3001N+1\u554f\u984c\u3092\u89e3\u6c7a\u3067\u304d\u307e\u3059\u3002<\/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=\"\"># app\/graphql\/types\/query_type.rb\nfield :posts, [Types::PostType], null: false\n\ndef posts\n  Post.includes(:author, :comments).all\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u65b9\u6cd5\u306b\u3088\u308a\u3001\u6295\u7a3f\u3068\u305d\u306e\u8457\u8005\u3001\u30b3\u30e1\u30f3\u30c8\u30921\u3064\u306e\u30af\u30a8\u30ea\u3067\u53d6\u5f97\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-24\">\u89e3\u6c7a\u7b562: GraphQL::Batch\u306e\u4f7f\u7528<\/h4>\n\n\n\n<p><code>graphql-batch<\/code> gem\u3092\u4f7f\u7528\u3059\u308b\u3068\u3001\u3088\u308a\u67d4\u8edf\u306a\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002<\/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=\"\"># app\/graphql\/loaders\/association_loader.rb\nclass AssociationLoader &lt; GraphQL::Batch::Loader\n  def initialize(model, association_name)\n    @model = model\n    @association_name = association_name\n  end\n\n  def perform(record_ids)\n    records = @model.where(id: record_ids).includes(@association_name)\n    records.each { |record| fulfill(record.id, record.public_send(@association_name)) }\n    record_ids.each { |id| fulfill(id, nil) unless fulfilled?(id) }\n  end\nend\n\n# app\/graphql\/types\/post_type.rb\nfield :author, Types::UserType, null: false\n\ndef author\n  AssociationLoader.for(Post, :author).load(object.id)\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u5b9f\u88c5\u306b\u3088\u308a\u3001\u8907\u6570\u306e\u6295\u7a3f\u306e\u8457\u8005\u3092\u52b9\u7387\u7684\u306b\u4e00\u62ec\u3067\u53d6\u5f97\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>N+1\u554f\u984c\u306e\u89e3\u6c7a\u306b\u3088\u308a\u3001\u30af\u30a8\u30ea\u6642\u9593\u3092\u6700\u592790%\u524a\u6e1b\u3067\u304d\u308b\u3053\u3068\u304c\u5831\u544a\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-25\">\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u6d3b\u7528\u3057\u305f\u30af\u30a8\u30ea\u306e\u52b9\u7387\u5316<\/h3>\n\n\n\n<p>\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u306f\u3001\u8907\u6570\u306e\u30ec\u30b3\u30fc\u30c9\u3092\u4e00\u5ea6\u306b\u52b9\u7387\u7684\u306b\u53d6\u5f97\u3059\u308b\u6280\u8853\u3067\u3059\u3002<br><code>graphql-batch<\/code> gem\u3092\u4f7f\u7528\u3059\u308b\u3068\u3001\u30ab\u30b9\u30bf\u30e0\u30ed\u30fc\u30c0\u30fc\u3092\u4f5c\u6210\u3057\u3066\u8907\u96d1\u306a\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/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=\"\"># app\/graphql\/loaders\/record_loader.rb\nclass RecordLoader &lt; GraphQL::Batch::Loader\n  def initialize(model)\n    @model = model\n  end\n\n  def perform(ids)\n    @model.where(id: ids).each { |record| fulfill(record.id, record) }\n    ids.each { |id| fulfill(id, nil) unless fulfilled?(id) }\n  end\nend\n\n# app\/graphql\/types\/comment_type.rb\nfield :user, Types::UserType, null: false\n\ndef user\n  RecordLoader.for(User).load(object.user_id)\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u5b9f\u88c5\u306b\u3088\u308a\u3001\u8907\u6570\u306e\u30b3\u30e1\u30f3\u30c8\u306e\u30e6\u30fc\u30b6\u30fc\u60c5\u5831\u30921\u56de\u306e\u30af\u30a8\u30ea\u3067\u52b9\u7387\u7684\u306b\u53d6\u5f97\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u306e\u5229\u70b9\u306f\u4ee5\u4e0b\u306e\u901a\u308a\u3067\u3059\u3002<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u30af\u30a8\u30ea\u306e\u524a\u6e1b<\/li>\n\n\n\n<li>\u30e1\u30e2\u30ea\u4f7f\u7528\u91cf\u306e\u6700\u9069\u5316<\/li>\n\n\n\n<li>\u5fdc\u7b54\u6642\u9593\u306e\u77ed\u7e2e<\/li>\n<\/ol>\n\n\n\n<p>\u5b9f\u969b\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306f\u3001\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u5c0e\u5165\u3059\u308b\u3053\u3068\u3067\u3001\u8907\u6570\u30ec\u30b3\u30fc\u30c9\u53d6\u5f97\u6642\u306b50-80%\u306e\u6027\u80fd\u5411\u4e0a\u304c\u5831\u544a\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-26\">\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u3068\u305d\u306e\u5b9f\u88c5\u65b9\u6cd5<\/h3>\n\n\n\n<p>\u30ad\u30e3\u30c3\u30b7\u30e5\u306f\u3001\u983b\u7e41\u306b\u30a2\u30af\u30bb\u30b9\u3055\u308c\u308b\u30c7\u30fc\u30bf\u3092\u9ad8\u901f\u306a\u30b9\u30c8\u30ec\u30fc\u30b8\u306b\u4fdd\u5b58\u3059\u308b\u3053\u3068\u3067\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u307e\u3059\u3002<br>GraphQL\u3067\u306f\u3001\u4ee5\u4e0b\u306e3\u3064\u306e\u30ec\u30d9\u30eb\u3067\u30ad\u30e3\u30c3\u30b7\u30e5\u3092\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">GraphQL\u306e\u30ec\u30d9\u30eb\u52253\u3064\u306e\u30ad\u30e3\u30c3\u30b7\u30e5<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ol class=\"wp-block-list\">\n<li>\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u30ad\u30e3\u30c3\u30b7\u30e5<\/li>\n\n\n\n<li>\u30af\u30a8\u30ea\u30ad\u30e3\u30c3\u30b7\u30e5<\/li>\n\n\n\n<li>\u30d5\u30a3\u30fc\u30eb\u30c9\u30ec\u30d9\u30eb\u30ad\u30e3\u30c3\u30b7\u30e5<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-27\">\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u30ad\u30e3\u30c3\u30b7\u30e5<\/h4>\n\n\n\n<p>Rails.cache\u3092\u4f7f\u7528\u3057\u3066\u3001\u500b\u3005\u306e\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3092\u30ad\u30e3\u30c3\u30b7\u30e5\u3067\u304d\u307e\u3059\u3002<\/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=\"\"># app\/graphql\/types\/user_type.rb\nfield :posts, [Types::PostType], null: false\n\ndef posts\n  Rails.cache.fetch([\"user\", object.id, \"posts\"], expires_in: 1.hour) do\n    object.posts.to_a\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u65b9\u6cd5\u306b\u3088\u308a\u3001\u30e6\u30fc\u30b6\u30fc\u306e\u6295\u7a3f\u30921\u6642\u9593\u30ad\u30e3\u30c3\u30b7\u30e5\u3057\u3001\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3078\u306e\u30a2\u30af\u30bb\u30b9\u3092\u6e1b\u3089\u3059\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-28\">\u30af\u30a8\u30ea\u30ad\u30e3\u30c3\u30b7\u30e5<\/h4>\n\n\n\n<p><code>graphql-ruby-cache<\/code> gem\u3092\u4f7f\u7528\u3059\u308b\u3068\u3001\u30af\u30a8\u30ea\u5168\u4f53\u3092\u30ad\u30e3\u30c3\u30b7\u30e5\u3067\u304d\u307e\u3059\u3002<\/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=\"\"># config\/initializers\/graphql_cache.rb\nGraphQL::Cache.configure do |c|\n  c.namespace = \"graphql:#{Rails.env}\"\n  c.expires_in = 1.hour\n  c.cache = Rails.cache\nend\n\n# app\/graphql\/types\/query_type.rb\nfield :popular_posts, [Types::PostType], null: false\n\ndef popular_posts\n  GraphQL::Cache.fetch(:popular_posts) do\n    Post.popular.limit(10).to_a\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u5b9f\u88c5\u306b\u3088\u308a\u3001\u4eba\u6c17\u306e\u6295\u7a3f\u4e00\u89a7\u30921\u6642\u9593\u30ad\u30e3\u30c3\u30b7\u30e5\u3057\u3001\u983b\u7e41\u306b\u5b9f\u884c\u3055\u308c\u308b\u30af\u30a8\u30ea\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u5411\u4e0a\u3055\u305b\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-29\">\u30d5\u30a3\u30fc\u30eb\u30c9\u30ec\u30d9\u30eb\u30ad\u30e3\u30c3\u30b7\u30e5<\/h4>\n\n\n\n<p>\u500b\u3005\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\u3092\u30ad\u30e3\u30c3\u30b7\u30e5\u3059\u308b\u3053\u3068\u3067\u3001\u3088\u308a\u7d30\u304b\u3044\u7c92\u5ea6\u3067\u306e\u30ad\u30e3\u30c3\u30b7\u30e5\u5236\u5fa1\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002<\/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=\"\"># app\/graphql\/types\/post_type.rb\nfield :comment_count, Integer, null: false\n\ndef comment_count\n  Rails.cache.fetch([\"post\", object.id, \"comment_count\"], expires_in: 5.minutes) do\n    object.comments.count\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u65b9\u6cd5\u306b\u3088\u308a\u3001\u6295\u7a3f\u306e\u30b3\u30e1\u30f3\u30c8\u6570\u30925\u5206\u9593\u30ad\u30e3\u30c3\u30b7\u30e5\u3057\u3001\u983b\u7e41\u306b\u5909\u66f4\u3055\u308c\u306a\u3044\u30c7\u30fc\u30bf\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u6700\u9069\u5316\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u3092\u5b9f\u88c5\u3059\u308b\u969b\u306f\u3001\u4ee5\u4e0b\u306e\u70b9\u306b\u6ce8\u610f\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#ffebeb;color:#f88080\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#f88080\"><i class=\"fas fa-exclamation\"><\/i><\/span><div class=\"sng-box-msg__title\">\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u306e\u6ce8\u610f\u70b9<\/div><\/div><div class=\"sng-box-msg__contents\">\n<ol class=\"wp-block-list\">\n<li>\u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u6709\u52b9\u671f\u9650\u3092\u9069\u5207\u306b\u8a2d\u5b9a\u3059\u308b<\/li>\n\n\n\n<li>\u30c7\u30fc\u30bf\u66f4\u65b0\u6642\u306b\u30ad\u30e3\u30c3\u30b7\u30e5\u3092\u9069\u5207\u306b\u7121\u52b9\u5316\u3059\u308b<\/li>\n\n\n\n<li>\u30ad\u30e3\u30c3\u30b7\u30e5\u30d2\u30c3\u30c8\u7387\u3092\u76e3\u8996\u3057\u3001\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u6226\u7565\u3092\u8abf\u6574\u3059\u308b<\/li>\n<\/ol>\n<\/div><\/div><\/div>\n\n\n\n<p>\u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u5c0e\u5165\u306b\u3088\u308a\u3001\u7e70\u308a\u8fd4\u3057\u30af\u30a8\u30ea\u306e\u5fdc\u7b54\u6642\u9593\u3092\u6700\u592795%\u77ed\u7e2e\u3067\u304d\u308b\u3053\u3068\u304c\u5831\u544a\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-30\">\u307e\u3068\u3081<\/h3>\n\n\n\n<p>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u306f\u3001GraphQL\u3092\u4f7f\u7528\u3057\u305fRuby on Rails\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u6210\u529f\u306b\u4e0d\u53ef\u6b20\u3067\u3059\u3002<br>N+1\u554f\u984c\u306e\u89e3\u6c7a\u3001\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u306e\u6d3b\u7528\u3001\u305d\u3057\u3066\u52b9\u679c\u7684\u306a\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u306e\u5b9f\u88c5\u306b\u3088\u308a\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u5fdc\u7b54\u6027\u3068\u30b9\u30b1\u30fc\u30e9\u30d3\u30ea\u30c6\u30a3\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af\u3092\u9069\u5207\u306b\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u30e6\u30fc\u30b6\u30fc\u30a8\u30af\u30b9\u30da\u30ea\u30a8\u30f3\u30b9\u3092\u5411\u4e0a\u3055\u305b\u3064\u3064\u3001\u30b5\u30fc\u30d0\u30fc\u30ea\u30bd\u30fc\u30b9\u3092\u52b9\u7387\u7684\u306b\u4f7f\u7528\u3067\u304d\u307e\u3059\u3002<br>\u305f\u3060\u3057\u3001\u6700\u9069\u5316\u3092\u884c\u3046\u969b\u306f\u3001\u30b3\u30fc\u30c9\u306e\u8907\u96d1\u6027\u3068\u306e\u30c8\u30ec\u30fc\u30c9\u30aa\u30d5\u3092\u5e38\u306b\u610f\u8b58\u3057\u3001\u9069\u5207\u306a\u30d0\u30e9\u30f3\u30b9\u3092\u53d6\u308b\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af\u3092\u8e0f\u307e\u3048\u305f\u4e0a\u3067\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u8a8d\u8a3c\u30fb\u8a8d\u53ef\u306e\u5b9f\u88c5\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-31\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u8a8d\u8a3c\u30fb\u8a8d\u53ef\u306e\u5b9f\u88c5<\/h2>\n\n\n\n<p>GraphQL\u3092\u4f7f\u7528\u3057\u305fRuby on Rails\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3067\u306f\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u304c\u6975\u3081\u3066\u91cd\u8981\u3067\u3059\u3002<br>\u9069\u5207\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u63aa\u7f6e\u306b\u3088\u308a\u3001\u30c7\u30fc\u30bf\u306e\u904e\u5270\u9732\u51fa\u3001\u30ea\u30bd\u30fc\u30b9\u306e\u904e\u5270\u6d88\u8cbb\u3001\u4e0d\u6b63\u30a2\u30af\u30bb\u30b9\u3001\u6a5f\u5bc6\u60c5\u5831\u306e\u6f0f\u6d29\u306a\u3069\u306e\u30ea\u30b9\u30af\u3092\u8efd\u6e1b\u3067\u304d\u307e\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001\u4e3b\u8981\u306a3\u3064\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-32\">GraphQL\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u306e\u4fdd\u8b77\u65b9\u6cd5<\/h3>\n\n\n\n<p>GraphQL\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092\u9069\u5207\u306b\u4fdd\u8b77\u3059\u308b\u3053\u3068\u306f\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u5168\u4f53\u7684\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3092\u78ba\u4fdd\u3059\u308b\u4e0a\u3067\u4e0d\u53ef\u6b20\u3067\u3059\u3002<br>\u4ee5\u4e0b\u306e\u65b9\u6cd5\u3092\u7d44\u307f\u5408\u308f\u305b\u3066\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3092\u304a\u52e7\u3081\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-33\">1. <strong>HTTPS \u306e\u4f7f\u7528<\/strong><\/h4>\n\n\n\n<p>\u5168\u3066\u306e\u901a\u4fe1\u3092HTTPS\u7d4c\u7531\u3067\u884c\u3046\u3088\u3046\u306b\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-34\">2. <strong>CSRF\u5bfe\u7b56<\/strong><\/h4>\n\n\n\n<p>Ruby on Rails\u306e\u7d44\u307f\u8fbc\u307f\u6a5f\u80fd\u3092\u4f7f\u7528\u3057\u3066CSRF\u5bfe\u7b56\u3092\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/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=\"\">   # app\/controllers\/graphql_controller.rb\n   class GraphqlController &lt; ApplicationController\n     protect_from_forgery with: :exception\n     # ...\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-35\">3. <strong>\u9069\u5207\u306aCORS\u8a2d\u5b9a<\/strong><\/h4>\n\n\n\n<p>\u30af\u30ed\u30b9\u30aa\u30ea\u30b8\u30f3\u30ea\u30af\u30a8\u30b9\u30c8\u3092\u9069\u5207\u306b\u5236\u5fa1\u3057\u307e\u3059\u3002<code>rack-cors<\/code> gem\u3092\u4f7f\u7528\u3057\u3066\u8a2d\u5b9a\u3067\u304d\u307e\u3059\u3002<\/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=\"\">   # config\/initializers\/cors.rb\n   Rails.application.config.middleware.insert_before 0, Rack::Cors do\n     allow do\n       origins 'https:\/\/your-frontend-domain.com'\n       resource '\/graphql', headers: :any, methods: [:post, :options]\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-36\">3. <strong>\u5165\u529b\u306e\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u3068\u30b5\u30cb\u30bf\u30a4\u30ba<\/strong><\/h4>\n\n\n\n<p>GraphQL\u306e\u578b\u30b7\u30b9\u30c6\u30e0\u3092\u6d3b\u7528\u3057\u3001\u5165\u529b\u5024\u3092\u9069\u5207\u306b\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u3057\u307e\u3059\u3002<\/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=\"\">   # app\/graphql\/types\/base_input_object.rb\n   module Types\n     class BaseInputObject &lt; GraphQL::Schema::InputObject\n       def self.sanitized_input(input)\n         # \u5165\u529b\u5024\u306e\u30b5\u30cb\u30bf\u30a4\u30ba\u30ed\u30b8\u30c3\u30af\u3092\u5b9f\u88c5\n       end\n     end\n   end<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-37\">\u30af\u30a8\u30ea\u306e\u8907\u96d1\u3055\u5236\u9650\u3068\u30ec\u30fc\u30c8\u5236\u9650\u306e\u8a2d\u5b9a<\/h3>\n\n\n\n<p>\u8907\u96d1\u306a\u30af\u30a8\u30ea\u3084\u30ea\u30af\u30a8\u30b9\u30c8\u306e\u983b\u5ea6\u3092\u5236\u9650\u3059\u308b\u3053\u3068\u3067\u3001DoS\u653b\u6483\u3092\u9632\u304e\u3001\u30ea\u30bd\u30fc\u30b9\u6d88\u8cbb\u3092\u5236\u5fa1\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-38\">\u30af\u30a8\u30ea\u306e\u8907\u96d1\u3055\u5236\u9650<\/h4>\n\n\n\n<p><code>graphql-query-complexity<\/code> gem\u3092\u4f7f\u7528\u3057\u3066\u3001\u30af\u30a8\u30ea\u306e\u8907\u96d1\u3055\u3092\u5236\u9650\u3067\u304d\u307e\u3059\u3002<\/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=\"\"># app\/graphql\/your_schema.rb\nclass YourSchema &lt; GraphQL::Schema\n  query_analyzer GraphQL::Analysis::QueryComplexity.new do |query, complexity|\n    max_complexity = 200\n    if complexity &gt; max_complexity\n      raise GraphQL::AnalysisError, \"\u30af\u30a8\u30ea\u306e\u8907\u96d1\u3055\uff08#{complexity}\uff09\u304c\u6700\u5927\u8a31\u5bb9\u5024\uff08#{max_complexity}\uff09\u3092\u8d85\u3048\u3066\u3044\u307e\u3059\"\n    end\n  end\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-39\">\u30ec\u30fc\u30c8\u5236\u9650<\/h4>\n\n\n\n<p><code>rack-attack<\/code> gem\u3092\u4f7f\u7528\u3057\u3066\u3001API\u30ea\u30af\u30a8\u30b9\u30c8\u306e\u30ec\u30fc\u30c8\u5236\u9650\u3092\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/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=\"\"># config\/initializers\/rack_attack.rb\nclass Rack::Attack\n  throttle('graphql\/ip', limit: 300, period: 5.minutes) do |req|\n    req.ip if req.path == '\/graphql'\n  end\nend<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-40\">\u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u3068\u30a2\u30af\u30bb\u30b9\u5236\u5fa1\u306e\u5b9f\u88c5\u4f8b<\/h3>\n\n\n\n<p>\u9069\u5207\u306a\u8a8d\u8a3c\u3068\u30a2\u30af\u30bb\u30b9\u5236\u5fa1\u3092\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u3001\u4e0d\u6b63\u30a2\u30af\u30bb\u30b9\u3092\u9632\u304e\u3001\u30e6\u30fc\u30b6\u30fc\u3054\u3068\u306b\u9069\u5207\u306a\u6a29\u9650\u3092\u5272\u308a\u5f53\u3066\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-41\">\u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c<\/h4>\n\n\n\n<p>JWT\u3092\u4f7f\u7528\u3057\u305f\u8a8d\u8a3c\u306e\u4f8b\u3092\u793a\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-42\">1. \u307e\u305a\u3001<code>jwt<\/code> gem\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\u3002<\/h4>\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=\"\"># Gemfile\ngem 'jwt'<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-43\">2. JWT\u30c8\u30fc\u30af\u30f3\u3092\u751f\u6210\u30fb\u691c\u8a3c\u3059\u308b\u30e2\u30b8\u30e5\u30fc\u30eb\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002<\/h4>\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=\"\"># app\/lib\/json_web_token.rb\nmodule JsonWebToken\n  SECRET_KEY = Rails.application.secrets.secret_key_base\n\n  def self.encode(payload, exp = 24.hours.from_now)\n    payload[:exp] = exp.to_i\n    JWT.encode(payload, SECRET_KEY)\n  end\n\n  def self.decode(token)\n    decoded = JWT.decode(token, SECRET_KEY)[0]\n    HashWithIndifferentAccess.new decoded\n  rescue\n    nil\n  end\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-44\">3. GraphQL\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u30fc\u3067\u8a8d\u8a3c\u3092\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/h4>\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=\"\"># app\/controllers\/graphql_controller.rb\nclass GraphqlController &lt; ApplicationController\n  def execute\n    context = {\n      current_user: current_user\n    }\n    result = YourSchema.execute(params[:query], context: context, variables: params[:variables])\n    render json: result\n  end\n\n  private\n\n  def current_user\n    header = request.headers['Authorization']\n    return nil if header.nil?\n\n    token = header.split(' ').last\n    decoded = JsonWebToken.decode(token)\n    return nil if decoded.nil?\n\n    User.find_by(id: decoded[:user_id])\n  end\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-45\">\u30a2\u30af\u30bb\u30b9\u5236\u5fa1<\/h4>\n\n\n\n<p>GraphQL\u306e\u30c7\u30a3\u30ec\u30af\u30c6\u30a3\u30d6\u3092\u4f7f\u7528\u3057\u305f\u30a2\u30af\u30bb\u30b9\u5236\u5fa1\u306e\u4f8b\u3092\u793a\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-46\">1. \u30ab\u30b9\u30bf\u30e0\u30c7\u30a3\u30ec\u30af\u30c6\u30a3\u30d6\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002<\/h4>\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=\"\"># app\/graphql\/directives\/authorize_directive.rb\nclass Directives::AuthorizeDirective &lt; GraphQL::Schema::Directive\n  description \"\u6307\u5b9a\u3055\u308c\u305f\u6a29\u9650\u3092\u6301\u3064\u30e6\u30fc\u30b6\u30fc\u306e\u307f\u304c\u30a2\u30af\u30bb\u30b9\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u307e\u3059\"\n  argument :role, String, required: true\n\n  def self.resolve(object, arguments, context)\n    user = context[:current_user]\n    return nil if user.nil? || user.role != arguments[:role]\n    yield\n  end\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-47\">2. \u30b9\u30ad\u30fc\u30de\u306b\u30c7\u30a3\u30ec\u30af\u30c6\u30a3\u30d6\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/h4>\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=\"\"># app\/graphql\/your_schema.rb\nclass YourSchema &lt; GraphQL::Schema\n  directive(Directives::AuthorizeDirective)\n  # ...\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-48\">3. \u30d5\u30a3\u30fc\u30eb\u30c9\u306b\u30c7\u30a3\u30ec\u30af\u30c6\u30a3\u30d6\u3092\u9069\u7528\u3057\u307e\u3059\u3002<\/h4>\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=\"\"># app\/graphql\/types\/query_type.rb\nmodule Types\n  class QueryType &lt; Types::BaseObject\n    field :sensitive_data, String, null: false do\n      directive :authorize, role: \"admin\"\n    end\n\n    def sensitive_data\n      \"This is sensitive information\"\n    end\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u308c\u306b\u3088\u308a\u3001\u201dadmin\u201d \u30ed\u30fc\u30eb\u3092\u6301\u3064\u30e6\u30fc\u30b6\u30fc\u306e\u307f\u304c <code>sensitiveData<\/code> \u30d5\u30a3\u30fc\u30eb\u30c9\u306b\u30a2\u30af\u30bb\u30b9\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-49\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-50\">1. <strong>\u5b9a\u671f\u7684\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u76e3\u67fb<\/strong><\/h4>\n\n\n\n<p>\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u8106\u5f31\u6027\u3092\u5b9a\u671f\u7684\u306b\u30c1\u30a7\u30c3\u30af\u3057\u3001\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u5bfe\u7b56\u3092\u8b1b\u3058\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-51\">2. <strong>\u4f9d\u5b58\u30e9\u30a4\u30d6\u30e9\u30ea\u306e\u6700\u65b0\u5316<\/strong><\/h4>\n\n\n\n<p><code>bundle audit<\/code> \u3092\u5b9a\u671f\u7684\u306b\u5b9f\u884c\u3057\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8106\u5f31\u6027\u304c\u5831\u544a\u3055\u308c\u3066\u3044\u308bgem\u3092\u66f4\u65b0\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-52\">3. <strong>\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u306e\u9069\u5207\u306a\u51e6\u7406<\/strong><\/h4>\n\n\n\n<p>\u672c\u756a\u74b0\u5883\u3067\u306f\u8a73\u7d30\u306a\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u5916\u90e8\u306b\u6f0f\u3089\u3055\u306a\u3044\u3088\u3046\u306b\u3057\u307e\u3059\u3002<\/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=\"\"># app\/graphql\/your_schema.rb\nclass YourSchema &lt; GraphQL::Schema\n  def self.unauthorized_object(error)\n    raise GraphQL::ExecutionError, \"\u6a29\u9650\u304c\u3042\u308a\u307e\u305b\u3093\"\n  end\n\n  def self.type_error(err, context)\n    if Rails.env.development?\n      super\n    else\n      raise GraphQL::ExecutionError, \"\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u307e\u3057\u305f\"\n    end\n  end\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-53\">4. <strong>\u672c\u756a\u74b0\u5883\u3067\u306eGraphiQL\u306e\u7121\u52b9\u5316<\/strong><\/h4>\n\n\n\n<p>\u958b\u767a\u30c4\u30fc\u30eb\u3078\u306e\u30a2\u30af\u30bb\u30b9\u3092\u5236\u9650\u3057\u307e\u3059\u3002<\/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=\"\"># config\/routes.rb\nRails.application.routes.draw do\n  post \"\/graphql\", to: \"graphql#execute\"\n  if Rails.env.development?\n    mount GraphiQL::Rails::Engine, at: \"\/graphiql\", graphql_path: \"\/graphql\"\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u8a8d\u8a3c\u30fb\u8a8d\u53ef\u306e\u5b9f\u88c5\u3092\u9069\u5207\u306b\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001GraphQL\u3092\u4f7f\u7528\u3057\u305fRuby on Rails\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u305f\u3060\u3057\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u306f\u7d99\u7d9a\u7684\u306a\u30d7\u30ed\u30bb\u30b9\u3067\u3042\u308a\u3001\u65b0\u305f\u306a\u8105\u5a01\u3084\u8106\u5f31\u6027\u306b\u5e38\u306b\u6ce8\u610f\u3092\u6255\u3044\u3001\u9069\u5207\u306b\u5bfe\u5fdc\u3057\u3066\u3044\u304f\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3092\u8e0f\u307e\u3048\u305f\u4e0a\u3067\u3001\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306eGraphQL\u6d3b\u7528\u4e8b\u4f8b\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-54\">\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306eGraphQL\u6d3b\u7528\u4e8b\u4f8b<\/h2>\n\n\n\n<p>\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u304a\u3044\u3066GraphQL\u3092\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u8907\u96d1\u306a\u30c7\u30fc\u30bf\u8981\u4ef6\u3092\u52b9\u7387\u7684\u306b\u51e6\u7406\u3057\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3068\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u306e\u5206\u96e2\u3092\u4fc3\u9032\u3057\u3001API\u306e\u9032\u5316\u306b\u67d4\u8edf\u306b\u5bfe\u5fdc\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001GraphQL\u3092\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u6d3b\u7528\u3059\u308b\u65b9\u6cd5\u3068\u3001\u5b9f\u969b\u306e\u4e8b\u4f8b\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-55\">\u30de\u30a4\u30af\u30ed\u30b5\u30fc\u30d3\u30b9\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u3068GraphQL\u306e\u7d71\u5408<\/h3>\n\n\n\n<p>\u30de\u30a4\u30af\u30ed\u30b5\u30fc\u30d3\u30b9\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u3068GraphQL\u3092\u7d71\u5408\u3059\u308b\u3053\u3068\u3067\u3001\u8907\u6570\u306e\u30b5\u30fc\u30d3\u30b9\u304b\u3089\u306e\u30c7\u30fc\u30bf\u3092\u52b9\u7387\u7684\u306b\u96c6\u7d04\u3057\u3001\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306b\u63d0\u4f9b\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u4e3b\u306a\u30a2\u30d7\u30ed\u30fc\u30c1\u3068\u3057\u3066\u3001API Gateway\u3001Schema Stitching\u3001Federation\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-56\">Apollo Federation<\/h4>\n\n\n\n<p>Apollo Federation\u306f\u3001\u8907\u6570\u306eGraphQL\u30b5\u30fc\u30d3\u30b9\u3092\u5358\u4e00\u306eGraphQL\u30b9\u30ad\u30fc\u30de\u306b\u7d71\u5408\u3059\u308b\u5f37\u529b\u306a\u65b9\u6cd5\u3067\u3059\u3002<br>Ruby on Rails\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306f\u3001<code>apollo-federation-ruby<\/code> gem\u3092\u4f7f\u7528\u3057\u3066\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/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=\"\"># app\/graphql\/types\/user_type.rb\nclass Types::UserType &lt; Types::BaseObject\n  key fields: 'id'\n\n  field :id, ID, null: false\n  field :name, String, null: false\n\n  def self.resolve_reference(reference, context)\n    User.find(reference[:id])\n  end\nend\n\n# app\/graphql\/your_schema.rb\nclass YourSchema &lt; GraphQL::Schema\n  include ApolloFederation::Schema\n\n  query Types::QueryType\n  # ...\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u30a2\u30d7\u30ed\u30fc\u30c1\u306b\u3088\u308a\u3001\u5404\u30de\u30a4\u30af\u30ed\u30b5\u30fc\u30d3\u30b9\u304c\u72ec\u81ea\u306eGraphQL\u30b9\u30ad\u30fc\u30de\u3092\u6301\u3061\u3064\u3064\u3001\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306b\u306f\u5358\u4e00\u306e\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092\u63d0\u4f9b\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#b4e0fa;color:#009EF3\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#009EF3\"><i class=\"far fa-lightbulb\"><\/i><\/span><div class=\"sng-box-msg__title\">\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/div><\/div><div class=\"sng-box-msg__contents\">\n<ul class=\"wp-block-list\">\n<li>\u30b5\u30fc\u30d3\u30b9\u5883\u754c\u3092\u660e\u78ba\u306b\u5b9a\u7fa9\u3057\u3001\u91cd\u8907\u3092\u6700\u5c0f\u9650\u306b\u6291\u3048\u308b<\/li>\n\n\n\n<li>\u5171\u901a\u578b\u306e\u7ba1\u7406\u3092\u614e\u91cd\u306b\u884c\u3044\u3001\u4e00\u8cab\u6027\u3092\u4fdd\u3064<\/li>\n\n\n\n<li>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u7d99\u7d9a\u7684\u306b\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3057\u3001\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u6700\u9069\u5316\u3092\u884c\u3046<\/li>\n<\/ul>\n<\/div><\/div><\/div>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-57\">\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u958b\u767a\u8005\u3068\u306e\u5354\u696d\u306b\u3088\u308bAPI\u8a2d\u8a08\u306e\u6700\u9069\u5316<\/h3>\n\n\n\n<p>GraphQL\u306e\u67d4\u8edf\u6027\u3092\u6700\u5927\u9650\u306b\u6d3b\u304b\u3059\u306b\u306f\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u958b\u767a\u8005\u3068\u306e\u7dca\u5bc6\u306a\u5354\u529b\u304c\u4e0d\u53ef\u6b20\u3067\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-58\">\u30b9\u30ad\u30fc\u30de\u99c6\u52d5\u958b\u767a<\/h4>\n\n\n\n<p>\u30b9\u30ad\u30fc\u30de\u99c6\u52d5\u958b\u767a\u306f\u3001GraphQL\u30b9\u30ad\u30fc\u30de\u3092\u8a2d\u8a08\u306e\u4e2d\u5fc3\u306b\u636e\u3048\u308b\u30a2\u30d7\u30ed\u30fc\u30c1\u3067\u3059\u3002\u4ee5\u4e0b\u306e\u30b9\u30c6\u30c3\u30d7\u3067\u5b9f\u65bd\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u8981\u4ef6\u306e\u8a73\u7d30\u306a\u30d2\u30a2\u30ea\u30f3\u30b0<\/li>\n\n\n\n<li>\u30b9\u30ad\u30fc\u30de\u306e\u521d\u671f\u8a2d\u8a08<\/li>\n\n\n\n<li>\u30e2\u30c3\u30af\u30b5\u30fc\u30d0\u30fc\u306e\u69cb\u7bc9<\/li>\n\n\n\n<li>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u958b\u767a\u3068\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u958b\u767a\u306e\u4e26\u884c\u9032\u884c<\/li>\n\n\n\n<li>\u7d99\u7d9a\u7684\u306a\u30d5\u30a3\u30fc\u30c9\u30d0\u30c3\u30af\u3068\u6539\u5584<\/li>\n<\/ol>\n\n\n\n<p>\u3053\u306e\u65b9\u6cd5\u306b\u3088\u308a\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3068\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u306e\u30c1\u30fc\u30e0\u304c\u52b9\u7387\u7684\u306b\u5354\u696d\u3057\u3001\u4e00\u8cab\u6027\u306e\u3042\u308bAPI\u3092\u8a2d\u8a08\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-59\">\u30c4\u30fc\u30eb\u306e\u6d3b\u7528<\/h4>\n\n\n\n<p>\u4ee5\u4e0b\u306e\u30c4\u30fc\u30eb\u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u5354\u696d\u30d7\u30ed\u30bb\u30b9\u3092\u5186\u6ed1\u5316\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>GraphQL Playground<\/strong>: \u5bfe\u8a71\u7684\u306b\u30af\u30a8\u30ea\u3092\u8a66\u305b\u308bIDE<\/li>\n\n\n\n<li><strong>Apollo Studio<\/strong>: \u30b9\u30ad\u30fc\u30de\u7ba1\u7406\u3068\u5206\u6790\u306e\u305f\u3081\u306e\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0<\/li>\n\n\n\n<li><strong>Postman<\/strong>: API\u30c6\u30b9\u30c8\u3068\u6587\u66f8\u5316\u306e\u305f\u3081\u306e\u30c4\u30fc\u30eb<\/li>\n<\/ul>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30c4\u30fc\u30eb\u3092\u4f7f\u7528\u3057\u3066\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u958b\u767a\u8005\u306fAPI\u306e\u52d5\u4f5c\u3092\u78ba\u8a8d\u3057\u3001\u30d5\u30a3\u30fc\u30c9\u30d0\u30c3\u30af\u3092\u63d0\u4f9b\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#b4e0fa;color:#009EF3\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#009EF3\"><i class=\"far fa-lightbulb\"><\/i><\/span><div class=\"sng-box-msg__title\">\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/div><\/div><div class=\"sng-box-msg__contents\">\n<ul class=\"wp-block-list\">\n<li>\u65e9\u671f\u306e\u30d7\u30ed\u30c8\u30bf\u30a4\u30d4\u30f3\u30b0\u3092\u884c\u3044\u3001\u8a2d\u8a08\u306e\u554f\u984c\u3092\u65e9\u671f\u306b\u767a\u898b\u3059\u308b<\/li>\n\n\n\n<li>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u8981\u4ef6\u3092\u4e01\u5be7\u306b\u30d2\u30a2\u30ea\u30f3\u30b0\u3057\u3001\u30e6\u30fc\u30b9\u30b1\u30fc\u30b9\u3092\u5341\u5206\u306b\u7406\u89e3\u3059\u308b<\/li>\n\n\n\n<li>\u5b9a\u671f\u7684\u306aAPI\u8a2d\u8a08\u30ec\u30d3\u30e5\u30fc\u3092\u5b9f\u65bd\u3057\u3001\u5168\u4f53\u306e\u4e00\u8cab\u6027\u3092\u4fdd\u3064<\/li>\n<\/ul>\n<\/div><\/div><\/div>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-60\">GraphQL\u30b9\u30ad\u30fc\u30de\u8a2d\u8a08\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3068\u9032\u5316\u306e\u7ba1\u7406<\/h3>\n\n\n\n<p>\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306f\u3001\u9069\u5207\u306a\u30b9\u30ad\u30fc\u30de\u8a2d\u8a08\u3068\u9032\u5316\u306e\u7ba1\u7406\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-61\">\u30b9\u30ad\u30fc\u30de\u8a2d\u8a08\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h4>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-62\">1. <strong>\u547d\u540d\u898f\u5247\u306e\u4e00\u8cab\u6027<\/strong><\/h4>\n\n\n\n<p>\u30ad\u30e3\u30e1\u30eb\u30b1\u30fc\u30b9\u3068\u30b9\u30cd\u30fc\u30af\u30b1\u30fc\u30b9\u306e\u6df7\u5728\u3092\u907f\u3051\u3001\u4e00\u8cab\u3057\u305f\u547d\u540d\u898f\u5247\u3092\u63a1\u7528\u3059\u308b\u3002<\/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=\"\">type User {\n  id: ID!\n  firstName: String!\n  lastName: String!\n  emailAddress: String!\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-63\">2. <strong>\u9069\u5207\u306a\u62bd\u8c61\u5316\u30ec\u30d9\u30eb<\/strong><\/h4>\n\n\n\n<p>\u904e\u5ea6\u306b\u7d30\u304b\u3044\u578b\u5b9a\u7fa9\u3092\u907f\u3051\u3001\u9069\u5207\u306a\u62bd\u8c61\u5316\u3092\u884c\u3046\u3002<\/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=\"\">type Order {\n  id: ID!\n  customer: User!\n  items: [OrderItem!]!\n  totalAmount: Money!\n}\n\ntype Money {\n  amount: Float!\n  currency: String!\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-64\">3. <strong>Nullability\u306e\u614e\u91cd\u306a\u6271\u3044<\/strong><\/h4>\n\n\n\n<p>\u5fc5\u9808\u30d5\u30a3\u30fc\u30eb\u30c9\u3068\u7701\u7565\u53ef\u80fd\u30d5\u30a3\u30fc\u30eb\u30c9\u3092\u660e\u78ba\u306b\u533a\u5225\u3059\u308b\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-65\">4. <strong>Connection\u30d1\u30bf\u30fc\u30f3\u306e\u6d3b\u7528<\/strong><\/h4>\n\n\n\n<p>\u30da\u30fc\u30b8\u30cd\u30fc\u30b7\u30e7\u30f3\u3084\u30ea\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u6271\u3044\u3092\u7d71\u4e00\u3059\u308b\u3002<\/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=\"\">field :posts, Types::PostType.connection_type, null: false<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-66\">5. <strong>\u30ab\u30b9\u30bf\u30e0\u30b9\u30ab\u30e9\u30fc\u306e\u9069\u5207\u306a\u4f7f\u7528<\/strong><\/h4>\n\n\n\n<p>\u65e5\u4ed8\u3084\u901a\u8ca8\u306a\u3069\u306e\u7279\u6b8a\u306a\u578b\u3092\u30ab\u30b9\u30bf\u30e0\u30b9\u30ab\u30e9\u30fc\u3068\u3057\u3066\u5b9a\u7fa9\u3059\u308b\u3002<\/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=\"\">class Types::DateType &lt; GraphQL::Schema::Scalar\n  def self.coerce_input(value, context)\n    Date.parse(value)\n  rescue Date::Error\n    raise GraphQL::CoercionError, \"Invalid date format\"\n  end\n\n  def self.coerce_result(value, context)\n    value.iso8601\n  end\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-67\">\u30b9\u30ad\u30fc\u30de\u306e\u9032\u5316\u3068\u7ba1\u7406<\/h4>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-68\">1. <strong>\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u6226\u7565<\/strong><\/h4>\n\n\n\n<p>\u660e\u793a\u7684\u306a\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u306f\u907f\u3051\u3001\u6bb5\u968e\u7684\u306a\u9032\u5316\u3092\u63a1\u7528\u3059\u308b\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-69\">2. <strong>\u975e\u63a8\u5968\u30d5\u30a3\u30fc\u30eb\u30c9\u306e\u7ba1\u7406<\/strong><\/h4>\n\n\n\n<p>\u524a\u9664\u4e88\u5b9a\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\u306b\u306f<code>@deprecated<\/code>\u30c7\u30a3\u30ec\u30af\u30c6\u30a3\u30d6\u3092\u4f7f\u7528\u3059\u308b\u3002<\/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=\"\">type User {\n  id: ID!\n  name: String! @deprecated(reason: \"Use firstName and lastName instead\")\n  firstName: String!\n  lastName: String!\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-70\">3. <strong>\u30b9\u30ad\u30fc\u30de\u5909\u66f4\u306e\u5f71\u97ff\u5206\u6790<\/strong><\/h4>\n\n\n\n<p>\u5909\u66f4\u524d\u306b\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3078\u306e\u5f71\u97ff\u3092\u5341\u5206\u306b\u5206\u6790\u3059\u308b\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-71\">\u5b9f\u969b\u306e\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306e\u6d3b\u7528\u4e8b\u4f8b<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>GitHub<\/strong>: REST API\u304b\u3089GraphQL\u3078\u306e\u79fb\u884c\u3092\u884c\u3044\u3001API\u306e\u67d4\u8edf\u6027\u3068\u52b9\u7387\u6027\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u307e\u3057\u305f\u3002<\/li>\n\n\n\n<li><strong>Shopify<\/strong>: \u5927\u898f\u6a21EC\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u306bGraphQL\u3092\u5c0e\u5165\u3057\u3001\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u6027\u306e\u9ad8\u3044API\u3092\u63d0\u4f9b\u3057\u3066\u3044\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>Airbnb<\/strong>: \u30de\u30a4\u30af\u30ed\u30b5\u30fc\u30d3\u30b9\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u3068GraphQL\u3092\u7d71\u5408\u3057\u3001\u8907\u96d1\u306a\u5bbf\u6cca\u4e88\u7d04\u30b7\u30b9\u30c6\u30e0\u3092\u52b9\u7387\u7684\u306b\u904b\u7528\u3057\u3066\u3044\u307e\u3059\u3002<\/li>\n<\/ol>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u4f01\u696d\u306f\u3001GraphQL\u306e\u63a1\u7528\u306b\u3088\u308a\u3001API\u958b\u767a\u306e\u52b9\u7387\u5316\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3068\u306e\u5354\u696d\u6539\u5584\u3001\u305d\u3057\u3066\u30e6\u30fc\u30b6\u30fc\u30a8\u30af\u30b9\u30da\u30ea\u30a8\u30f3\u30b9\u306e\u5411\u4e0a\u3092\u5b9f\u73fe\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-72\">\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306eGraphQL\u6d3b\u7528\u306b\u304a\u3051\u308b\u8ab2\u984c\u3068\u89e3\u6c7a\u7b56<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9<\/strong>: Dataloader\u3068Batching\u3092\u6d3b\u7528\u3057\u3001N+1\u554f\u984c\u3092\u89e3\u6c7a\u3059\u308b<\/li>\n\n\n\n<li><strong>\u8a8d\u8a3c\u3068\u8a8d\u53ef<\/strong>: \u30c7\u30a3\u30ec\u30af\u30c6\u30a3\u30d6\u3068\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u3092\u7d44\u307f\u5408\u308f\u305b\u3066\u3001\u7d30\u7c92\u5ea6\u306e\u30a2\u30af\u30bb\u30b9\u5236\u5fa1\u3092\u5b9f\u73fe\u3059\u308b<\/li>\n\n\n\n<li><strong>\u30b9\u30ad\u30fc\u30de\u8a2d\u8a08\u306e\u8907\u96d1\u3055<\/strong>: \u30c9\u30e1\u30a4\u30f3\u99c6\u52d5\u8a2d\u8a08\u3092\u9069\u7528\u3057\u3001\u30d3\u30b8\u30cd\u30b9\u30ed\u30b8\u30c3\u30af\u3092\u9069\u5207\u306b\u53cd\u6620\u3057\u305f\u30b9\u30ad\u30fc\u30de\u3092\u8a2d\u8a08\u3059\u308b<\/li>\n<\/ol>\n\n\n\n<p>GraphQL\u3092\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u8907\u96d1\u306a\u30c7\u30fc\u30bf\u8981\u4ef6\u3092\u52b9\u7387\u7684\u306b\u51e6\u7406\u3057\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u958b\u767a\u8005\u3068\u306e\u5354\u696d\u3092\u5186\u6ed1\u306b\u3057\u3001\u67d4\u8edf\u3067\u9032\u5316\u53ef\u80fd\u306aAPI\u3092\u63d0\u4f9b\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u9069\u5207\u306a\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u8a2d\u8a08\u3001\u30c4\u30fc\u30eb\u306e\u6d3b\u7528\u3001\u305d\u3057\u3066\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u306e\u9069\u7528\u306b\u3088\u308a\u3001GraphQL\u306e\u5229\u70b9\u3092\u6700\u5927\u9650\u306b\u5f15\u304d\u51fa\u3059\u3053\u3068\u304c\u3067\u304d\u308b\u3067\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001REST\u304b\u3089GraphQL\u3078\u306e\u79fb\u884c\u6226\u7565\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3059\u3002<br>\u65e2\u5b58\u306eRESTfulAPI\u3092\u6301\u3064\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u304c\u3069\u306e\u3088\u3046\u306bGraphQL\u3092\u5c0e\u5165\u3057\u3001\u6bb5\u968e\u7684\u306b\u79fb\u884c\u3057\u3066\u3044\u304f\u304b\u3092\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-73\">REST\u304b\u3089GraphQL\u3078\u306e\u79fb\u884c\u6226\u7565<\/h2>\n\n\n\n<p>\u65e2\u5b58\u306eREST API\u3092GraphQL\u306b\u79fb\u884c\u3059\u308b\u3053\u3068\u3067\u3001\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306e\u67d4\u8edf\u6027\u5411\u4e0a\u3001\u30aa\u30fc\u30d0\u30fc\u30d5\u30a7\u30c3\u30c1\u3068\u30a2\u30f3\u30c0\u30fc\u30d5\u30a7\u30c3\u30c1\u306e\u89e3\u6d88\u3001API\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u306e\u7c21\u7d20\u5316\u306a\u3069\u3001\u591a\u304f\u306e\u5229\u70b9\u3092\u5f97\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001Ruby on Rails\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067REST\u304b\u3089GraphQL\u3078\u79fb\u884c\u3059\u308b\u969b\u306e\u6226\u7565\u3068\u5b9f\u8df5\u7684\u306a\u30a2\u30d7\u30ed\u30fc\u30c1\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-74\">\u6bb5\u968e\u7684\u306a\u79fb\u884c\u30d7\u30ed\u30bb\u30b9\u306e\u8a2d\u8a08\u3068\u5b9f\u88c5<\/h3>\n\n\n\n<p>REST\u304b\u3089GraphQL\u3078\u306e\u79fb\u884c\u306f\u3001\u4e00\u671d\u4e00\u5915\u306b\u306f\u884c\u3048\u307e\u305b\u3093\u3002<br>\u6bb5\u968e\u7684\u306a\u30a2\u30d7\u30ed\u30fc\u30c1\u3092\u53d6\u308b\u3053\u3068\u3067\u3001\u30ea\u30b9\u30af\u3092\u6700\u5c0f\u9650\u306b\u6291\u3048\u3064\u3064\u3001\u30b9\u30e0\u30fc\u30ba\u306a\u79fb\u884c\u3092\u5b9f\u73fe\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-75\">1. <strong>\u65e2\u5b58API\u306e\u5206\u6790\u3068\u8a55\u4fa1<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u73fe\u5728\u306eREST API\u306e\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u3068\u3001\u305d\u306e\u30c7\u30fc\u30bf\u69cb\u9020\u3092\u8a73\u7d30\u306b\u5206\u6790\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u983b\u7e41\u306b\u4f7f\u7528\u3055\u308c\u308b\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3084\u3001\u8907\u6570\u306e\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092\u7d44\u307f\u5408\u308f\u305b\u3066\u4f7f\u7528\u3057\u3066\u3044\u308b\u30b1\u30fc\u30b9\u3092\u7279\u5b9a\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-76\">2. <strong>GraphQL\u30b9\u30ad\u30fc\u30de\u306e\u8a2d\u8a08<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5206\u6790\u7d50\u679c\u3092\u57fa\u306b\u3001GraphQL\u30b9\u30ad\u30fc\u30de\u3092\u8a2d\u8a08\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u65e2\u5b58\u306e\u30c7\u30fc\u30bf\u30e2\u30c7\u30eb\u3092\u6d3b\u304b\u3057\u3064\u3064\u3001GraphQL\u306e\u5229\u70b9\u3092\u6700\u5927\u9650\u306b\u6d3b\u7528\u3067\u304d\u308b\u69cb\u9020\u3092\u8003\u3048\u307e\u3059\u3002<\/li>\n<\/ul>\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=\"\">   # app\/graphql\/types\/user_type.rb\n   module Types\n     class UserType &lt; Types::BaseObject\n       field :id, ID, null: false\n       field :name, String, null: false\n       field :email, String, null: false\n       field :posts, [Types::PostType], null: false\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-77\">3. <strong>\u90e8\u5206\u7684\u306aGraphQL\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u6700\u3082\u4fa1\u5024\u306e\u9ad8\u3044\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u304b\u3089\u9806\u306b\u3001GraphQL\u3078\u306e\u79fb\u884c\u3092\u958b\u59cb\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u65e2\u5b58\u306e\u30d3\u30b8\u30cd\u30b9\u30ed\u30b8\u30c3\u30af\u3092\u518d\u5229\u7528\u3057\u3001GraphQL\u30ea\u30be\u30eb\u30d0\u30fc\u3068\u3057\u3066\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\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=\"\">   # app\/graphql\/types\/query_type.rb\n   module Types\n     class QueryType &lt; Types::BaseObject\n       field :user, Types::UserType, null: true do\n         argument :id, ID, required: true\n       end\n\n       def user(id:)\n         User.find(id)\n       end\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-78\">4. <strong>\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306e\u6bb5\u968e\u7684\u79fb\u884c<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u65b0\u3057\u3044GraphQL\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092\u4f7f\u7528\u3059\u308b\u3088\u3046\u306b\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3092\u5f90\u3005\u306b\u66f4\u65b0\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u3053\u306e\u904e\u7a0b\u3067\u3001GraphQL\u306e\u5229\u70b9\uff08\u5fc5\u8981\u306a\u30c7\u30fc\u30bf\u306e\u307f\u306e\u53d6\u5f97\u3001\u8907\u6570\u30ea\u30bd\u30fc\u30b9\u306e\u540c\u6642\u53d6\u5f97\u306a\u3069\uff09\u3092\u6d3b\u304b\u3057\u305f\u30ea\u30d5\u30a1\u30af\u30bf\u30ea\u30f3\u30b0\u3092\u884c\u3044\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-79\">5. <strong>\u30ec\u30ac\u30b7\u30fcAPI\u306e\u6bb5\u968e\u7684\u5ec3\u6b62<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u3059\u3079\u3066\u306e\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u304cGraphQL\u306b\u79fb\u884c\u3057\u305f\u3053\u3068\u3092\u78ba\u8a8d\u5f8c\u3001\u53e4\u3044REST\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092\u6bb5\u968e\u7684\u306b\u5ec3\u6b62\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u5ec3\u6b62\u4e88\u5b9a\u306e\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u306b\u306f\u9069\u5207\u306a\u8b66\u544a\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u4ed8\u4e0e\u3057\u3001\u5341\u5206\u306a\u79fb\u884c\u671f\u9593\u3092\u8a2d\u3051\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-80\">\u65e2\u5b58\u306eREST\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3068GraphQL\u306e\u5171\u5b58\u30c6\u30af\u30cb\u30c3\u30af<\/h3>\n\n\n\n<p>\u79fb\u884c\u671f\u9593\u4e2d\u306f\u3001REST\u3068GraphQL\u306eAPI\u3092\u5171\u5b58\u3055\u305b\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<br>\u4ee5\u4e0b\u306e\u30c6\u30af\u30cb\u30c3\u30af\u3092\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u30b9\u30e0\u30fc\u30ba\u306a\u5171\u5b58\u3068\u6bb5\u968e\u7684\u306a\u79fb\u884c\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-81\">1. <strong>GraphQL\u30b2\u30fc\u30c8\u30a6\u30a7\u30a4\u306e\u6d3b\u7528<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>GraphQL\u30b2\u30fc\u30c8\u30a6\u30a7\u30a4\u3092\u5c0e\u5165\u3057\u3001\u65e2\u5b58\u306eREST\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092GraphQL\u30b9\u30ad\u30fc\u30de\u306b\u30de\u30c3\u30d4\u30f3\u30b0\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>Apollo Federation\u3084GraphQL Gateway\u306a\u3069\u306e\u30c4\u30fc\u30eb\u3092\u4f7f\u7528\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-82\">2. <strong>REST\u30e9\u30c3\u30d1\u30fc\u306e\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u65e2\u5b58\u306eREST\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092GraphQL\u30ea\u30be\u30eb\u30d0\u30fc\u5185\u3067\u30e9\u30c3\u30d7\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\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=\"\">   # app\/graphql\/types\/query_type.rb\n   field :legacy_data, Types::LegacyDataType, null: false do\n     argument :id, ID, required: true\n   end\n\n   def legacy_data(id:)\n     response = HTTP.get(\"https:\/\/api.example.com\/v1\/legacy_data\/#{id}\")\n     JSON.parse(response.body)\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-83\">3. <strong>\u30cf\u30a4\u30d6\u30ea\u30c3\u30c9\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u306e\u4f5c\u6210<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5358\u4e00\u306e\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3067\u3001REST\u3068GraphQL\u306e\u4e21\u65b9\u306e\u30ea\u30af\u30a8\u30b9\u30c8\u3092\u51e6\u7406\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u30ea\u30af\u30a8\u30b9\u30c8\u306e\u5185\u5bb9\u306b\u5fdc\u3058\u3066\u3001\u9069\u5207\u306a\u30cf\u30f3\u30c9\u30e9\u30fc\u306b\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\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=\"\">   # config\/routes.rb\n   post '\/api', to: 'api#handle'\n\n   # app\/controllers\/api_controller.rb\n   class ApiController &lt; ApplicationController\n     def handle\n       if params[:query].present?\n         result = Schema.execute(params[:query], variables: params[:variables])\n         render json: result\n       else\n         # RESTful API logic\n       end\n     end\n   end<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-84\">\u79fb\u884c\u5f8c\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6539\u5584\u3068\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u65b9\u6cd5<\/h3>\n\n\n\n<p>GraphQL\u3078\u306e\u79fb\u884c\u5f8c\u306f\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u6700\u9069\u5316\u3068\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u304c\u91cd\u8981\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-85\">1. <strong>N+1\u554f\u984c\u306e\u89e3\u6c7a<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li><code>graphql-batch<\/code> gem\u3092\u4f7f\u7528\u3057\u3066\u3001\u52b9\u7387\u7684\u306a\u30c7\u30fc\u30bf\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\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=\"\">   # app\/graphql\/loaders\/association_loader.rb\n   class AssociationLoader &lt; GraphQL::Batch::Loader\n     def initialize(model, association_name)\n       @model = model\n       @association_name = association_name\n     end\n\n     def perform(record_ids)\n       records = @model.where(id: record_ids).includes(@association_name)\n       records.each { |record| fulfill(record.id, record.public_send(@association_name)) }\n       record_ids.each { |id| fulfill(id, nil) unless fulfilled?(id) }\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-86\">2. <strong>\u30af\u30a8\u30ea\u8907\u96d1\u6027\u306e\u5236\u9650<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li><code>graphql-query-complexity<\/code> gem\u3092\u4f7f\u7528\u3057\u3066\u3001\u8907\u96d1\u306a\u30af\u30a8\u30ea\u306b\u3088\u308b\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u4f4e\u4e0b\u3092\u9632\u304e\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-87\">3. <strong>\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u30c4\u30fc\u30eb\u306e\u5c0e\u5165<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Apollo Studio\u3084New Relic GraphQL monitoring\u3092\u4f7f\u7528\u3057\u3066\u3001\u30af\u30a8\u30ea\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3068\u4f7f\u7528\u50be\u5411\u3092\u76e3\u8996\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u30ab\u30b9\u30bf\u30e0\u30ed\u30b0\u89e3\u6790\u3092\u5b9f\u88c5\u3057\u3001\u7279\u5b9a\u306e\u30af\u30a8\u30ea\u30d1\u30bf\u30fc\u30f3\u3084\u6027\u80fd\u554f\u984c\u3092\u691c\u51fa\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-88\">\u79fb\u884c\u4e8b\u4f8b\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>GitHub<\/strong>: \u5927\u898f\u6a21\u306aREST API\u304b\u3089GraphQL\u3078\u306e\u79fb\u884c\u3092\u6bb5\u968e\u7684\u306b\u884c\u3044\u3001\u958b\u767a\u8005\u4f53\u9a13\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u307e\u3057\u305f\u3002<\/li>\n\n\n\n<li><strong>Shopify<\/strong>: REST\u3068GraphQL\u3092\u4e26\u884c\u904b\u7528\u3057\u306a\u304c\u3089\u3001\u6bb5\u968e\u7684\u306b\u79fb\u884c\u3092\u9032\u3081\u3066\u3044\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#b4e0fa;color:#009EF3\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#009EF3\"><i class=\"far fa-lightbulb\"><\/i><\/span><div class=\"sng-box-msg__title\">\u79fb\u884c\u3092\u6210\u529f\u3055\u305b\u308b\u305f\u3081\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/div><\/div><div class=\"sng-box-msg__contents\">\n<ol class=\"wp-block-list\">\n<li>\u6bb5\u968e\u7684\u30a2\u30d7\u30ed\u30fc\u30c1\u3092\u63a1\u7528\u3057\u3001\u30ea\u30b9\u30af\u3092\u6700\u5c0f\u9650\u306b\u6291\u3048\u308b<\/li>\n\n\n\n<li>\u5341\u5206\u306a\u30c6\u30b9\u30c8\u30ab\u30d0\u30ec\u30c3\u30b8\u3092\u78ba\u4fdd\u3057\u3001\u79fb\u884c\u306b\u3088\u308b\u6a5f\u80fd\u9000\u884c\u3092\u9632\u3050<\/li>\n\n\n\n<li>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30c1\u30fc\u30e0\u3068\u5bc6\u63a5\u306b\u5354\u529b\u3057\u3001\u65b0API\u306e\u5229\u70b9\u3092\u6700\u5927\u9650\u306b\u6d3b\u304b\u3059<\/li>\n\n\n\n<li>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u30e1\u30c8\u30ea\u30af\u30b9\u3092\u7d99\u7d9a\u7684\u306b\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3057\u3001\u6700\u9069\u5316\u306e\u6a5f\u4f1a\u3092\u9003\u3055\u306a\u3044<\/li>\n\n\n\n<li>\u8a73\u7d30\u306a\u30c9\u30ad\u30e5\u30e1\u30f3\u30c6\u30fc\u30b7\u30e7\u30f3\u3092\u63d0\u4f9b\u3057\u3001\u958b\u767a\u8005\u306e\u5b66\u7fd2\u66f2\u7dda\u3092\u7de9\u3084\u304b\u306b\u3059\u308b<\/li>\n<\/ol>\n<\/div><\/div><\/div>\n\n\n\n<p>REST\u304b\u3089GraphQL\u3078\u306e\u79fb\u884c\u306f\u3001\u614e\u91cd\u306b\u8a08\u753b\u3057\u5b9f\u884c\u3059\u308b\u5fc5\u8981\u304c\u3042\u308b\u5927\u304d\u306a\u53d6\u308a\u7d44\u307f\u3067\u3059\u3002<br>\u3057\u304b\u3057\u3001\u9069\u5207\u306a\u6226\u7565\u3068\u6bb5\u968e\u7684\u306a\u30a2\u30d7\u30ed\u30fc\u30c1\u3092\u63a1\u7528\u3059\u308b\u3053\u3068\u3067\u3001API\u306e\u67d4\u8edf\u6027\u3068\u52b9\u7387\u6027\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u3001\u958b\u767a\u8005\u3068\u30e6\u30fc\u30b6\u30fc\u53cc\u65b9\u306b\u5927\u304d\u306a\u4fa1\u5024\u3092\u3082\u305f\u3089\u3059\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001GraphQL\u3092\u4f7f\u7528\u3057\u305fRuby on Rails\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30c7\u30d7\u30ed\u30a4\u3068\u904b\u7528\u306b\u3064\u3044\u3066\u3001\u3088\u308a\u8a73\u7d30\u306b\u898b\u3066\u3044\u304d\u307e\u3059\u3002<br>\u672c\u756a\u74b0\u5883\u3067\u306e\u6700\u9069\u5316\u8a2d\u5b9a\u3084\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3001\u7d99\u7d9a\u7684\u306a\u30b9\u30ad\u30fc\u30de\u6539\u5584\u306e\u65b9\u6cd5\u306a\u3069\u3092\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-89\">\u672c\u756a\u74b0\u5883\u3067\u306eGraphQL\u306e\u6700\u9069\u5316\u8a2d\u5b9a<\/h3>\n\n\n\n<p>GraphQL\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u672c\u756a\u74b0\u5883\u3067\u306e\u6027\u80fd\u3092\u6700\u5927\u5316\u3059\u308b\u306b\u306f\u3001\u4ee5\u4e0b\u306e\u6700\u9069\u5316\u8a2d\u5b9a\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-90\">1. <strong>\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u306e\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30e1\u30e2\u30ea\u30ad\u30e3\u30c3\u30b7\u30e5\uff08Redis\u3084Memcached\uff09\u3092\u6d3b\u7528\u3057\u3066\u3001\u983b\u7e41\u306b\u8981\u6c42\u3055\u308c\u308b\u30c7\u30fc\u30bf\u3092\u30ad\u30e3\u30c3\u30b7\u30e5\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>CDN\u3092\u4f7f\u7528\u3057\u3066\u3001\u9759\u7684\u30a2\u30bb\u30c3\u30c8\u3084API\u5fdc\u7b54\u3092\u30ad\u30e3\u30c3\u30b7\u30e5\u3057\u3001\u30ec\u30a4\u30c6\u30f3\u30b7\u3092\u524a\u6e1b\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u30af\u30a8\u30ea\u7d50\u679c\u306e\u30ad\u30e3\u30c3\u30b7\u30e5\u3092\u5b9f\u88c5\u3057\u3066\u3001\u540c\u4e00\u30af\u30a8\u30ea\u306e\u7e70\u308a\u8fd4\u3057\u5b9f\u884c\u3092\u6700\u9069\u5316\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\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=\"\">   # app\/graphql\/types\/query_type.rb\n   field :popular_posts, [Types::PostType], null: false\n\n   def popular_posts\n     Rails.cache.fetch(\"popular_posts\", expires_in: 1.hour) do\n       Post.popular.limit(10).to_a\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-91\">2. <strong>N+1\u554f\u984c\u5bfe\u7b56<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li><code>GraphQL::Batch<\/code>\u3092\u6d3b\u7528\u3057\u3066\u3001\u52b9\u7387\u7684\u306a\u30c7\u30fc\u30bf\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u30af\u30a8\u30ea\u306e\u6700\u9069\u5316\u3092\u884c\u3044\u3001\u4e0d\u5fc5\u8981\u306a\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u30a2\u30af\u30bb\u30b9\u3092\u524a\u6e1b\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\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=\"\">   # app\/graphql\/loaders\/association_loader.rb\n   class AssociationLoader &lt; GraphQL::Batch::Loader\n     def initialize(model, association_name)\n       @model = model\n       @association_name = association_name\n     end\n\n     def perform(record_ids)\n       records = @model.where(id: record_ids).includes(@association_name)\n       records.each { |record| fulfill(record.id, record.public_send(@association_name)) }\n       record_ids.each { |id| fulfill(id, nil) unless fulfilled?(id) }\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-92\">3. <strong>\u30af\u30a8\u30ea\u306e\u8907\u96d1\u3055\u5236\u9650<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30af\u30a8\u30ea\u306e\u6df1\u3055\u3001\u30d5\u30a3\u30fc\u30eb\u30c9\u6570\u3001\u304a\u3088\u3073\u30af\u30a8\u30ea\u30b3\u30b9\u30c8\u306b\u5236\u9650\u3092\u8a2d\u3051\u307e\u3059\u3002<\/li>\n\n\n\n<li><code>graphql-query-complexity<\/code> gem\u3092\u4f7f\u7528\u3057\u3066\u3001\u8907\u96d1\u306a\u30af\u30a8\u30ea\u3092\u5236\u9650\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\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=\"\">   # app\/graphql\/your_schema.rb\n   class YourSchema &lt; GraphQL::Schema\n     max_depth 10\n     max_complexity 300\n     query_analyzer GraphQL::Analysis::QueryComplexity.new do |query, complexity|\n       raise GraphQL::AnalysisError, \"Query is too complex\" if complexity &gt; 300\n     end\n   end<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-93\">\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u30c4\u30fc\u30eb\u306e\u5c0e\u5165\u3068\u7570\u5e38\u691c\u77e5\u306e\u4ed5\u7d44\u307f<\/h3>\n\n\n\n<p>\u52b9\u679c\u7684\u306a\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3068\u8fc5\u901f\u306a\u7570\u5e38\u691c\u77e5\u306f\u3001GraphQL\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u5b89\u5b9a\u904b\u7528\u306b\u4e0d\u53ef\u6b20\u3067\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-94\">1. <strong>Apollo Studio<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30b9\u30ad\u30fc\u30de\u7ba1\u7406\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u5206\u6790\u3001\u30a8\u30e9\u30fc\u8ffd\u8de1\u3092\u4e00\u5143\u7684\u306b\u884c\u3048\u307e\u3059\u3002<\/li>\n\n\n\n<li>GraphQL\u7279\u6709\u306e\u30e1\u30c8\u30ea\u30af\u30b9\u3092\u53ef\u8996\u5316\u3057\u3001\u30af\u30a8\u30ea\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u6700\u9069\u5316\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-95\">2. <strong>New Relic<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>APM\u3068GraphQL\u56fa\u6709\u306e\u30e1\u30c8\u30ea\u30af\u30b9\u3092\u7d44\u307f\u5408\u308f\u305b\u3066\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u5168\u4f53\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u76e3\u8996\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u30c8\u30e9\u30f3\u30b6\u30af\u30b7\u30e7\u30f3\u30c8\u30ec\u30fc\u30b9\u306b\u3088\u308a\u3001\u30dc\u30c8\u30eb\u30cd\u30c3\u30af\u3092\u7279\u5b9a\u3057\u3001\u6700\u9069\u5316\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-96\">3. <strong>Datadog<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30ab\u30b9\u30bf\u30e0\u30e1\u30c8\u30ea\u30af\u30b9\u3001\u30ed\u30b0\u7ba1\u7406\u3001\u5206\u6563\u30c8\u30ec\u30fc\u30b7\u30f3\u30b0\u3092\u7d71\u5408\u7684\u306b\u63d0\u4f9b\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>GraphQL\u30af\u30a8\u30ea\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3068\u5f71\u97ff\u3092\u53ef\u8996\u5316\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-97\">4. <strong>Prometheus + Grafana<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30ab\u30b9\u30bf\u30e0\u30e1\u30c8\u30ea\u30af\u30b9\u306e\u53ce\u96c6\u3068\u53ef\u8996\u5316\u3092\u67d4\u8edf\u306b\u884c\u3048\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u30a2\u30e9\u30fc\u30c8\u30eb\u30fc\u30eb\u3092\u8a2d\u5b9a\u3057\u3001\u8fc5\u901f\u306b\u7570\u5e38\u3092\u691c\u77e5\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<p>\u7570\u5e38\u691c\u77e5\u306e\u4ed5\u7d44\u307f\u3092\u5b9f\u88c5\u3059\u308b\u969b\u306f\u3001\u4ee5\u4e0b\u306e\u70b9\u306b\u6ce8\u610f\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30ec\u30b9\u30dd\u30f3\u30b9\u30bf\u30a4\u30e0\u3001\u30a8\u30e9\u30fc\u30ec\u30fc\u30c8\u3001\u30ea\u30bd\u30fc\u30b9\u4f7f\u7528\u7387\u306a\u3069\u306e\u91cd\u8981\u30e1\u30c8\u30ea\u30af\u30b9\u3092\u7d99\u7d9a\u7684\u306b\u76e3\u8996\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u30ab\u30b9\u30bf\u30e0\u30a2\u30e9\u30fc\u30c8\u3092\u8a2d\u5b9a\u3057\u3001\u95be\u5024\u3092\u8d85\u3048\u305f\u5834\u5408\u306b\u5373\u5ea7\u306b\u901a\u77e5\u3092\u53d7\u3051\u53d6\u308c\u308b\u3088\u3046\u306b\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u30ed\u30b0\u5206\u6790\u3092\u884c\u3044\u3001\u30a8\u30e9\u30fc\u30d1\u30bf\u30fc\u30f3\u3084\u7570\u5e38\u306a\u52d5\u4f5c\u3092\u691c\u51fa\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\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=\"\"># config\/initializers\/prometheus.rb\nrequire 'prometheus\/client'\n\nprometheus = Prometheus::Client.registry\n\ngraphql_query_duration = Prometheus::Client::Histogram.new(:graphql_query_duration_seconds, docstring: 'GraphQL query duration')\nprometheus.register(graphql_query_duration)\n\n# app\/controllers\/graphql_controller.rb\ndef execute\n  start_time = Time.now\n  result = YourSchema.execute(params[:query], variables: params[:variables], context: context, operation_name: params[:operationName])\n  duration = Time.now - start_time\n\n  graphql_query_duration.observe(duration)\n\n  render json: result\nend<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-98\">\u7d99\u7d9a\u7684\u306a\u30b9\u30ad\u30fc\u30de\u6539\u5584\u3068\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u6226\u7565<\/h3>\n\n\n\n<p>GraphQL\u30b9\u30ad\u30fc\u30de\u306e\u7d99\u7d9a\u7684\u306a\u6539\u5584\u3068\u9069\u5207\u306a\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u6226\u7565\u306f\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u9577\u671f\u7684\u306a\u5065\u5168\u6027\u3092\u7dad\u6301\u3059\u308b\u305f\u3081\u306b\u91cd\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-99\">1. <strong>\u30b9\u30ad\u30fc\u30de\u6539\u5584\u6226\u7565<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30b9\u30ad\u30fc\u30de\u5909\u66f4\u306e\u5f71\u97ff\u3092\u614e\u91cd\u306b\u5206\u6790\u3057\u3001\u65e2\u5b58\u306e\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3078\u306e\u5f71\u97ff\u3092\u6700\u5c0f\u9650\u306b\u6291\u3048\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u6bb5\u968e\u7684\u306a\u30c7\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u884c\u3044\u3001\u53e4\u3044\u30d5\u30a3\u30fc\u30eb\u30c9\u3084\u578b\u3092\u5f90\u3005\u306b\u524a\u9664\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u30d0\u30c3\u30af\u30ef\u30fc\u30c9\u30b3\u30f3\u30d1\u30c1\u30d3\u30ea\u30c6\u30a3\u3092\u7dad\u6301\u3057\u3064\u3064\u3001\u65b0\u6a5f\u80fd\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-100\">2. <strong>\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u6226\u7565<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u660e\u793a\u7684\u306a\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u3088\u308a\u3082\u3001\u30b9\u30ad\u30fc\u30de\u306e\u7de9\u3084\u304b\u306a\u9032\u5316\u3092\u63a8\u5968\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u975e\u63a8\u5968\u30d5\u30a3\u30fc\u30eb\u30c9\u306b\u306f<code>@deprecated<\/code>\u30c7\u30a3\u30ec\u30af\u30c6\u30a3\u30d6\u3092\u4f7f\u7528\u3057\u3001\u79fb\u884c\u671f\u9593\u3092\u8a2d\u3051\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3054\u3068\u306b\u30b9\u30ad\u30fc\u30de\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u7ba1\u7406\u3057\u3001\u6bb5\u968e\u7684\u306a\u79fb\u884c\u3092\u53ef\u80fd\u306b\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\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=\"\">type User {\n  id: ID!\n  name: String! @deprecated(reason: \"Use firstName and lastName instead\")\n  firstName: String!\n  lastName: String!\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-101\">3. <strong>\u30b9\u30ad\u30fc\u30de\u5909\u66f4\u306e\u30ef\u30fc\u30af\u30d5\u30ed\u30fc<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5909\u66f4\u6848\u306e\u63d0\u6848 \u2192 \u30a4\u30f3\u30d1\u30af\u30c8\u5206\u6790 \u2192 \u30ec\u30d3\u30e5\u30fc \u2192 \u30c6\u30b9\u30c8 \u2192 \u6bb5\u968e\u7684\u30c7\u30d7\u30ed\u30a4 \u2192 \u30e2\u30cb\u30bf\u30ea\u30f3\u30b0<\/li>\n\n\n\n<li>\u5404\u30b9\u30c6\u30c3\u30d7\u3067\u306e\u30d5\u30a3\u30fc\u30c9\u30d0\u30c3\u30af\u3092\u57fa\u306b\u3001\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u5909\u66f4\u3092\u8abf\u6574\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-102\">\u30c7\u30d7\u30ed\u30a4\u3068\u904b\u7528\u306e\u6210\u529f\u4e8b\u4f8b<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>GitHub<\/strong>: \u5927\u898f\u6a21GraphQL API\u306e\u904b\u7528\u3068\u7d99\u7d9a\u7684\u6539\u5584\u3092\u5b9f\u73fe\u3002\u30b9\u30ad\u30fc\u30de\u8a2d\u8a08\u306e\u67d4\u8edf\u6027\u3068\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u306b\u3088\u308a\u3001\u958b\u767a\u8005\u4f53\u9a13\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3002<\/li>\n\n\n\n<li><strong>Shopify<\/strong>: \u9ad8\u30c8\u30e9\u30d5\u30a3\u30c3\u30af\u306b\u8010\u3048\u308bGraphQL\u30a4\u30f3\u30d5\u30e9\u30b9\u30c8\u30e9\u30af\u30c1\u30e3\u3092\u69cb\u7bc9\u3002\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u3068\u30af\u30a8\u30ea\u6700\u9069\u5316\u306b\u3088\u308a\u3001\u5927\u898f\u6a21EC\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u306e\u8981\u6c42\u306b\u5bfe\u5fdc\u3002<\/li>\n\n\n\n<li><strong>Airbnb<\/strong>: \u30de\u30a4\u30af\u30ed\u30b5\u30fc\u30d3\u30b9\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u3067\u306eGraphQL\u904b\u7528\u3092\u6210\u529f\u3055\u305b\u3001\u8907\u96d1\u306a\u5bbf\u6cca\u4e88\u7d04\u30b7\u30b9\u30c6\u30e0\u3092\u52b9\u7387\u7684\u306b\u7d71\u5408\u3002<\/li>\n<\/ol>\n\n\n\n<p>GraphQL\u3092\u4f7f\u7528\u3057\u305fRuby on Rails\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30c7\u30d7\u30ed\u30a4\u3068\u904b\u7528\u306f\u3001\u7d99\u7d9a\u7684\u306a\u6700\u9069\u5316\u3068\u76e3\u8996\u304c\u5fc5\u8981\u306a\u6311\u6226\u7684\u306a\u30bf\u30b9\u30af\u3067\u3059\u3002<br>\u3057\u304b\u3057\u3001\u9069\u5207\u306a\u6226\u7565\u3068\u30c4\u30fc\u30eb\u3092\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u5b89\u5b9a\u6027\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3001\u30b9\u30b1\u30fc\u30e9\u30d3\u30ea\u30c6\u30a3\u3092\u78ba\u4fdd\u3057\u3064\u3064\u3001\u30e6\u30fc\u30b6\u30fc\u306b\u4fa1\u5024\u3092\u63d0\u4f9b\u3057\u7d9a\u3051\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-103\">\u30c7\u30d7\u30ed\u30a4\u3068\u904b\u7528\u306b\u304a\u3051\u308b\u4e00\u822c\u7684\u306a\u8ab2\u984c\u3068\u89e3\u6c7a\u7b56<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-104\">1. <strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u30dc\u30c8\u30eb\u30cd\u30c3\u30af<\/strong><\/h4>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#fff9e6;color:#ffb36b\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#ffb36b\"><i class=\"fas fa-pencil-alt\"><\/i><\/span><div class=\"sng-box-msg__title\">\u8ab2\u984c<\/div><\/div><div class=\"sng-box-msg__contents\">\n<p>:\u8907\u96d1\u306a\u30af\u30a8\u30ea\u3084\u9ad8\u8ca0\u8377\u6642\u306e\u30ec\u30b9\u30dd\u30f3\u30b9\u9045\u5ef6<\/p>\n<\/div><\/div><\/div>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#b4e0fa;color:#009EF3\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#009EF3\"><i class=\"far fa-lightbulb\"><\/i><\/span><div class=\"sng-box-msg__title\">\u89e3\u6c7a\u7b56<\/div><\/div><div class=\"sng-box-msg__contents\">\n<ul class=\"wp-block-list\">\n<li>\u30af\u30a8\u30ea\u306e\u8907\u96d1\u3055\u306b\u5236\u9650\u3092\u8a2d\u3051\u308b<\/li>\n\n\n\n<li>\u30d0\u30c3\u30c1\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u5b9f\u88c5\u3057\u3066 N+1 \u554f\u984c\u3092\u89e3\u6d88<\/li>\n\n\n\n<li>\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u3092\u6700\u9069\u5316<\/li>\n<\/ul>\n<\/div><\/div><\/div>\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=\"\">   # app\/graphql\/your_schema.rb\n   class YourSchema &lt; GraphQL::Schema\n     query_analyzer GraphQL::Analysis::QueryComplexity.new do |query, complexity|\n       max_complexity = 200\n       raise GraphQL::AnalysisError, \"Query too complex\" if complexity &gt; max_complexity\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-105\">2. <strong>\u30b9\u30b1\u30fc\u30e9\u30d3\u30ea\u30c6\u30a3\u306e\u78ba\u4fdd<\/strong><\/h4>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#fff9e6;color:#ffb36b\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#ffb36b\"><i class=\"fas fa-pencil-alt\"><\/i><\/span><div class=\"sng-box-msg__title\">\u8ab2\u984c<\/div><\/div><div class=\"sng-box-msg__contents\">\n<p>\u30c8\u30e9\u30d5\u30a3\u30c3\u30af\u5897\u52a0\u6642\u306e\u30b7\u30b9\u30c6\u30e0\u5b89\u5b9a\u6027<\/p>\n<\/div><\/div><\/div>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#b4e0fa;color:#009EF3\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#009EF3\"><i class=\"far fa-lightbulb\"><\/i><\/span><div class=\"sng-box-msg__title\">\u89e3\u6c7a\u7b56<\/div><\/div><div class=\"sng-box-msg__contents\">\n<ul class=\"wp-block-list\">\n<li>\u6c34\u5e73\u30b9\u30b1\u30fc\u30ea\u30f3\u30b0\u304c\u53ef\u80fd\u306a\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u306e\u63a1\u7528<\/li>\n\n\n\n<li>CDN\u306e\u6d3b\u7528\u306b\u3088\u308b\u30a8\u30c3\u30b8\u30ad\u30e3\u30c3\u30b7\u30f3\u30b0<\/li>\n\n\n\n<li>\u8ca0\u8377\u5206\u6563\u3068\u30aa\u30fc\u30c8\u30b9\u30b1\u30fc\u30ea\u30f3\u30b0\u306e\u8a2d\u5b9a<\/li>\n<\/ul>\n<\/div><\/div><\/div>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-106\">3. <strong>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30ea\u30b9\u30af\u306e\u7ba1\u7406<\/strong><\/h4>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#fff9e6;color:#ffb36b\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#ffb36b\"><i class=\"fas fa-pencil-alt\"><\/i><\/span><div class=\"sng-box-msg__title\">\u8ab2\u984c<\/div><\/div><div class=\"sng-box-msg__contents\">\n<p>\u4e0d\u6b63\u30a2\u30af\u30bb\u30b9\u3084\u60c5\u5831\u6f0f\u6d29\u306e\u9632\u6b62<\/p>\n<\/div><\/div><\/div>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#b4e0fa;color:#009EF3\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#009EF3\"><i class=\"far fa-lightbulb\"><\/i><\/span><div class=\"sng-box-msg__title\">\u89e3\u6c7a\u7b56<\/div><\/div><div class=\"sng-box-msg__contents\">\n<ul class=\"wp-block-list\">\n<li>\u9069\u5207\u306a\u8a8d\u8a3c\u30fb\u8a8d\u53ef\u306e\u5b9f\u88c5<\/li>\n\n\n\n<li>\u30af\u30a8\u30ea\u306e\u6df1\u3055\u3084\u8907\u96d1\u3055\u306e\u5236\u9650<\/li>\n\n\n\n<li>\u30ec\u30fc\u30c8\u5236\u9650\u306e\u5c0e\u5165<\/li>\n<\/ul>\n<\/div><\/div><\/div>\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=\"\">   # app\/controllers\/graphql_controller.rb\n   class GraphqlController &lt; ApplicationController\n     before_action :authenticate_user!\n\n     def execute\n       # ... GraphQL\u5b9f\u884c\u30ed\u30b8\u30c3\u30af ...\n     end\n\n     private\n\n     def authenticate_user!\n       # \u8a8d\u8a3c\u30ed\u30b8\u30c3\u30af\u306e\u5b9f\u88c5\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-107\">4. <strong>\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3068\u306e\u4e92\u63db\u6027\u7dad\u6301<\/strong><\/h4>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#fff9e6;color:#ffb36b\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#ffb36b\"><i class=\"fas fa-pencil-alt\"><\/i><\/span><div class=\"sng-box-msg__title\">\u8ab2\u984c<\/div><\/div><div class=\"sng-box-msg__contents\">\n<p>\u30b9\u30ad\u30fc\u30de\u5909\u66f4\u306b\u3088\u308b\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306e\u7834\u58ca<\/p>\n<\/div><\/div><\/div>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#b4e0fa;color:#009EF3\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#009EF3\"><i class=\"far fa-lightbulb\"><\/i><\/span><div class=\"sng-box-msg__title\">\u89e3\u6c7a\u7b56<\/div><\/div><div class=\"sng-box-msg__contents\">\n<ul class=\"wp-block-list\">\n<li>\u30d0\u30c3\u30af\u30ef\u30fc\u30c9\u30b3\u30f3\u30d1\u30c1\u30d3\u30ea\u30c6\u30a3\u3092\u7dad\u6301\u3057\u305f\u30b9\u30ad\u30fc\u30de\u9032\u5316<\/li>\n\n\n\n<li>\u975e\u63a8\u5968\u30d5\u30a3\u30fc\u30eb\u30c9\u306e\u6bb5\u968e\u7684\u306a\u5ec3\u6b62<\/li>\n\n\n\n<li>\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3054\u3068\u306e\u30b9\u30ad\u30fc\u30de\u30d0\u30fc\u30b8\u30e7\u30f3\u7ba1\u7406<\/li>\n<\/ul>\n<\/div><\/div><\/div>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-108\">\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3068Tips<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-109\">1. <strong>\u6bb5\u968e\u7684\u30c7\u30d7\u30ed\u30a4<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30ab\u30ca\u30ea\u30a2\u30ea\u30ea\u30fc\u30b9\u3092\u6d3b\u7528\u3057\u3001\u65b0\u6a5f\u80fd\u3084\u5909\u66f4\u3092\u4e00\u90e8\u306e\u30e6\u30fc\u30b6\u30fc\u306b\u9650\u5b9a\u3057\u3066\u30c6\u30b9\u30c8<\/li>\n\n\n\n<li>\u30d6\u30eb\u30fc\/\u30b0\u30ea\u30fc\u30f3\u30c7\u30d7\u30ed\u30a4\u30e1\u30f3\u30c8\u3092\u4f7f\u7528\u3057\u3001\u30c0\u30a6\u30f3\u30bf\u30a4\u30e0\u3092\u6700\u5c0f\u9650\u306b\u6291\u3048\u308b<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-110\">2. <strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u30c1\u30e5\u30fc\u30cb\u30f3\u30b0<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30af\u30a8\u30ea\u30d7\u30e9\u30f3\u306e\u5206\u6790\u3068\u30a4\u30f3\u30c7\u30c3\u30af\u30b9\u306e\u6700\u9069\u5316<\/li>\n\n\n\n<li>N+1\u30af\u30a8\u30ea\u306e\u691c\u51fa\u3068\u89e3\u6d88<\/li>\n\n\n\n<li>\u30e1\u30e2\u30ea\u4f7f\u7528\u91cf\u306e\u76e3\u8996\u3068\u6700\u9069\u5316<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-111\">3. <strong>\u30a8\u30e9\u30fc\u51e6\u7406\u3068\u30ed\u30ae\u30f3\u30b0<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u69cb\u9020\u5316\u30ed\u30b0\u306e\u63a1\u7528\u306b\u3088\u308b\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u306e\u52b9\u7387\u5316<\/li>\n\n\n\n<li>\u30a8\u30e9\u30fc\u306e\u96c6\u4e2d\u7ba1\u7406\u3068\u5206\u6790\uff08\u4f8b\uff1aSentry, Bugsnag\uff09<\/li>\n<\/ul>\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=\"\">   # config\/initializers\/graphql_error_handling.rb\n   GraphQL::Errors.configure(YourSchema) do\n     rescue_from ActiveRecord::RecordNotFound do |err, obj, args, ctx, field|\n       ErrorTracker.log_error(err)\n       raise GraphQL::ExecutionError, \"Record not found\"\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-112\">4. <strong>\u30c9\u30ad\u30e5\u30e1\u30f3\u30c6\u30fc\u30b7\u30e7\u30f3\u3068\u30b9\u30ad\u30fc\u30de\u516c\u958b<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>GraphQL Playground\u306e\u5c0e\u5165\u306b\u3088\u308b\u958b\u767a\u8005\u4f53\u9a13\u306e\u5411\u4e0a<\/li>\n\n\n\n<li>\u30b9\u30ad\u30fc\u30de\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u7ba1\u7406\u3068\u5909\u66f4\u5c65\u6b74\u306e\u516c\u958b<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-113\">5. <strong>\u7d99\u7d9a\u7684\u30a4\u30f3\u30c6\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\/\u7d99\u7d9a\u7684\u30c7\u30d7\u30ed\u30a4\u30e1\u30f3\u30c8 (CI\/CD)<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u81ea\u52d5\u30c6\u30b9\u30c8\u3068\u30b9\u30ad\u30fc\u30de\u691c\u8a3c\u306e CI \u30d1\u30a4\u30d7\u30e9\u30a4\u30f3\u3078\u306e\u7d44\u307f\u8fbc\u307f<\/li>\n\n\n\n<li>\u30b9\u30ad\u30fc\u30de\u5909\u66f4\u306e\u30ec\u30d3\u30e5\u30fc\u30d7\u30ed\u30bb\u30b9\u306e\u81ea\u52d5\u5316<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-114\">\u7d50\u8ad6<\/h3>\n\n\n\n<p>GraphQL\u3092\u4f7f\u7528\u3057\u305fRuby on Rails\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30c7\u30d7\u30ed\u30a4\u3068\u904b\u7528\u306f\u3001\u6280\u8853\u7684\u306a\u8ab2\u984c\u3068\u6a5f\u4f1a\u306e\u4e21\u65b9\u3092\u63d0\u4f9b\u3057\u307e\u3059\u3002<br>\u9069\u5207\u306a\u6700\u9069\u5316\u3001\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3092\u5b9f\u88c5\u3057\u3001\u7d99\u7d9a\u7684\u306a\u6539\u5584\u3092\u884c\u3046\u3053\u3068\u3067\u3001\u9ad8\u6027\u80fd\u3067\u5b89\u5b9a\u3057\u305fAPI\u3092\u63d0\u4f9b\u3057\u7d9a\u3051\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u5927\u898f\u6a21\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u6210\u529f\u4e8b\u4f8b\u304b\u3089\u5b66\u3073\u3001\u81ea\u8eab\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u9069\u3057\u305f\u30a2\u30d7\u30ed\u30fc\u30c1\u3092\u9078\u629e\u3059\u308b\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<br>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3001\u30b9\u30b1\u30fc\u30e9\u30d3\u30ea\u30c6\u30a3\u306e\u30d0\u30e9\u30f3\u30b9\u3092\u53d6\u308a\u306a\u304c\u3089\u3001\u30e6\u30fc\u30b6\u30fc\u30cb\u30fc\u30ba\u3068\u958b\u767a\u8005\u4f53\u9a13\u306e\u4e21\u65b9\u3092\u6e80\u305f\u3059\u30bd\u30ea\u30e5\u30fc\u30b7\u30e7\u30f3\u3092\u69cb\u7bc9\u3057\u3066\u3044\u304f\u3053\u3068\u304c\u3001GraphQL\u3092\u6d3b\u7528\u3057\u305f\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u6210\u529f\u306b\u3064\u306a\u304c\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u6b21\u306e\u30b9\u30c6\u30c3\u30d7\u3068\u3057\u3066\u3001\u3053\u308c\u3089\u306e\u77e5\u8b58\u3092\u81ea\u8eab\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u9069\u7528\u3057\u3001\u7d99\u7d9a\u7684\u306a\u5b66\u7fd2\u3068\u6539\u5584\u3092\u884c\u3063\u3066\u3044\u304f\u3053\u3068\u3092\u304a\u52e7\u3081\u3057\u307e\u3059\u3002<br>GraphQL\u30b3\u30df\u30e5\u30cb\u30c6\u30a3\u3084Ruby on Rails\u30b3\u30df\u30e5\u30cb\u30c6\u30a3\u306b\u53c2\u52a0\u3057\u3001\u6700\u65b0\u306e\u30c8\u30ec\u30f3\u30c9\u3084\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3092\u5e38\u306b\u628a\u63e1\u3059\u308b\u3053\u3068\u3082\u3001\u9577\u671f\u7684\u306a\u6210\u529f\u306b\u306f\u4e0d\u53ef\u6b20\u3067\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-115\">\u307e\u3068\u3081\uff1aRuby on Rails\u3068GraphQL\u306e\u672a\u6765<\/h2>\n\n\n\n<p>Ruby on Rails\u3068GraphQL\u306e\u7d44\u307f\u5408\u308f\u305b\u306f\u3001Web\u958b\u767a\u306e\u65b0\u305f\u306a\u5730\u5e73\u3092\u5207\u308a\u958b\u3044\u3066\u3044\u307e\u3059\u3002<br>\u3053\u306e\u5f37\u529b\u306a\u30c7\u30e5\u30aa\u306f\u3001\u67d4\u8edf\u306aAPI\u8a2d\u8a08\u3001\u52b9\u7387\u7684\u306a\u30c7\u30fc\u30bf\u30d5\u30a7\u30c3\u30c1\u30f3\u30b0\u3001\u305d\u3057\u3066\u958b\u767a\u30d7\u30ed\u30bb\u30b9\u5168\u4f53\u306e\u6700\u9069\u5316\u3092\u3082\u305f\u3089\u3057\u3001\u30e2\u30c0\u30f3\u306aWeb\u958b\u767a\u306e\u8981\u6c42\u306b\u5fdc\u3048\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-116\">GraphQL\u304c\u3082\u305f\u3089\u3059Ruby on Rails\u958b\u767a\u306e\u9769\u65b0<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u67d4\u8edf\u306aAPI\u8a2d\u8a08<\/strong>: GraphQL\u306b\u3088\u308a\u3001\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u304c\u5fc5\u8981\u306a\u30c7\u30fc\u30bf\u306e\u307f\u3092\u8981\u6c42\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u3001API\u306e\u67d4\u8edf\u6027\u304c\u5927\u5e45\u306b\u5411\u4e0a\u3057\u307e\u3057\u305f\u3002<br>\u3053\u308c\u306f\u3001\u7279\u306b\u8907\u96d1\u306a\u30c7\u30fc\u30bf\u8981\u4ef6\u3092\u6301\u3064\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3067\u5a01\u529b\u3092\u767a\u63ee\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u6700\u9069\u5316<\/strong>: \u30aa\u30fc\u30d0\u30fc\u30d5\u30a7\u30c3\u30c1\u3068\u30a2\u30f3\u30c0\u30fc\u30d5\u30a7\u30c3\u30c1\u306e\u554f\u984c\u3092\u89e3\u6d88\u3057\u3001\u30cd\u30c3\u30c8\u30ef\u30fc\u30af\u52b9\u7387\u3092\u9ad8\u3081\u3066\u3044\u307e\u3059\u3002<br>Ruby on Rails\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30ec\u30b9\u30dd\u30f3\u30b9\u6642\u9593\u304c\u6539\u5584\u3055\u308c\u3001\u30e6\u30fc\u30b6\u30fc\u30a8\u30af\u30b9\u30da\u30ea\u30a8\u30f3\u30b9\u306e\u5411\u4e0a\u306b\u3064\u306a\u304c\u3063\u3066\u3044\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u958b\u767a\u52b9\u7387\u306e\u5411\u4e0a<\/strong>: \u5f37\u529b\u306a\u578b\u30b7\u30b9\u30c6\u30e0\u306b\u3088\u308a\u3001\u958b\u767a\u6642\u306e\u30a8\u30e9\u30fc\u691c\u51fa\u304c\u5bb9\u6613\u306b\u306a\u308a\u3001\u30b3\u30fc\u30c9\u306e\u54c1\u8cea\u3068\u4fdd\u5b88\u6027\u304c\u5411\u4e0a\u3057\u3066\u3044\u307e\u3059\u3002<br>\u307e\u305f\u3001\u30b9\u30ad\u30fc\u30de\u99c6\u52d5\u958b\u767a\u306e\u4fc3\u9032\u306b\u3088\u308a\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3068\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u306e\u30c1\u30fc\u30e0\u9593\u306e\u30b3\u30e9\u30dc\u30ec\u30fc\u30b7\u30e7\u30f3\u304c\u5f37\u5316\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30de\u30a4\u30af\u30ed\u30b5\u30fc\u30d3\u30b9\u3068\u306e\u89aa\u548c\u6027<\/strong>: GraphQL\u306f\u3001Ruby on Rails\u3092\u4f7f\u7528\u3057\u305f\u30de\u30a4\u30af\u30ed\u30b5\u30fc\u30d3\u30b9\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u306e\u5b9f\u88c5\u3092\u5bb9\u6613\u306b\u3057\u3001\u30b9\u30b1\u30fc\u30e9\u30d6\u30eb\u3067\u67d4\u8edf\u306a\u30b7\u30b9\u30c6\u30e0\u8a2d\u8a08\u3092\u53ef\u80fd\u306b\u3057\u3066\u3044\u307e\u3059\u3002<\/li>\n<\/ol>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-117\">\u6b21\u306e\u30b9\u30c6\u30c3\u30d7\uff1a\u3055\u3089\u306a\u308b\u5b66\u7fd2\u30ea\u30bd\u30fc\u30b9\u3068\u5b9f\u8df5\u7684\u306a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30a2\u30a4\u30c7\u30a2<\/h3>\n\n\n\n<p>GraphQL\u3068Ruby on Rails\u306e\u77e5\u8b58\u3092\u3055\u3089\u306b\u6df1\u3081\u308b\u305f\u3081\u306b\u3001\u4ee5\u4e0b\u306e\u30ea\u30bd\u30fc\u30b9\u3068\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30a2\u30a4\u30c7\u30a2\u3092\u6d3b\u7528\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-118\">\u5b66\u7fd2\u30ea\u30bd\u30fc\u30b9<\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u66f8\u7c4d: \u300cGraphQL in Action\u300dby Samer Buna<\/li>\n\n\n\n<li>\u30aa\u30f3\u30e9\u30a4\u30f3\u30b3\u30fc\u30b9: GraphQL by Example (Udemy)<\/li>\n\n\n\n<li>\u30b3\u30df\u30e5\u30cb\u30c6\u30a3: GraphQL Weekly Newsletter, Ruby on Rails Link Slack community<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-119\">\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30a2\u30a4\u30c7\u30a2<\/h4>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u66f4\u65b0\u6a5f\u80fd\u3092\u6301\u3064\u30d6\u30ed\u30b0\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0<\/li>\n\n\n\n<li>GraphQL\u3092\u4f7f\u7528\u3057\u305fe\u30b3\u30de\u30fc\u30b9API<\/li>\n\n\n\n<li>\u30de\u30a4\u30af\u30ed\u30b5\u30fc\u30d3\u30b9\u30d9\u30fc\u30b9\u306e\u30bf\u30b9\u30af\u7ba1\u7406\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3<\/li>\n<\/ol>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u53d6\u308a\u7d44\u3080\u3053\u3068\u3067\u3001\u7406\u8ad6\u3092\u5b9f\u8df5\u306b\u79fb\u3057\u3001\u5b9f\u969b\u306e\u30b7\u30ca\u30ea\u30aa\u3067GraphQL\u3068Ruby on Rails\u306e\u529b\u3092\u4f53\u9a13\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-120\">\u5c55\u671b<\/h3>\n\n\n\n<p>GraphQL\u3068Ruby on Rails\u306e\u7d71\u5408\u306f\u3001Web\u958b\u767a\u306e\u672a\u6765\u3092\u5f62\u4f5c\u308b\u91cd\u8981\u306a\u8981\u7d20\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002<br>Federation\uff08\u5206\u6563\u578bGraphQL\uff09\u306e\u666e\u53ca\u3001AI\u3068\u306e\u7d71\u5408\u306b\u3088\u308b\u30b9\u30ad\u30fc\u30de\u8a2d\u8a08\u306e\u81ea\u52d5\u5316\u3001\u30a8\u30c3\u30b8\u30b3\u30f3\u30d4\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u306e\u878d\u5408\u306a\u3069\u3001\u8208\u5473\u6df1\u3044\u5c55\u958b\u304c\u671f\u5f85\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u6280\u8853\u3092\u7a4d\u6975\u7684\u306b\u63a1\u7528\u3057\u3001\u7d99\u7d9a\u7684\u306b\u5b66\u7fd2\u3057\u3066\u3044\u304f\u3053\u3068\u3067<br>\u3053\u308c\u3089\u306e\u6280\u8853\u3092\u7a4d\u6975\u7684\u306b\u63a1\u7528\u3057\u3001\u7d99\u7d9a\u7684\u306b\u5b66\u7fd2\u3057\u3066\u3044\u304f\u3053\u3068\u3067\u3001\u958b\u767a\u8005\u306f\u5e38\u306b\u6700\u5148\u7aef\u306e Web \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u958b\u767a\u3092\u884c\u3046\u3053\u3068\u304c\u3067\u304d\u308b\u3067\u3057\u3087\u3046\u3002<br>Ruby on Rails \u3068 GraphQL \u306e\u7d44\u307f\u5408\u308f\u305b\u306f\u3001\u5358\u306a\u308b\u30c8\u30ec\u30f3\u30c9\u3067\u306f\u306a\u304f\u3001\u6301\u7d9a\u53ef\u80fd\u3067\u52b9\u7387\u7684\u306a\u958b\u767a\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3092\u5b9f\u73fe\u3059\u308b\u624b\u6bb5\u3068\u3057\u3066\u3001\u4eca\u5f8c\u3082\u9032\u5316\u3092\u7d9a\u3051\u3066\u3044\u304f\u3068\u8003\u3048\u3089\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-121\">\u4eca\u5f8c\u306e\u30c8\u30ec\u30f3\u30c9\u3068\u53ef\u80fd\u6027<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>AI \u3068\u306e\u7d71\u5408<\/strong>: \u6a5f\u68b0\u5b66\u7fd2\u30e2\u30c7\u30eb\u3092 GraphQL API \u306b\u7d71\u5408\u3059\u308b\u3053\u3068\u3067\u3001\u3088\u308a\u8ce2\u660e\u306a\u30c7\u30fc\u30bf\u5206\u6790\u3084\u30ec\u30b3\u30e1\u30f3\u30c7\u30fc\u30b7\u30e7\u30f3\u30b7\u30b9\u30c6\u30e0\u306e\u69cb\u7bc9\u304c\u53ef\u80fd\u306b\u306a\u308b\u3067\u3057\u3087\u3046\u3002<\/li>\n\n\n\n<li><strong>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u306e\u5f37\u5316<\/strong>: GraphQL \u7279\u6709\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8ab2\u984c\u306b\u5bfe\u5fdc\u3059\u308b\u305f\u3081\u306e\u5c02\u9580\u30c4\u30fc\u30eb\u3084\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u304c\u3055\u3089\u306b\u767a\u5c55\u3059\u308b\u3068\u4e88\u60f3\u3055\u308c\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u6700\u9069\u5316<\/strong>: \u30a8\u30c3\u30b8\u30b3\u30f3\u30d4\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068 GraphQL \u306e\u878d\u5408\u306b\u3088\u308a\u3001\u3055\u3089\u306a\u308b\u30ec\u30b9\u30dd\u30f3\u30b9\u6642\u9593\u306e\u77ed\u7e2e\u3068\u30b9\u30b1\u30fc\u30e9\u30d3\u30ea\u30c6\u30a3\u306e\u5411\u4e0a\u304c\u671f\u5f85\u3055\u308c\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u958b\u767a\u8005\u4f53\u9a13\u306e\u5411\u4e0a<\/strong>: \u3088\u308a\u6d17\u7df4\u3055\u308c\u305f GraphQL \u958b\u767a\u30c4\u30fc\u30eb\u3084 IDE \u30d7\u30e9\u30b0\u30a4\u30f3\u306b\u3088\u308a\u3001Ruby on Rails \u958b\u767a\u8005\u306e\u751f\u7523\u6027\u304c\u3055\u3089\u306b\u5411\u4e0a\u3059\u308b\u3067\u3057\u3087\u3046\u3002<\/li>\n<\/ol>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-122\">\u6700\u5f8c\u306b<\/h3>\n\n\n\n<p>Ruby on Rails \u3068 GraphQL \u306e\u7d44\u307f\u5408\u308f\u305b\u306f\u3001\u73fe\u4ee3\u306e Web \u958b\u767a\u306b\u304a\u3051\u308b\u5f37\u529b\u306a\u30bd\u30ea\u30e5\u30fc\u30b7\u30e7\u30f3\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002<br>\u3053\u306e\u6280\u8853\u30b9\u30bf\u30c3\u30af\u306f\u3001\u9ad8\u3044\u67d4\u8edf\u6027\u3001\u512a\u308c\u305f\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3001\u305d\u3057\u3066\u958b\u767a\u52b9\u7387\u306e\u5411\u4e0a\u3092\u63d0\u4f9b\u3057\u3001\u591a\u69d8\u306a\u8981\u6c42\u306b\u5fdc\u3048\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u7d99\u7d9a\u7684\u306a\u5b66\u7fd2\u3068\u5b9f\u8df5\u3092\u901a\u3058\u3066\u3001\u3053\u308c\u3089\u306e\u6280\u8853\u3092\u7fd2\u5f97\u3057\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u958b\u767a\u8005\u306f\u9769\u65b0\u7684\u3067\u52b9\u7387\u7684\u306a Web \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u69cb\u7bc9\u3059\u308b\u80fd\u529b\u3092\u8eab\u306b\u3064\u3051\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>Ruby on Rails \u3068 GraphQL \u306e\u4e16\u754c\u306f\u5e38\u306b\u9032\u5316\u3057\u7d9a\u3051\u3066\u304a\u308a\u3001\u3053\u306e\u5206\u91ce\u3067\u306e\u30b9\u30ad\u30eb\u3092\u78e8\u304f\u3053\u3068\u306f\u3001\u30ad\u30e3\u30ea\u30a2\u306e\u767a\u5c55\u3068\u6280\u8853\u7684\u306a\u6210\u9577\u306e\u4e21\u9762\u3067\u5927\u304d\u306a\u4fa1\u5024\u3092\u3082\u305f\u3089\u3059\u3067\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<p>\u4eca\u5f8c\u3082 Ruby on Rails \u3068 GraphQL \u306e\u30a8\u30b3\u30b7\u30b9\u30c6\u30e0\u306e\u767a\u5c55\u306b\u6ce8\u76ee\u3057\u3001\u65b0\u3057\u3044\u53ef\u80fd\u6027\u3092\u63a2\u6c42\u3057\u7d9a\u3051\u308b\u3053\u3068\u3092\u304a\u52e7\u3081\u3057\u307e\u3059\u3002<br>\u3053\u306e\u5f37\u529b\u306a\u7d44\u307f\u5408\u308f\u305b\u304c\u3001Web \u958b\u767a\u306e\u672a\u6765\u3092\u3069\u306e\u3088\u3046\u306b\u5f62\u4f5c\u3063\u3066\u3044\u304f\u306e\u304b\u3001\u5171\u306b\u898b\u5b88\u308a\u3001\u305d\u306e\u4e00\u7aef\u3092\u62c5\u3063\u3066\u3044\u3051\u308b\u3053\u3068\u3092\u697d\u3057\u307f\u306b\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Ruby on Rails\u3068GraphQL\u306e\u7d44\u307f\u5408\u308f\u305b\u306f\u3001\u73fe\u4ee3\u306eWeb\u958b\u767a\u306b\u304a\u3051\u308b\u5f37\u529b\u306a\u30bd\u30ea\u30e5\u30fc\u30b7\u30e7\u30f3\u3068\u3057\u3066\u6ce8\u76ee\u3092\u96c6\u3081\u3066\u3044\u307e\u3059\u3002\u3053\u306e\u8a18\u4e8b\u3067\u306f\u3001GraphQL\u3092Ruby on Rails\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u7d71\u5408\u3059\u308b\u65b9\u6cd5\u304b\u3089\u3001\u5927\u898f &#8230; <\/p>\n","protected":false},"author":1,"featured_media":3118,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[3,44],"tags":[],"class_list":{"0":"post-116","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-ruby","8":"category-ruby-rails"},"_links":{"self":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/116","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=116"}],"version-history":[{"count":3,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/116\/revisions"}],"predecessor-version":[{"id":119,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/116\/revisions\/119"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/media\/3118"}],"wp:attachment":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=116"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=116"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=116"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}