その方が単純に情報量が増えるため 最初 boolean にしてたけど後から時刻もほしくなるということはよくある。後から日時型のカラムに変えようと思っても、過去のイベントの日時は失われてしまっていて困る。今は日時が必要でないように感じても日時にしておく方がよい。 またアプリケーション的に使わなくても、データ分析のためにあると嬉しいことは多い。 コード的にも特に扱いにくくなることはない 以下のようにして簡単に boolean と同じ感覚で扱うことができる。 class Post < ApplicationRecord scope :unpublished, -> { where(published_at: nil) } scope :published, -> { where.not(published_at: nil) } def published? !published_at.nil?
![Boolean のカラムを生やす前に考えたいこと](https://cdn-ak-scissors.b.st-hatena.com/image/square/855b92f6b3154fd7717feb4c345c0ae97e2b6d6e/height=288;version=1;width=512/https%3A%2F%2Fres.cloudinary.com%2Fzenn%2Fimage%2Fupload%2Fs--QUMOJHJJ--%2Fc_fit%252Cg_north_west%252Cl_text%3Anotosansjp-medium.otf_55%3ABoolean%252520%2525E3%252581%2525AE%2525E3%252582%2525AB%2525E3%252583%2525A9%2525E3%252583%2525A0%2525E3%252582%252592%2525E7%252594%25259F%2525E3%252582%252584%2525E3%252581%252599%2525E5%252589%25258D%2525E3%252581%2525AB%2525E8%252580%252583%2525E3%252581%252588%2525E3%252581%25259F%2525E3%252581%252584%2525E3%252581%252593%2525E3%252581%2525A8%252Cw_1010%252Cx_90%252Cy_100%2Fg_south_west%252Cl_text%3Anotosansjp-medium.otf_37%3AShingo%252520Tomioka%252Cx_203%252Cy_121%2Fg_south_west%252Ch_90%252Cl_fetch%3AaHR0cHM6Ly9saDMuZ29vZ2xldXNlcmNvbnRlbnQuY29tL2EvQUFUWEFKd3NYellpYkxRVzdvTWREOEl0dl9FWlhQRVN5UFRveWdLZDVIMWg9czk2LWM%3D%252Cr_max%252Cw_90%252Cx_87%252Cy_95%2Fv1627283836%2Fdefault%2Fog-base-w1200-v2.png)