Difference between revisions of "Freeside:Documentation:Developer:Schema changes"

From Freeside
Jump to: navigation, search
(Essential documentation)
(Essential documentation)
Line 6: Line 6:
 
=== Essential documentation ===
 
=== Essential documentation ===
  
* The upgrade script will automatically handle new tables as well as new columns, removed columns and changes to indices.  Column changes (other than NULLability) are '''not''' handled.
+
* The upgrade script will automatically handle new tables as well as new columns, removed columns and changes to columns and indices.  Column changes (other than NULLability) require  DBIx::DBSchema version 0.37 or later.
* If other schema changes are required (such as changed columns, renamed or removed tables, etc.), add a quick note to the upgrade instructions at [[Freeside:1.9:Documentation:Upgrading-HEAD]]
+
* If other schema changes are required (such as renamed or removed tables, etc.), add a quick note to the upgrade instructions at [[Freeside:1.9:Documentation:Upgrading-HEAD]]
  
 
=== Skeleton class autogeneration ===
 
=== Skeleton class autogeneration ===

Revision as of 15:25, 27 December 2009

Schema.pm

  • Required
  • Edit the big data structure in FS/FS/Schema.pm and add your tables and columns

Essential documentation

  • The upgrade script will automatically handle new tables as well as new columns, removed columns and changes to columns and indices. Column changes (other than NULLability) require DBIx::DBSchema version 0.37 or later.
  • If other schema changes are required (such as renamed or removed tables, etc.), add a quick note to the upgrade instructions at Freeside:1.9:Documentation:Upgrading-HEAD

Skeleton class autogeneration

  • For new tables. Optional but recommended. We're trying to save you work!
  • Make sure the tables have been added to FS/FS/Schema.pm and run make install-perl-modules
  • From the root freeside directory, run bin/generate-table-module tablename for each table.
  • Edit the resulting FS/FS/table.pm
  • FS/MANIFEST is updated and FS/t/table.t is added. Don't forget to cvs add FS/FS/table.pm and FS/t/table.t and check them in.

Required Documentation

  • For new tables: add to FS/FS.pm

Optional: Documentation looking for adopters or innovative autogeneration

  • somehwat neglected: httemplate/docs/schema.html
  • really neglected: httemplate/docs/schema.dia