GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages


Manual Reference Pages  -  SQL::TRANSLATOR::DIFF (3)

.ds Aq ’

NAME

SQL::Translator::Diff - determine differences between two schemas

CONTENTS

DESCRIPTION

Takes two input SQL::Translator::Schemas (or SQL files) and produces ALTER statements to make them the same

SNYOPSIS

Simplest usage:



 use SQL::Translator::Diff;
 my $sql = SQL::Translator::Diff::schema_diff($source_schema, MySQL, $target_schema, MySQL, $options_hash)



OO usage:



 use SQL::Translator::Diff;
 my $diff = SQL::Translator::Diff->new({
   output_db     => MySQL,
   source_schema => $source_schema,
   target_schema => $target_schema,
   %$options_hash,
 })->compute_differences->produce_diff_sql;



OPTIONS

<B>ignore_index_namesB> Match indexes based on types and fields, ignoring name.
<B>ignore_constraint_namesB> Match constrains based on types, fields and tables, ignoring name.
<B>output_dbB> Which producer to use to produce the output.
<B>case_insensitiveB> Ignore case of table, field, index and constraint names when comparing
<B>no_batch_altersB> Produce each alter as a distinct ALTER TABLE statement even if the producer supports the ability to do all alters for a table as one statement.
<B>ignore_missing_methodsB> If the diff would need a method that is missing from the producer, just emit a comment showing the method is missing, rather than dieing with an error
<B>producer_argsB> Hash of extra arguments passed to new in SQL::Translator and the below PRODUCER FUNCTIONS.

PRODUCER FUNCTIONS

The following producer functions should be implemented for completeness. If any of them are needed for a given diff, but not found, an error will be thrown.
o alter_create_constraint($con, $args)
o alter_drop_constraint($con, $args)
o alter_create_index($idx, $args)
o alter_drop_index($idx, $args)
o add_field($fld, $args)
o alter_field($old_fld, $new_fld, $args)
o rename_field($old_fld, $new_fld, $args)
o drop_field($fld, $args)
o alter_table($table, $args)
o drop_table($table, $args)
o rename_table($old_table, $new_table, $args) (optional)
o batch_alter_table($table, $hash, $args) (optional)

If the producer supports batch_alter_table, it will be called with the table to alter and a hash, the keys of which will be the method names listed above; values will be arrays of fields or constraints to operate on. In the case of the field functions that take two arguments this will appear as an array reference.

I.e. the hash might look something like the following:



 {
   alter_create_constraint => [ $constraint1, $constraint2 ],
   add_field   => [ $field ],
   alter_field => [ [$old_field, $new_field] ]
 }



o preprocess_schema($schema) (optional)

preprocess_schema is called by the Diff code to allow the producer to normalize any data it needs to first. For example, the MySQL producer uses this method to ensure that FK constraint names are unique.

Basicaly any changes that need to be made to produce the SQL file for the schema should be done here, so that a diff between a parsed SQL file and (say) a parsed DBIx::Class::Schema object will be sane.

(As an aside, DBIx::Class, for instance, uses the presence of a preprocess_schema function on the producer to know that it can diff between the previous SQL file and its own internal representation. Without this method on th producer it will diff the two SQL files which is slower, but known to work better on old-style producers.)

AUTHOR

Original Author(s) unknown.

Refactor/re-write and more comprehensive tests by Ash Berlin ash@cpan.org.

Redevelopment sponsored by Takkle Inc.

Search for    or go to Top of page |  Section 3 |  Main Index


perl v5.20.3 SQL::TRANSLATOR::DIFF (3) 2014-09-25

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with manServer 1.07.