What is db/development_structure.sql in a rails project?

后端 未结 4 945
無奈伤痛
無奈伤痛 2020-12-29 06:33

There is a development_structure.sql inside my /db folder of my rails application (rails 2.3.4, ruby 1.8.7) and I am not sure exactly what it does.

相关标签:
4条回答
  • 2020-12-29 07:02

    In rails 3, you don't even have to write this line,

    config.active_record.schema_format = :sql

    You can generate this structure.sql file by simply running the above rake command mentioned above

    0 讨论(0)
  • 2020-12-29 07:04

    This post has been used as a reference by a coworker of mine, but the two answers are not exact or informative enough.

    development_structure.sql is a low-level dump of the schema, which is necessary when you start to use proprietary database features - either you want to or not, you're going to use them at some point.

    Regarding the question of storing it or not, there's some debate. Here is an informative post: http://www.saturnflyer.com/blog/jim/2010/09/14/always-check-in-schema-rb/. And my take on this follows.

    The objective of the development_structure.sql is to sync, for any given commit, the database structure with the code, without having previous knowledge of the schema structure, that is, without having to rely on a pre-existing state of the schema to get the new one.

    In a nutshell, by having a schema structure available, whenever you change branch/commit, you load it directly and forget it. This is mostly valid for dynamic and "crowded" projects, where different branches have differences in the underlying schema structure.

    Without having the schema structure stored, you would need to always use an existing reference schema in your database, and migrate it back or forward every time you change branch/commit; several real-world cases can make this process inefficient (e.g. when another branch doesn't have some migrations you currently have, or some migrations can't be rolled back).

    Another problem is automated builds, which suffer from the same problems, and even worse, they can't apply manual changes.

    The only downside is that it requires a certain habit, which is, to store it every time you run a migration. Easy to say, but also easy to forget.

    I don't say you can't live without development_structure.sql - of course you can. But if you have it, when changing branch/commit you just load-and-forget; if you don't, you [may] have to go through a series of manual steps.

    0 讨论(0)
  • 2020-12-29 07:05

    You should not add it to your git repository.

    It is a file created automatically by rails when you run migrations with your database.yml configured to connect against a mysql database. You can view it as an alternative to schema.rb

    I believe you can force rails to create it by adding in your environment.rb:

    config.active_record.schema_format = :sql
    

    When present this file is used for example by:

    rake db:test:clone_structure
    

    Edit

    Relevant section in Ruby On Rails Guides. http://guides.rubyonrails.org/migrations.html#schema-dumping-and-you

    They recommend to check it into source control on the wiki.

    I personally like to keep it out of it. I like to be able to run all migrations very quickly. It is for me a good sign. If migrations become slow I feel like I am not in total control of my environment anymore. Slowness in migrations generally means I have a lot of data in my development database which I feel wrong.

    However, It seems to be a matter of personal taste nowadays. Follow your instincts on this one.

    0 讨论(0)
  • 2020-12-29 07:05

    It's created when you run a rake task to clone your development database to your test database. The development database is outputted to SQL which is then read in to your test DB. You can safely delete it.

    0 讨论(0)
提交回复
热议问题