{"id":80,"date":"2019-12-22T15:02:38","date_gmt":"2019-12-22T15:02:38","guid":{"rendered":"https:\/\/oidema-jp.com\/media\/2019-12-22-150238\/"},"modified":"2022-06-10T13:12:36","modified_gmt":"2022-06-10T04:12:36","slug":"2019-12-22-150238","status":"publish","type":"post","link":"https:\/\/oidema-jp.com\/media\/2019-12-22-150238\/","title":{"rendered":"\u3010NestJS\u3011TypeORM\u306b\u3088\u308bMigration\u30d5\u30a1\u30a4\u30eb\u304c\u8a2d\u5b9a\u3057\u305f\u30d5\u30a9\u30eb\u30c0\u306b\u4fdd\u5b58\u3055\u308c\u306a\u3044\u554f\u984c\u306b\u3064\u3044\u3066"},"content":{"rendered":"\n<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_81 counter-hierarchy ez-toc-counter ez-toc-grey ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\">\n<p class=\"ez-toc-title\" style=\"cursor:inherit\">Table of Contents<\/p>\n<span class=\"ez-toc-title-toggle\"><a href=\"#\" class=\"ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle\" aria-label=\"Toggle Table of Content\"><span class=\"ez-toc-js-icon-con\"><span class=\"\"><span class=\"eztoc-hide\" style=\"display:none;\">Toggle<\/span><span class=\"ez-toc-icon-toggle-span\"><svg style=\"fill: #999;color:#999\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"list-377408\" width=\"20px\" height=\"20px\" viewBox=\"0 0 24 24\" fill=\"none\"><path d=\"M6 6H4v2h2V6zm14 0H8v2h12V6zM4 11h2v2H4v-2zm16 0H8v2h12v-2zM4 16h2v2H4v-2zm16 0H8v2h12v-2z\" fill=\"currentColor\"><\/path><\/svg><svg style=\"fill: #999;color:#999\" class=\"arrow-unsorted-368013\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"10px\" height=\"10px\" viewBox=\"0 0 24 24\" version=\"1.2\" baseProfile=\"tiny\"><path d=\"M18.2 9.3l-6.2-6.3-6.2 6.3c-.2.2-.3.4-.3.7s.1.5.3.7c.2.2.4.3.7.3h11c.3 0 .5-.1.7-.3.2-.2.3-.5.3-.7s-.1-.5-.3-.7zM5.8 14.7l6.2 6.3 6.2-6.3c.2-.2.3-.5.3-.7s-.1-.5-.3-.7c-.2-.2-.4-.3-.7-.3h-11c-.3 0-.5.1-.7.3-.2.2-.3.5-.3.7s.1.5.3.7z\"\/><\/svg><\/span><\/span><\/span><\/a><\/span><\/div>\n<nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/oidema-jp.com\/media\/2019-12-22-150238\/#%E3%81%AF%E3%81%98%E3%82%81%E3%81%AB\" >\u306f\u3058\u3081\u306b<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/oidema-jp.com\/media\/2019-12-22-150238\/#%E8%B5%B7%E3%81%93%E3%81%A3%E3%81%A6%E3%81%84%E3%82%8B%E3%81%93%E3%81%A8\" >\u8d77\u3053\u3063\u3066\u3044\u308b\u3053\u3068<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/oidema-jp.com\/media\/2019-12-22-150238\/#%E8%A8%AD%E5%AE%9A%E3%81%AE%E7%A2%BA%E8%AA%8D%E3%82%92%E8%A1%8C%E3%81%86\" >\u8a2d\u5b9a\u306e\u78ba\u8a8d\u3092\u884c\u3046<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/oidema-jp.com\/media\/2019-12-22-150238\/#packagejson%E3%81%AE%E8%A8%AD%E5%AE%9A%E3%82%92%E7%A2%BA%E8%AA%8D\" >package.json\u306e\u8a2d\u5b9a\u3092\u78ba\u8a8d<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/oidema-jp.com\/media\/2019-12-22-150238\/#srcconfigtypeormconfigts%E3%81%AE%E8%A8%98%E8%BF%B0%E3%82%92%E7%A2%BA%E8%AA%8D%E3%81%99%E3%82%8B\" >src\/config\/typeorm.config.ts\u306e\u8a18\u8ff0\u3092\u78ba\u8a8d\u3059\u308b<\/a><\/li><\/ul><\/li><\/ul><\/nav><\/div>\n<h2 class=\"wp-block-heading\" id=\"\u76ee\u6b21\"><span class=\"ez-toc-section\" id=\"%E3%81%AF%E3%81%98%E3%82%81%E3%81%AB\"><\/span>\u306f\u3058\u3081\u306b<span class=\"ez-toc-section-end\"><\/span><\/h2>\n\n\n\n<p>\u4eca\u56de\u306fNestJS\u3082\u305d\u3046\u3067\u3059\u304c\u3001<br><br>\u305d\u3082\u305d\u3082TypeScript\u3082TypeORM\u3082\u521d\u3081\u3066\u306a\u30c1\u30e3\u30ec\u30f3\u30b8\u30f3\u30b0\u306a\u958b\u767a\u3067\u3001<br><br><br>DB\u30b9\u30ad\u30fc\u30de\u306e\u5909\u66f4\u3092\u884c\u3044\u305f\u3044\u305f\u3081\u3001\u8272\u3005\u53c2\u8003\u306b\u3057\u306a\u304c\u3089\u9032\u3081\u3066\u3044\u306a\u304c\u3089\u3082\u3001<br>\u72d9\u3063\u305f\u30d5\u30a9\u30eb\u30c0\u306bmigration\u30d5\u30a1\u30a4\u30eb\u304c\u4f5c\u6210\u3055\u308c\u306a\u3044\u554f\u984c\u304c\u767a\u751f\u3057\u3066\u3044\u308b\u306e\u3067<br>\u89e3\u6c7a\u3067\u304d\u308b\u307e\u3067\u3086\u308b\u3063\u3068\u30e1\u30e2\u3092\u6b8b\u305d\u3046\u3068\u3044\u3046\u30e1\u30e2\u3067\u3042\u308b\u3002<\/p>\n\n\n\n<p>\u4e00\u5fdc\u3001\u4e0b\u8a18\u306e\u30b5\u30a4\u30c8\u3092\u53c2\u8003\u306b\u306f\u3057\u3066\u3044\u308b\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\"><li><a href=\"https:\/\/qiita.com\/renresozz\/items\/69357ce1d4e8e2fc4929\">\u3010Qiita\u3011NestJS\u3067TypeORM\u3092\u4f7f\u3063\u3066migration\u3092\u8a66\u3057\u3066\u307f\u308b<\/a><\/li><li><a href=\"https:\/\/github.com\/typeorm\/typeorm\/blob\/master\/docs\/using-cli.md#create-a-new-migration\">\u3010GitHub\u3011typeorm\/typeorm<\/a><\/li><\/ul>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u8d77\u3053\u3063\u3066\u3044\u308b\u3053\u3068\"><span class=\"ez-toc-section\" id=\"%E8%B5%B7%E3%81%93%E3%81%A3%E3%81%A6%E3%81%84%E3%82%8B%E3%81%93%E3%81%A8\"><\/span>\u8d77\u3053\u3063\u3066\u3044\u308b\u3053\u3068<span class=\"ez-toc-section-end\"><\/span><\/h2>\n\n\n\n<p>\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u308b\u3068\u30eb\u30fc\u30c8\u30d5\u30a9\u30eb\u30c0\u306b\u4f5c\u6210\u3055\u308c\u3066\u3057\u307e\u3046<\/p>\n\n\n\n<p><b>\u2192\u3000\u672c\u5f53\u306fsrc\/migration\u914d\u4e0b\u306b\u3067\u304d\u3066\u307b\u3057\u3044<\/b><\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">$ npm run typeorm migration:create <span class=\"synSpecial\">--<\/span> <span class=\"synSpecial\">-n<\/span> AddRestaurantDescription\n<\/pre>\n\n\n\n<figure class=\"wp-block-image\"><img decoding=\"async\" src=\"https:\/\/cdn-ak.f.st-hatena.com\/images\/fotolife\/k\/keisuke8925gdk\/20191220\/20191220204711.png\" alt=\"f:id:keisuke8925gdk:20191220204711p:plain\" title=\"f:id:keisuke8925gdk:20191220204711p:plain\"><\/figure>\n\n\n\n<p>\u2191\u3053\u3093\u306a\u611f\u3058\u3067\u30eb\u30fc\u30c8\u30d5\u30a9\u30eb\u30c0\u306b\u3067\u304d\u3066\u3057\u307e\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u8a2d\u5b9a\u306e\u78ba\u8a8d\u3092\u884c\u3046\"><span class=\"ez-toc-section\" id=\"%E8%A8%AD%E5%AE%9A%E3%81%AE%E7%A2%BA%E8%AA%8D%E3%82%92%E8%A1%8C%E3%81%86\"><\/span>\u8a2d\u5b9a\u306e\u78ba\u8a8d\u3092\u884c\u3046<span class=\"ez-toc-section-end\"><\/span><\/h2>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"packagejson\u306e\u8a2d\u5b9a\u3092\u78ba\u8a8d\"><span class=\"ez-toc-section\" id=\"packagejson%E3%81%AE%E8%A8%AD%E5%AE%9A%E3%82%92%E7%A2%BA%E8%AA%8D\"><\/span>package.json\u306e\u8a2d\u5b9a\u3092\u78ba\u8a8d<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-preformatted\"> \"<span class=\"synStatement\">scripts<\/span>\": <span class=\"synSpecial\">{<\/span>\n~~~~~~~~~~~~~~~~~~~~\n\"<span class=\"synStatement\">typeorm<\/span>\": \"<span class=\"synConstant\">ts-node -r tsconfig-paths\/register .\/node_modules\/typeorm\/cli.js --config src\/config\/typeorm.config.ts<\/span>\"\n<span class=\"synSpecial\">}<\/span>,\n<\/pre>\n\n\n\n<p>\u7279\u306b\u4eca\u56de\u306f\u3001\u2013config\u30aa\u30d7\u30b7\u30e7\u30f3\u3067<code>--config src\/config\/typeorm.config.ts<\/code>\u3092\u6307\u5b9a\u3057\u3066\u3044\u308b\u306e\u3067src\/migration\u914d\u4e0b\u306bmigration\u30d5\u30a1\u30a4\u30eb\u304c\u6307\u5b9a\u3067\u304d\u3066\u3044\u308b\u3068\u601d\u3063\u3066\u3044\u308b\u306e\u3060\u304c\u3001\u3001\u305d\u3046\u306f\u306a\u3063\u3066\u3044\u306a\u3044\u3002<\/p>\n\n\n\n<p>2020\u5e741\u670815\u65e5\u8ffd\u8a18<br><br>\u305d\u3082\u305d\u3082Config\u30aa\u30d7\u30b7\u30e7\u30f3\u306f\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3092\u6307\u5b9a\u3059\u308b\u30aa\u30d7\u30b7\u30e7\u30f3\u3067\u306a\u3044\u305f\u3081\u3001\u307e\u3063\u305f\u304f\u95a2\u4fc2\u306a\u3044\u3002<br>\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3092\u6307\u5b9a\u3059\u308b\u5834\u5408\u306f\u3001<code>-- dir src\/migration<\/code>\u3053\u3093\u306a\u611f\u3058\u3067\u884c\u3048\u3070\u554f\u984c\u306a\u304b\u3063\u305f\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"srcconfigtypeormconfigts\u306e\u8a18\u8ff0\u3092\u78ba\u8a8d\u3059\u308b\"><span class=\"ez-toc-section\" id=\"srcconfigtypeormconfigts%E3%81%AE%E8%A8%98%E8%BF%B0%E3%82%92%E7%A2%BA%E8%AA%8D%E3%81%99%E3%82%8B\"><\/span>src\/config\/typeorm.config.ts\u306e\u8a18\u8ff0\u3092\u78ba\u8a8d\u3059\u308b<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-preformatted\"><span class=\"synStatement\">import<\/span> <span class=\"synIdentifier\">{<\/span> TypeOrmModuleOptions <span class=\"synIdentifier\">}<\/span> <span class=\"synStatement\">from<\/span> <span class=\"synConstant\">'@nestjs\/typeorm'<\/span><span class=\"synStatement\">;<\/span>\n<span class=\"synStatement\">export<\/span> <span class=\"synStatement\">const<\/span> typeOrmConfig: TypeOrmModuleOptions <span class=\"synStatement\">=<\/span> <span class=\"synIdentifier\">{<\/span>\n<span class=\"synStatement\">type<\/span>: <span class=\"synConstant\">'postgres'<\/span><span class=\"synStatement\">,<\/span>\nhost: <span class=\"synConstant\">'localhost'<\/span><span class=\"synStatement\">,<\/span>\nport: <span class=\"synConstant\">5432<\/span><span class=\"synStatement\">,<\/span>\nusername: <span class=\"synConstant\">'\u3042\u3042\u3042\u3042'<\/span><span class=\"synStatement\">,<\/span>\npassword: <span class=\"synConstant\">'\u3044\u3044\u3044\u3044'<\/span><span class=\"synStatement\">,<\/span>\ndatabase: <span class=\"synConstant\">'\u3046\u3046\u3046\u3046'<\/span><span class=\"synStatement\">,<\/span>\nentities: <span class=\"synIdentifier\">[<\/span>__dirname + <span class=\"synConstant\">'\/..\/**\/*.entity.{js,ts}'<\/span><span class=\"synIdentifier\">]<\/span><span class=\"synStatement\">,<\/span>\u3000\u2190\u3000\u3053\u308c\u3082\u6700\u521d\u30a8\u30e9\u30fc\u306b\u306a\u3063\u3066\u305f\nsynchronize: <span class=\"synConstant\">true<\/span><span class=\"synStatement\">,<\/span>\nmigrations: <span class=\"synIdentifier\">[<\/span><span class=\"synConstant\">'src\/migration\/*.ts'<\/span><span class=\"synIdentifier\">]<\/span><span class=\"synStatement\">,<\/span>\ncli: <span class=\"synIdentifier\">{<\/span>\nmigrationsDir: <span class=\"synConstant\">'src\/migration'<\/span><span class=\"synStatement\">,<\/span>\n<span class=\"synIdentifier\">}<\/span><span class=\"synStatement\">,<\/span>\n<span class=\"synIdentifier\">}<\/span><span class=\"synStatement\">;<\/span>\n<\/pre>\n\n\n\n<p>2020\u5e741\u670815\u65e5\u8ffd\u8a18<br><br>\u3084\u3063\u3071\u308a\u3053\u3053\u306f\u554f\u984c\u306a\u304b\u3063\u305f\u3002<br><code>migrationDir<\/code>\u3067src\/migration\u30d5\u30a9\u30eb\u30c0\u914d\u4e0b\u3092\u6307\u5b9a\u3057\u3066\u304a\u308a\u3053\u3053\u3082\u554f\u984c\u306a\u3055\u305d\u3046\u3067\u3042\u308b\u3002\u3002\u3002<\/p>\n\n\n\n<p>2020\u5e741\u670816\u65e5\u8ffd\u8a18<br><br>package.json\u306escripts\u30ea\u30b9\u30c8\u306b<code>--dir<\/code>\u30aa\u30d7\u30b7\u30e7\u30f3\u3092\u8a18\u8f09\u3057\u3066\u3044\u308b\u3068<code>typeorm migration:run<\/code>\u672a\u77e5\u306e\u5f15\u6570\u304c\u3042\u308b\u65e8\u306e\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3059\u308b\u306e\u3067\u3053\u308c\u306f\u6307\u5b9a\u3057\u3066\u306f\u3044\u3051\u306a\u3044\u3002<\/p>\n\n\n\n<p>\u305d\u3082\u305d\u3082\u3001ormconfig.json\u306f\u30eb\u30fc\u30c8\u30d5\u30a9\u30eb\u30c0\u306b\u914d\u7f6e\u3059\u308c\u3070\u305d\u3082\u305d\u3082\u554f\u984c\u306a\u3044\u3002<\/p>\n\n\n\n<p>2020\u5e741\u670815\u65e5\u8ffd\u8a18\uff08\u89e3\u6c7a\u3057\u305f\uff09<\/p>\n\n\n\n<p>\u2192 \u305d\u3082\u305d\u3082\u3001typeorm\u306eConfigmigration\u30d5\u30a1\u30a4\u30eb\u306f\u30eb\u30fc\u30c8\u30d5\u30a9\u30eb\u30c0\u3092\u898b\u306b\u884c\u304f\u8a2d\u5b9a\u3068\u306a\u3063\u3066\u3044\u308b\u3002<br><br>\u2192 \u4eca\u56de\u306f\u30eb\u30fc\u30c8\u30d5\u30a9\u30eb\u30c0\u306b<code>ormconfig.json<\/code>\u3092\u914d\u7f6e\u3059\u308b\u3053\u3068\u3067\u6b63\u5e38\u306bmigration\u304c\u52d5\u4f5c\u3059\u308b\u3088\u3046\u306b\u306a\u3063\u305f\u3002<\/p>\n\n\n\n<p><a href=\"https:\/\/github.com\/typeorm\/typeorm\/blob\/master\/docs\/using-ormconfig.md?fbclid=IwAR1tHftsx0xfmFfZY052AsIyBeLaAuH343E484j1BHpND50N8vkk76FuLFc#using-environment-variables\">\u3053\u3061\u3089<\/a>\u3092\u53c2\u7167\u3057\u305f\u306e\u3067\u30b7\u30a7\u30a2<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u306f\u3058\u3081\u306b \u4eca\u56de\u306fNestJS\u3082\u305d\u3046\u3067\u3059\u304c\u3001 \u305d\u3082\u305d\u3082TypeScript\u3082TypeORM\u3082\u521d\u3081\u3066\u306a\u30c1\u30e3\u30ec\u30f3\u30b8\u30f3\u30b0\u306a\u958b\u767a\u3067\u3001 DB\u30b9\u30ad\u30fc\u30de\u306e\u5909\u66f4\u3092\u884c\u3044\u305f\u3044\u305f\u3081\u3001\u8272\u3005\u53c2\u8003\u306b\u3057\u306a\u304c\u3089\u9032\u3081\u3066\u3044\u306a\u304c\u3089\u3082\u3001\u72d9\u3063\u305f\u30d5\u30a9\u30eb\u30c0\u306bmigra &#8230; <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"om_disable_all_campaigns":false,"footnotes":""},"categories":[1],"tags":[],"class_list":{"0":"post-80","1":"post","2":"type-post","3":"status-publish","4":"format-standard","6":"category-uncategorized","7":"entry","8":"nothumb"},"acf":[],"aioseo_notices":[],"mb":[],"mfb_rest_fields":["title","aioseo_notices"],"_links":{"self":[{"href":"https:\/\/oidema-jp.com\/media\/wp-json\/wp\/v2\/posts\/80","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/oidema-jp.com\/media\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/oidema-jp.com\/media\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/oidema-jp.com\/media\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/oidema-jp.com\/media\/wp-json\/wp\/v2\/comments?post=80"}],"version-history":[{"count":1,"href":"https:\/\/oidema-jp.com\/media\/wp-json\/wp\/v2\/posts\/80\/revisions"}],"predecessor-version":[{"id":498,"href":"https:\/\/oidema-jp.com\/media\/wp-json\/wp\/v2\/posts\/80\/revisions\/498"}],"wp:attachment":[{"href":"https:\/\/oidema-jp.com\/media\/wp-json\/wp\/v2\/media?parent=80"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/oidema-jp.com\/media\/wp-json\/wp\/v2\/categories?post=80"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/oidema-jp.com\/media\/wp-json\/wp\/v2\/tags?post=80"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}