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

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

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

Knex.jsは、JavaScript用のSQLクエリを生成するために用いるSQLクエリビルダです。また、Bookshelf.jsと呼ばれるORマッパーの基幹モジュールでもあります。

Node.js

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

JavaScript

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

Q&A

解決済

1回答

517閲覧

Bookshelfjsを使用して、中間テーブルを用いたリレーション間の絞り込み検索を実現したい

soak

総合スコア21

Knex.js

Knex.jsは、JavaScript用のSQLクエリを生成するために用いるSQLクエリビルダです。また、Bookshelf.jsと呼ばれるORマッパーの基幹モジュールでもあります。

Node.js

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

JavaScript

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

0グッド

0クリップ

投稿2018/05/15 07:49

編集2018/05/16 10:00

nodejs + knex + bookshelf (typescript)で、ブログのバックエンドのようなものを作っています。
ブログでよくある「特定のタグを含むエントリー」を一覧で取得したいのですが、タグとエントリーは中間テーブルで関連を定義していて、こういった場合の検索方法が分からず困っています。
bookshelfを使ってリレーション先を展開する事は出来たのですが…

テーブルの構成と、Bookshelfでのテーブル定義は以下の通りです。

テーブルとその構成

entry - id - content - author tag - id - name entry_tag - id - entry - tag

Bookshelfで定義したモデル

インポートは省略しています。

tag.ts

typescript

1export default class Tag extends bookshelf.Model<Tag>{ 2 get tableName(){return "tag";} 3}

tag_entry.ts

typescript

1export default class EntryTag extends bookshelf.Model<EntryTag>{ 2 get tableName(){return "entry_tag";} 3}

entry.ts

typescript

1export default class Entry extends bookshelf.Model<Entry>{ 2 3 get tableName(){return "entry";} 4 tags(){ 5 return this.belongsToMany(Tag, "entry_tag", "entry", "tag", "id", "id"); 6 } 7 8}

試してみたコード

entry.ts内で作っているtagsに対して検索をかけてみているのですが、

typescript

1let model=new Entry(); 2model.where("tags", 1).fetchAll({withRelated:["tags"]}).then(v=>{ 3 console.log(v); 4}).catch(e=>{ 5 console.log(e); 6})

(当然?)そんなカラムはありませんと怒られてしまいます。

{ Error: SQLITE_ERROR: no such column: tags errno: 1, code: 'SQLITE_ERROR' }

直接sqlを発行?

以下の記事を見るとsql的にベストプラクティスがあるようなのですが、これをBookshelfを用いて実行する方法が分かりません。

https://qiita.com/ak-ymst/items/506ae4f176596488d1ac

knex等を使用してsqlを発行する事は出来ると思うのですが、そうするとリレーションの展開を結局自力でやる必要が出てきて、bookshelfを使用しているメリットが生かせなそうだなと思っています。

以上になります。
宜しくお願いします。

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

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

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

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

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

guest

回答1

0

自己解決

結局Bookshelfにはその機能が無いようで、modelをfetchする時にknexのqueryを直接自分で発行する事にしました。

typescript

1let model=new EntryModel(); 2model.query(builder=>{ 3 builder.innerJoin("entry_tag", function(){ 4 this.on("entry_tag.entry", "entry.id"); 5 this.andOn("entry_tag.tag",  knex.raw("?", [1])); 6 }); 7}).fetchAll().then(v=>{ 8 console.log(v.toJSON()); 9}).catch(e=>{ 10 console.log(e); 11})

Bookshelfだけの機能でどうにかするのではなく、knexも絡めて使っていくのが良さそうです。

投稿2018/05/23 07:24

編集2018/05/23 08:06
soak

総合スコア21

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問