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

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

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

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

MongoDB

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

Q&A

解決済

1回答

426閲覧

配列を含むドキュメントの配列内要素に対する並び替えとフィルター

ponyo877

総合スコア17

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

MongoDB

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

0グッド

0クリップ

投稿2021/07/01 14:50

やりたいこと:

処理対象のドキュメントをmongoDBのコマンドで下記した期待する結果を出力したいです。
(一部配列を含まないドキュメントもあります)

処理対象のドキュメント

json

1{ 2 "_id": ObjectId("60ddc26b03edfb7a6b424f10"), 3 "member": [ 4 { 5 "joinDate": "2021-07-01 12:00:00.000", 6 "username": "John" 7 }, 8 { 9 "joinDate": "2021-07-01 13:00:00.000", 10 "username": "Maria" 11 } 12 ], 13 "createdAt": "2021-07-01 11:00", 14 "roomName": "roomA", 15} 16{ 17 "_id": ObjectId("60ddbcccd495870939756dcb"), 18 "member": [ 19 { 20 "joinDate": "2021-07-01 14:00:00.000", 21 "userName": "Jack" 22 }, 23 { 24 "joinDate": "2021-07-01 11:00:00.000", 25 "userName": "George" 26 } 27 ], 28 "createdAt": "2021-07-01 10:00", 29 "roomName": "roomB" 30} 31{ 32 "_id": ObjectId("60ddbcccd495870939756dcc"), 33 "createdAt": "2021-07-01 12:00", 34 "roomName": "roomC" 35}

以下の条件を満たす結果を出力する

  • joinDateが最も新しい要素のみドキュメント内の配列の2つの要素をドキュメントに展開する
  • 更に配列の要素名を変更し(接頭辞にlatestを付与)する
  • ドキュメントをlatestJoinDateの降順に並び替える
  • memberの要素が存在しないドキュメントは出力しない

期待する結果

json

1{ 2 "_id": ObjectId("60ddbcccd495870939756dcb"), 3 "latestJoinDate": "2021-07-01 14:00:00.000", 4 "latestUserName": "Jack", 5 "createdAt": "2021-07-01 10:00", 6 "roomName": "roomB" 7} 8{ 9 "_id": ObjectId("60ddc26b03edfb7a6b424f10"), 10 "latestJoinDate": "2021-07-01 13:00:00.000", 11 "latestUserName": "Maria", 12 "createdAt": "2021-07-01 11:00", 13 "roomName": "roomA", 14}

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

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

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

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

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

guest

回答1

0

自己解決

こちら自己解決しました!
以下が私が求めていたQueryです。

json

1db.collection.aggregate([ 2 { 3 $match: { 4 member: { 5 $exists: true 6 } 7 } 8 }, 9 { 10 $addFields: { 11 member: { 12 $arrayElemAt: [ 13 "$member", 14 { 15 $indexOfArray: [ 16 "$member.joinDate", 17 { 18 $max: "$member.joinDate" 19 } 20 ] 21 } 22 ] 23 } 24 } 25 }, 26 { 27 $project: { 28 createdAt: 1, 29 roomName: 1, 30 latestJoinDate: "$member.joinDate", 31 latestUserName: "$member.userName" 32 } 33 }, 34 { 35 $sort: { 36 latestJoinDate: -1 37 } 38 } 39])

https://mongoplayground.net/p/mYE2Q1tk4ij

投稿2021/07/03 11:59

ponyo877

総合スコア17

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問