5
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

structure.sqlを使いたい!

Posted at

はじめに

Railsではdb:migrateすると、デフォルトでdb/schema.rbを生成されて、このファイルでスキーマ管理をしてくれます。
しかし、ユニークインデックスにwhereを付けるようなRDB固有の命令については、Rails標準のschema.rbで管理し続けるのは限界があるのではないかという問題点があります。
それを解決してくれるのがstructure.sqlで、SQLでスキーマ情報を管理することも可能です。

structure.sql生成方法

config/application.rbに以下を記述して、rails db:migrateを実行することで生成されます。

config/application.rb
config.active_record.schema_format = :sql # デフォルトでは「:ruby」となっています

structure.sqlをロードする

生成されたstructure.sqlファイルは、下記のコマンドでデータベースへロードできます。

$ rails db:structure:load

SQLファイルだけ欲しい場合

SQLダンプファイルのみが欲しい場合は、下記コマンドでstructure.sqlのみを生成することができます。

$ rails db:structure:dump

注意点

migrationファイルに基づいてstructure.sqlは更新されていくので、中身を変更したい時は手動では無くrails db:migrate:resetなどでmigrationを実行し直す。

終わりに

最近では、structure.sqlでスキーマ管理することも増えてきている?っぽいので、どういったものか?ということくらいは掴んでおいた方がいいかもしれないですね!

5
3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?