質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

ルーティング

ルーティングとは、TCP/IPネットワークにおいて、目的のホストまでパケットを送る為のパス選定のプロセスを言います。

Q&A

解決済

1回答

1259閲覧

sequelizeのモデルのデータベース操作について

velonica74

総合スコア11

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

ルーティング

ルーティングとは、TCP/IPネットワークにおいて、目的のホストまでパケットを送る為のパス選定のプロセスを言います。

0グッド

0クリップ

投稿2021/07/02 11:57

編集2021/07/02 12:42

sequelizeのモデルのデータベース操作について、現在Node.jsで開発を行なっています。

以下ルーティング処理を行なっているJSのコードです。

Javascript

1router.get('/sell', (req, res, next) => { 2 if (check(req, res)){ return }; 3 db.User.findOne({ 4 where: { 5 name: req.session.login.name 6 } 7 }).then(usr => { 8 console.log(usr.dataValues)

これにより抽出したユーザのデータの出力が

{ id: 1, name: 'Taro', pass: 'yamada', item1: 1, item2: null, item3: 3, item4: 2, item5: null, item6: null, item7: null, item8: null, item9: null, item10: null, createdAt: 2021-07-02T09:02:36.000Z, updatedAt: 2021-07-02T09:02:36.000Z }

となっています。
item1~10の数字はアイテムコードになっていて、Itemモデルにアイテムコードとアイテム名の対応づけがあります。
そこでdb.Itemへの操作を行うことで

[ Item { dataValues: { id: 1, item_name: 'foo', createdAt: 2021-07-02T09:02:36.000Z, updatedAt: 2021-07-02T09:02:36.000Z }, null, Item { dataValues: { id: 3, item_name: 'hoge', createdAt: 2021-07-02T09:02:36.000Z, updatedAt: 2021-07-02T09:02:36.000Z }, Item { dataValues: { id: 2, item_name: 'bar', createdAt: 2021-07-02T09:02:36.000Z, updatedAt: 2021-07-02T09:02:36.000Z } null, null, null, null, null, null ]

のようなに、アイテムコードに対応したレコードを10個分出力させたいのですが、何か良い書き方はないでしょうか。
初心者質問で恐縮ですが、何卒よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

includejoinができるようです

router.get('/sell', (req, res, next) => { if (check(req, res)){ return }; db.User.findOne({ where: { name: req.session.login.name }, include: [{ model: db.item, required: false }] }).then(usr => { console.log(usr.dataValues)

投稿2021/07/03 10:41

dyekv

総合スコア128

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問