Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Django:bagaimana mendapatkan order_detail_data sesuai order_id

Jika Anda menggunakan kueri mentah, Anda hanya perlu menggabungkan data. Sesuatu seperti ini seharusnya berhasil,

def merge_order_data_and_detail(orders, details):
  """Group details by order_id and merge it in orders."""
  # create dictionary key:order_id value:[order_detail_data]
  dic = {}
  for d in details:
    if d['order_id'] not in dic:
      dic[d['order_id']] = []
    dic[d['order_id']].append(d)
  # iterate orders and add details
  for o in orders:
    if o['order_id'] in dic:
      o['order_detail_data'] = dic[o['order_id']]

orders = [
  {
      "order_id": 1,
      "user_id": 5
  },
  {
      "order_id": 2,
      "user_id": 50
  }    
]
details = [
  {
      "order_detail_id": 1,
      "order_id": 1,
      "user_id": 5,
      "product_id": 202
  },
  {
      "order_detail_id": 2,
      "order_id": 1,
      "user_id": 5,
      "product_id": 203
  },
  {
      "order_detail_id": 3,
      "order_id": 2,
      "user_id": 50,
      "product_id": 402
  },
  {
      "order_detail_id": 4,
      "order_id": 2,
      "user_id": 50,
      "product_id": 403
  }
]
merge_order_data_and_detail(orders, details)
print(orders)

Hasil:

[{'order_id': 1, 'user_id': 5, 'order_detail_data': [{'order_detail_id': 1, 'order_id': 1, 'user_id': 5, 'product_id': 202}, {'order_detail_id': 2, 'order_id': 1, 'user_id': 5, 'product_id': 203}]}, {'order_id': 2, 'user_id': 50, 'order_detail_data': [{'order_detail_id': 3, 'order_id': 2, 'user_id': 50, 'product_id': 402}, {'order_detail_id': 4, 'order_id': 
2, 'user_id': 50, 'product_id': 403}]}]

Saya menghapus banyak pesanan dan atribut detail hanya untuk mempermudah pengujian.

Saya tidak memiliki gambaran keseluruhan, tetapi harus berpikir dalam menggunakan model Django jika Anda belum menggunakannya. Ini adalah cara untuk memanfaatkan potensi penuh dari kerangka kerja.

Semoga membantu.




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySql.Data.MySqlClient.MySqlException:Batas waktu kedaluwarsa

  2. Mysql -- 30 hari terakhir

  3. cara mereset kata sandi pengguna root di meja kerja MySQL

  4. Setara dengan varchar (maks) di MySQL?

  5. Bagaimana cara mengatasi jenis bidang integer yang tidak ditandatangani yang tidak didukung di MS SQL?