2016-05-01 7 views
0

私はruby 2.2でrails 4.2を使用しています。 私はいくつかのデータをハッシュ形式で列の中に保存しようとしています。列をシリアライズして保存する

私はtextデータ型であるlicense欄にライセンスの詳細を保存しようとしている、と私は与えてくれたそれぞれのモデルに:

serialize :license, JSON 

私はコントローラでこれを持っている:

params.require(:company_detail).permit(:company_name, :trading_name, :contact_name, :acn, :address, :suburb, :state, :post_code, :phone_number, :fax_number, :nrma_approved, :start_date, :release_date , :website_url ,:email, license: {date1: :date1, license1: :license1, date2: :date2, license2: :license2, date3: :date3, license3: :license3, date4: :date4, license4: :license4}) 
私が入る試み

及び形態で

= form_for @company_detail, remote: true, html: {class: 'form-horizontal form-label-left', data: {"parsley-validate" => ""}} do |f| 
     = f.fields_for :license do |l| 
     .row 
      .col-lg-6 
      .form-group 
       %label.control-label.col-md-4.col-xs-12 Date 1 
       .col-md-8.col-xs-12 
       = l.text_field :date1, value: @company_detail.license.present? ? @company_detail.license["date1"] : '', class: 'date-picker form-control has-feedback-left datePicker' 
      .col-lg-6 
      .form-group 
       %label.control-label.col-md-4.col-xs-12 Licence Number 1 
       .col-md-8.col-xs-12 
       = l.text_field :license1, value: @company_detail.license.present? ? @company_detail.license["license1"] : '', class: 'form-control' 

フォーム内のいくつかのフィールドが送信されますが、パラメータが正しく入力されていても保存される値はnullです。これは、ログです:

Parameters: {"utf8"=>"✓", "company_detail"=>{"license"=>{"date1"=>"121212", "license1"=>"12313", "date2"=>"122131123", "license2"=>"123123", "date3"=>"", "license3"=>"", "date4"=>"", "license4"=>""}}, "commit"=>"Save", "id"=>"1"} 
CompanyDetail Load (0.3ms) SELECT "company_details".* FROM "company_details" WHERE "company_details"."id" = $1 LIMIT 1 [["id", 1]] 
User Load (0.8ms) SELECT "users".* FROM "users" WHERE "users"."id" = $1 ORDER BY "users"."id" ASC LIMIT 1 [["id", 1]] 
(1.0ms) BEGIN 
SQL (0.4ms) UPDATE "company_details" SET "license" = $1, "updated_at" = $2 WHERE "company_details"."id" = $3 [["license", "{\"date1\":null,\"license1\":null,\"date2\":null,\"license2\":null,\"date3\":null,\"license3\":null,\"date4\":null,\"license4\":null}"], ["updated_at", "2016-05-01 12:15:44.918547"], ["id", 1]] 
+0

はPostgreSQL v9.4でjsonbデータ型のみを導入した注意してください、私はあなたが直接これらを使用して回避することができます 'json'データ型があると考えています。 – Alfie

+0

@ Alfie i '、postgresを使用して、どうすればよいですか? –

+0

シリアル化された列のどこでクエリを実行できますか? –

答えて

0

licenceのためのあなたの強いパラメータのためにこれを試してみてください:

license: [:date1, :license1, :date2, :license2, :date3, :license3, :date4, :license4]

+0

こんにちは@ tirdadcあなたの答えが助けられました、私はシリアライズされた列でクエリを行うことができます –

+0

あなたはデータ@Alfieが示唆するように、あなたのカラムにJSONBデータ型を使うべきです。シリアライズされたデータは、主に読み取り/書き込み用です。 – tirdadc

+0

JSONBの使い方の詳細は、このSOの回答を参照してください(Rails 4.2以降も必要です):http://stackoverflow.com/questions/27462929/how-to-make-rails-4-2-work-with- postgres-jsonb – tirdadc

0

あなたはデシベルとしてはpostgresを使用している場合は、あなたがあなたのカラムのデータ型としてjson使用することができます。

はこちらを参照してください - ActiveRecord JSON

あなたはJSONのフィールドをクエリに探しているなら、あなたはjsonbフィールドを使用する必要があります。あなたはpostgresのを使用している場合Reference

しかし

関連する問題