LionIQ 数据狮数据狮专注于移动端电商插件开发,让任何 APP 快速完善电商功能。本文章讨论如何用 JSON 属性储存入数据库。
一般电商应用数据库我们可以现象订单对象 Order
与产品对象 Item
的关联,但是也有些情况把订单信息直接以静态 JSON 属性储存入数据库会有优势:
把关系数据列如订单列表项 order_items
直接以 JSON 属性存入数据库会失去所谓订单 Order
于产品 Item
的关联。因而订单信息的互动有限,反而宁愿订单信息生成后固定更改:
另外,在移动 APP 会经常需要把数据转换成 JSON 格式。因此,直接把订单信息储存为 JSON 属性是个方便的选择。我们在 LionIQ 数据狮使用的技术是 Postgresql + Ruby/Rails 5.0, 以下范例以此为主。
创建数据如下:
rails g model Order order_no:uniq user:belongs_to order_infos:jsonb
创建一般的 Order
对象,再加上了一个 order_infos
以 jsonb
的属性装订单信息。[1]
# app/models/order.rb
class Order < ApplicationRecord
belongs_to :shop_user
# jsonb accessors
store :order_infos, accessors: [:address, :order_items, :total_amount]
store_accessor :order_infos
end
数据定义里我们用了 store_accessor
及 store
可以透过 order_infos
参数获取 JSON
数据,以及相应 order_infos
内的参数。
lioniq$ rails c
Running via Spring preloader in process 29470
Loading development environment (Rails 5.0.0)
irb(main):001:0> o = Order.new
=> #<Order id: nil, key: nil, archived: false, user_id: nil, order_infos: {}, created_at: nil, updated_at: nil, order_no: nil>
irb(main):002:0> o.order_infos
=> {}
irb(main):004:0> o.address = "98 Yanping Lu"
=> "98 Yanping Lu"
irb(main):005:0> o.order_items = [{key: "some_item_key", title: "cool tshirt", price: 3000, qty: 1}, {key: "another_key", title: "air jordan V", price: 10000, qty: 1}]
=> [{"key"=>"some_item_key", "title"=>"cool tshirt", "price"=>3000, "qty"=>1}, {"key"=>"another_key", "title"=>"air jordan V", "price"=>10000, "qty"=>1}]
irb(main):006:0>
LionIQ 插件会以 JSON 格式传订单 Order
数据,之后可以传送到你的后台 API 然后保存为以上定义的 Order
数据。因为我们在 model
里定义了 store_accessor
可以很方便的定义 strong parameters
可允许的 JSON 参数传给 Order
初始化方式。
# app/controllers/orders_controller.rb
class OrdersController < ApplicationController
# POST /orders
# POST /orders.json
def create
@order = Order.new(order_params)
# associate user, depending on your authentication
@order.user = current_user
if @order.save
render :show, status: :created, location: @order
else
render json: @order.errors, status: :unprocessable_entity
end
end
private
def order_params
item_params = [:key, :title, :price]
params.require(:order).permit(:order_no, :total_amount, :address,
order_items: [{item: item_params}, :qty])
end
end
本文章采用很简单的 Ruby/Rails + Postgresql 示范如何保存订单信息为 JSON 属性入数据库。你是否需要开发电商 APP 功能?欢迎来到 LionIQ 数据狮 试用我们的 iOS 电商插件, 今天就可以完善电商功能!
欢迎来到我们技术 QQ 群:258693280 或发送邮件:[email protected]