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

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

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

MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

2307閲覧

MongoDB:collection内の全フィールド名を取得

u1men

総合スコア7

MongoDB

MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2018/02/19 10:45

前提・実現したいこと

MongoDBの調査を始めたばかりの段階で、初心者すぎる質問かもしれないことをご容赦ください。

collection内の全フィールド名を取得することはできないでしょうか。

目的はUI(PHPで作成予定)からの検索時に対象条件フィールドをドロップダウンから選択したく、
DB内のフィールド情報を取得できれば可変にできるのでは、と考えたからです。

通常のRDBではまずやらないことですが、スキーマレスということもあり、フィールドが定まらないということで、上記のように考えました。

調べた限り、スキーマレスであれども外での管理は必要なのかな、という気がしています。

全データを舐めれば可能だということは解るのですが、大量データとなったとき非効率であることは明白です。

右も左もわからぬ中、識者の方のお知恵を頂ければ幸いです。

###バージョン等
MongoDB : v3.6.2
PHP : Version 7.1.8 (Xampp環境)

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

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

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

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

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

guest

回答1

0

ベストアンサー

collection内の全フィールド名を取得することはできないでしょうか。

MongoDB の(というか NoSQL データベース)の設計思想から index 以外のメタデータをコレクションに持っておらず、不可能だと思います。

目的はUI(PHPで作成予定)からの検索時に対象条件フィールドをドロップダウンから選択したく、

プログラムからスキーマを生成して、オブジェクトの挿入、更新時にフィールドが増えていれば、自動的に追加するとかすればでできそうです。使われなくなったフィールドを消すために別途バッチで削除するとかもいるかもしれません。

ただし、普通はスキーマはプログラマがメンテナンスできるはずなので、フィールドが頻繁に変化するのでなければ、自動的にスキーマをメンテナナスするプログラムの開発コストを回収できないと思います。

スキーマを yaml とかで設定ファイルに記載しておいて、そこから、ドロップダウンリストの選択肢を生成するくらいがよいのではないでしょうか。

投稿2018/02/19 11:13

mit0223

総合スコア3401

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

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

u1men

2018/02/20 01:08

mit0223さま、早速のご回答ありがとうございました! メタデータにフィールド情報は持っていないのですね。この部分については諦めがつきました!! 大変助かりました。 スキーマの変更ですが、UIを通してユーザが任意で項目を増やせるようにしたいと考えていましたので、 (このあたり説明不足にて申し訳ございません)お知恵を頂いたプログラムを通して管理する方法を検討してみたいと思います。 今次は大変ありがとうございました。また何かあればお助けください。何卒よろしくお願いします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問