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

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

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

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

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

2回答

955閲覧

【Rails】モデルのカラムの型でjsonとは何か?

NCC1701

総合スコア1680

JSON

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

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2023/05/29 06:25

カラムタイプに json が使えるようなのだが、どう把握してよいのでしょうか?

ドキュメント(モデルの生成)にも書かれていない。一方で、rails g model User dict:jsonとしてもエラーはでません。(dict:hashとするとエラー)

ruby

1class CreateUsers < ActiveRecord::Migration[7.0] 2 def change 3 create_table :users do |t| 4 t.json :dict 5 6 t.timestamps 7 end 8 end 9end
  1. ドキュメントがないということは json タイプは非公式の型?
  2. ruby のコード上での扱いは Hash でよいのか?つまり、値を取得(上の例だとuser.dict)すればそのクラスは Hash?(そのように振る舞っているように見える)
  3. 値を設定するときは Hash で渡せば良い?(user.dict = {name: "Alice"}
  4. 永続化のDB(sqlite、PostgreSQL、MySQL など)で違いはない?
  5. キーやバリューの制限など値の制限は json の制限に従えば良い?それとも Hash の制限?
  6. どこかにドキュメントはある?

よろしくお願いします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

jsonの型はRailsのAPI一覧のサイトでも書かれており、MySQLなどでも利用可能です。
https://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/Table.html#method-i-column

jsonb型はPostgreSQL専用です。
https://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/PostgreSQL/ColumnMethods.html#method-i-jsonb

投稿2023/05/29 09:59

hatsu

総合スコア1809

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

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

NCC1701

2023/05/30 07:11

ありがとうございました。試行錯誤をしなくて良いので助かります。
guest

0

ドキュメントがないということは json タイプは非公式の型?

いえ、Rails Guideには記載があります。当該のドキュメントに載っていないだけです。

永続化のDB(sqlite、PostgreSQL、MySQL など)で違いはない?

上のRails Guideのリンクにあるように、PostgreSQL専用です。

投稿2023/05/29 09:17

maisumakun

総合スコア145360

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

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

NCC1701

2023/05/30 07:12

ありがとうございました。見つけられずに若干悔しいです。
shinoharat
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.44%

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

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

質問する

関連した質問