Package org.apache.openjpa.jdbc.meta
Class MappingTool
- java.lang.Object
- 
- org.apache.openjpa.jdbc.meta.MappingTool
 
- 
- All Implemented Interfaces:
- MetaDataModes
 
 public class MappingTool extends java.lang.Object implements MetaDataModes Tool for manipulating class mappings and associated schema.- Author:
- Abe White
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classMappingTool.FlagsRun flags.static interfaceMappingTool.ImportExportHelper used to import and export mapping data.
 - 
Field SummaryFields Modifier and Type Field Description static java.lang.StringACTION_ADDstatic java.lang.StringACTION_BUILD_SCHEMAstatic java.lang.StringACTION_DROPstatic java.lang.StringACTION_DROP_SCHEMAstatic java.lang.StringACTION_EXPORTstatic java.lang.StringACTION_IMPORTstatic java.lang.StringACTION_REFRESHstatic java.lang.StringACTION_SCRIPT_CREATEstatic java.lang.StringACTION_SCRIPT_DROPstatic java.lang.StringACTION_SCRIPT_LOADstatic java.lang.StringACTION_VALIDATEstatic java.lang.String[]ACTIONSstatic java.lang.StringSCHEMA_ACTION_NONE- 
Fields inherited from interface org.apache.openjpa.meta.MetaDataModesMODE_ALL, MODE_ANN_MAPPING, MODE_MAPPING, MODE_MAPPING_INIT, MODE_META, MODE_NONE, MODE_QUERY
 
- 
 - 
Constructor SummaryConstructors Constructor Description MappingTool(JDBCConfiguration conf, java.lang.String action, boolean meta)Constructor.MappingTool(JDBCConfiguration conf, java.lang.String action, boolean meta, java.lang.ClassLoader loader)Constructor.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclear()Reset the internal repository.java.lang.StringgetAction()The action supplied on construction.booleangetDropUnusedComponents()Whether schema components that are unused by any mapping will be dropped from this tool'sSchemaGroup, and, depending on the schema action, from the database.booleangetForeignKeys()Whether foreign keys on existing tables should be manipulated.booleangetIgnoreErrors()Whether and SQL errors should cause a failure or just issue a warning.booleangetIndexes()Whether indexes on existing tables should be manipulated.java.io.WritergetMappingWriter()The stream to export the planned mappings to as an XML document.java.io.FilegetMetaDataFile()If adding metadata, the metadata file to add to.booleangetPrimaryKeys()Whether primary keys on existing tables should be manipulated.booleangetReadSchema()Set to true to read the entire schema before mapping.MappingRepositorygetRepository()Return the repository to use to access mapping information.booleangetRollbackBeforeDDL()If true, rollback will be performed before each DDL statement is executed.java.lang.StringgetSchemaAction()The schema modification policy, ornone.SchemaGroupgetSchemaGroup()Return the schema group to use in mapping.java.io.WritergetSchemaWriter()The stream to export the planned schema to as an XML document.booleangetSequences()Whether to manipulate sequences.booleanisMetaDataAction()Whether the action works on metadata as well as mappings.static voidmain(java.lang.String[] arguments)Usage: java org.apache.openjpa.jdbc.meta.MappingTool [option]* [-action/-a <refresh | add | buildSchema | drop | validate | import | export>] <class name | .java file | .class file | .jdo file>* Where the following options are recognized.voidrecord()Records the changes that have been made to both the mappings and the associated schema, and clears the tool for further use.voidrecord(MappingTool.Flags flags)voidrun(java.lang.Class<?> cls)Run the configured action on the given instance.static booleanrun(JDBCConfiguration conf, java.lang.String[] args, MappingTool.Flags flags, java.lang.ClassLoader loader)Run the tool.static booleanrun(JDBCConfiguration conf, java.lang.String[] args, Options opts, java.lang.ClassLoader loader)Run the tool.voidsetDropUnusedComponents(boolean dropUnused)Whether schema components that are unused by any mapping will be dropped from this tool'sSchemaGroup, and, depending on the schema action, from the database.voidsetForeignKeys(boolean fks)Whether foreign keys on existing tables should be manipulated.voidsetIgnoreErrors(boolean ignoreErrors)Whether and SQL errors should cause a failure or just issue a warning.voidsetIndexes(boolean indexes)Whether indexes on existing tables should be manipulated.voidsetMappingWriter(java.io.Writer mappingWriter)The stream to export the planned mappings to as an XML document.voidsetMetaDataFile(java.io.File file)If adding metadata, the metadata file to add to.voidsetPrimaryKeys(boolean pks)Whether primary keys on existing tables should be manipulated.voidsetReadSchema(boolean readSchema)Set to true to read the entire schema before mapping.voidsetRepository(MappingRepository repos)Set the repository to use to access mapping information.voidsetRollbackBeforeDDL(boolean rollbackBeforeDDL)If true, rollback will be performed before each DDL statement is executed.voidsetSchemaAction(java.lang.String schemaAction)The schema modification policy, ornone.voidsetSchemaGroup(SchemaGroup schema)Set the schema to use in mapping.voidsetSchemaTool(SchemaTool tool)Set the schema tool to use for schema modification.voidsetSchemaWriter(java.io.Writer schemaWriter)The stream to export the planned schema to as an XML document.voidsetSequences(boolean seqs)Whether to manipulate sequences.
 
- 
- 
- 
Field Detail- 
SCHEMA_ACTION_NONEpublic static final java.lang.String SCHEMA_ACTION_NONE - See Also:
- Constant Field Values
 
 - 
ACTION_ADDpublic static final java.lang.String ACTION_ADD - See Also:
- Constant Field Values
 
 - 
ACTION_REFRESHpublic static final java.lang.String ACTION_REFRESH - See Also:
- Constant Field Values
 
 - 
ACTION_BUILD_SCHEMApublic static final java.lang.String ACTION_BUILD_SCHEMA - See Also:
- Constant Field Values
 
 - 
ACTION_DROPpublic static final java.lang.String ACTION_DROP - See Also:
- Constant Field Values
 
 - 
ACTION_DROP_SCHEMApublic static final java.lang.String ACTION_DROP_SCHEMA - See Also:
- Constant Field Values
 
 - 
ACTION_VALIDATEpublic static final java.lang.String ACTION_VALIDATE - See Also:
- Constant Field Values
 
 - 
ACTION_EXPORTpublic static final java.lang.String ACTION_EXPORT - See Also:
- Constant Field Values
 
 - 
ACTION_IMPORTpublic static final java.lang.String ACTION_IMPORT - See Also:
- Constant Field Values
 
 - 
ACTION_SCRIPT_CREATEpublic static final java.lang.String ACTION_SCRIPT_CREATE - See Also:
- Constant Field Values
 
 - 
ACTION_SCRIPT_DROPpublic static final java.lang.String ACTION_SCRIPT_DROP - See Also:
- Constant Field Values
 
 - 
ACTION_SCRIPT_LOADpublic static final java.lang.String ACTION_SCRIPT_LOAD - See Also:
- Constant Field Values
 
 - 
ACTIONSpublic static final java.lang.String[] ACTIONS 
 
- 
 - 
Constructor Detail- 
MappingToolpublic MappingTool(JDBCConfiguration conf, java.lang.String action, boolean meta) Constructor. Supply configuration and action.
 - 
MappingToolpublic MappingTool(JDBCConfiguration conf, java.lang.String action, boolean meta, java.lang.ClassLoader loader) Constructor. Supply configuration and action.
 
- 
 - 
Method Detail- 
getActionpublic java.lang.String getAction() The action supplied on construction.
 - 
isMetaDataActionpublic boolean isMetaDataAction() Whether the action works on metadata as well as mappings.
 - 
getSchemaActionpublic java.lang.String getSchemaAction() The schema modification policy, ornone. See the ACTION constants inSchemaTool. May be a comma-separated list of values. Defaults toSchemaTool.ACTION_ADD.
 - 
setSchemaActionpublic void setSchemaAction(java.lang.String schemaAction) The schema modification policy, ornone. See the ACTION constants inSchemaTool. May be a comma-separated list of values. Defaults toSchemaTool.ACTION_ADD.
 - 
getReadSchemapublic boolean getReadSchema() Set to true to read the entire schema before mapping. Leaving this option false saves time, but is dangerous when adding new mappings, because without full knowledge of the existing schema the mapping tool might create tables or indexes that conflict with existing components.
 - 
setReadSchemapublic void setReadSchema(boolean readSchema) Set to true to read the entire schema before mapping. Leaving this option false saves time, but is dangerous when adding new mappings, because without full knowledge of the existing schema the mapping tool might create tables or indexes that conflict with existing components.
 - 
getSequencespublic boolean getSequences() Whether to manipulate sequences. Defaults to true.
 - 
setSequencespublic void setSequences(boolean seqs) Whether to manipulate sequences. Defaults to true.
 - 
getIndexespublic boolean getIndexes() Whether indexes on existing tables should be manipulated. Defaults to false.
 - 
setIndexespublic void setIndexes(boolean indexes) Whether indexes on existing tables should be manipulated. Defaults to false.
 - 
getForeignKeyspublic boolean getForeignKeys() Whether foreign keys on existing tables should be manipulated. Defaults to false.
 - 
setForeignKeyspublic void setForeignKeys(boolean fks) Whether foreign keys on existing tables should be manipulated. Defaults to false.
 - 
getPrimaryKeyspublic boolean getPrimaryKeys() Whether primary keys on existing tables should be manipulated. Defaults to false.
 - 
setPrimaryKeyspublic void setPrimaryKeys(boolean pks) Whether primary keys on existing tables should be manipulated. Defaults to false.
 - 
getDropUnusedComponentspublic boolean getDropUnusedComponents() Whether schema components that are unused by any mapping will be dropped from this tool'sSchemaGroup, and, depending on the schema action, from the database. Defaults to true.
 - 
setDropUnusedComponentspublic void setDropUnusedComponents(boolean dropUnused) Whether schema components that are unused by any mapping will be dropped from this tool'sSchemaGroup, and, depending on the schema action, from the database. Defaults to true.
 - 
setIgnoreErrorspublic void setIgnoreErrors(boolean ignoreErrors) Whether and SQL errors should cause a failure or just issue a warning.
 - 
getIgnoreErrorspublic boolean getIgnoreErrors() Whether and SQL errors should cause a failure or just issue a warning.
 - 
getRollbackBeforeDDLpublic boolean getRollbackBeforeDDL() If true, rollback will be performed before each DDL statement is executed. Defaults to true.
 - 
setRollbackBeforeDDLpublic void setRollbackBeforeDDL(boolean rollbackBeforeDDL) If true, rollback will be performed before each DDL statement is executed. Defaults to true.
 - 
setSchemaToolpublic void setSchemaTool(SchemaTool tool) Set the schema tool to use for schema modification.
 - 
getSchemaWriterpublic java.io.Writer getSchemaWriter() The stream to export the planned schema to as an XML document. If non-null, then the database schema will not be altered.
 - 
setSchemaWriterpublic void setSchemaWriter(java.io.Writer schemaWriter) The stream to export the planned schema to as an XML document. If non-null, then the database schema will not be altered.
 - 
getMappingWriterpublic java.io.Writer getMappingWriter() The stream to export the planned mappings to as an XML document. If non-null, then the mapping repository will not be altered.
 - 
setMappingWriterpublic void setMappingWriter(java.io.Writer mappingWriter) The stream to export the planned mappings to as an XML document. If non-null, then the mapping repository will not be altered.
 - 
getMetaDataFilepublic java.io.File getMetaDataFile() If adding metadata, the metadata file to add to.
 - 
setMetaDataFilepublic void setMetaDataFile(java.io.File file) If adding metadata, the metadata file to add to.
 - 
getRepositorypublic MappingRepository getRepository() Return the repository to use to access mapping information. Defaults to a newMappingRepository.
 - 
setRepositorypublic void setRepository(MappingRepository repos) Set the repository to use to access mapping information.
 - 
getSchemaGrouppublic SchemaGroup getSchemaGroup() Return the schema group to use in mapping. If none has been set, the schema will be generated from the database.
 - 
setSchemaGrouppublic void setSchemaGroup(SchemaGroup schema) Set the schema to use in mapping.
 - 
clearpublic void clear() Reset the internal repository. This is called automatically after everyrecord().
 - 
recordpublic void record() Records the changes that have been made to both the mappings and the associated schema, and clears the tool for further use. This also involves clearing the internal mapping repository.
 - 
recordpublic void record(MappingTool.Flags flags) 
 - 
runpublic void run(java.lang.Class<?> cls) Run the configured action on the given instance.
 - 
mainpublic static void main(java.lang.String[] arguments) throws java.io.IOException, java.sql.SQLExceptionUsage: java org.apache.openjpa.jdbc.meta.MappingTool [option]* [-action/-a <refresh | add | buildSchema | drop | validate | import | export>] <class name | .java file | .class file | .jdo file>* Where the following options are recognized.- -properties/-p <properties file or resource>: The
 path or resource name of a OpenJPA properties file containing
 information as outlined in OpenJPAConfiguration. Optional.
- -<property name> <property value>: All bean
 properties of the OpenJPA JDBCConfigurationcan be set by using their names and supplying a value. For example:-licenseKey adslfja83r3lkadf
- -file/-f <stdout | output file or resource>: Use
 this option to write the planned mappings to an XML document rather
 than store them in the repository. This option also specifies the
 metadata file to write to if using the addaction with the-meta trueflag, or the file to dump to if using theexportaction.
- -schemaAction/-sa <schema action | none>: The
 SchemaTooldefines the actions possible. The actions will apply to all schema components used by the mappings involved. Unless you are running the mapping tool on all of your persistent types at once, be careful running schema actions that can drop data. It is possible to accidentally drop schema components that are used by classes you aren't currently running the tool over. The action defaults toadd.
- -schemaFile/-sf <stdout | output file or resource>: Use this option to write the planned schema to an XML document rather than modify the data store.
- -sqlFile/-sql <stdout | output file or resource>: Use this option to write the planned schema changes as a SQL script rather than modifying the data store.
- -sqlEncode/-se <encoding>: Use
 this option with the -sqlFileflag to write the SQL script in a different Java character set encoding than the default JVM locale, such asUTF-8.
- -dropTables/-dt <true/t | false/f>: Corresponds to the
 same-named option in the SchemaTool.
- -dropSequences/-dsq <true/t | false/f>: Corresponds
 to the same-named option in the SchemaTool.
- -openjpaTables/-kt <true/t | false/f>: Corresponds to
 the same-named option in the SchemaTool.
- -ignoreErrors/-i <true/t | false/f>: Corresponds to the
 same-named option in the SchemaTool.
- -readSchema/-rs <true/t | false/f>: Set this to true to read the entire existing schema (even when false the parts of the schema used by classes the tool is run on will still be read). Turning on schema reading can ensure that no naming conflicts will occur, but it can take a long time.
- -primaryKeys/-pk <true/t | false/f>: Whether primary keys on existing tables are manipulated. Defaults to false.
- -foreignKeys/-fk <true/t | false/f>: Whether foreign keys on existing tables are manipulated. Defaults to false.
- -indexes/-ix <true/t | false/f>: Whether indexes on existing tables are manipulated. Defaults to false.
- -sequences/-sq <true/t | false/f>: Whether sequences are manipulated. Defaults to true.
- -schemas/-s <schema and table names>: A list of schemas
 and/or tables to read. Corresponds to the
 same-named option in the SchemaGenerator. This option is ignored ifreadSchemais false.
- -meta/-m <true/t | false/f>: Whether the given action applies to metadata as well as mappings.
 - refresh: Bring the mapping information up-to-date with the class definitions. OpenJPA will attempt to use any provided mapping information, and fill in missing information. If the provided information conflicts with the class definition, the conflicting information will be discarded and the class/field will be re-mapped to new columns/tables. This is the default action.
- add: If used with the -metaoption, adds new default metadata for the given class(es). Otherwise, brings the mapping information up-to-date with the class definitions. OpenJPA will attempt to use any provided mapping information, and fill in missing information. OpenJPA will fail if the provided information conflicts with the class definition.
- buildSchema: Create the schema matching the existing mappings for the given class(es). Any invalid mapping information will cause an exception.
- drop: Delete mappings for the given classes. If used with
 the -metaoption, also deletes metadata.
- validate: Validate the given mappings. The mapping repository and schema will not be affected.
- import: Import mappings from an XML document and store them as the current system mappings.
- export: Dump the current mappings for the given classes to
 an XML document specified by the fileoption. 
 If used with the
 -metaoption, the metadata will be included in the export.- Refresh the mappings for given package, without dropping any
 schema components:
 java org.apache.openjpa.jdbc.meta.MappingTool mypackage.jdo
- Refresh the mappings for all persistent classes in the classpath,
 dropping any unused columns and even tables:
 java org.apache.openjpa.jdbc.meta.MappingTool -sa refresh -dt true
- Make sure the mappings you've created by hand match the object
 model and schema:
 java org.apache.openjpa.jbdc.meta.MappingTool -a validate Person.java
- Remove the recorded mapping for a given class:
 java org.apache.openjpa.jbdc.meta.MappingTool -a drop Person.java
- Record the current mappings in an XML file:
 java org.apache.openjpa.jdbc.meta.MappingTool -f mypackage.orm -a export mypackage.jdo
 - Throws:
- java.io.IOException
- java.sql.SQLException
 
- -properties/-p <properties file or resource>: The
 path or resource name of a OpenJPA properties file containing
 information as outlined in 
 - 
runpublic static boolean run(JDBCConfiguration conf, java.lang.String[] args, Options opts, java.lang.ClassLoader loader) throws java.io.IOException, java.sql.SQLException Run the tool. Returns false if invalid options are given.- Throws:
- java.io.IOException
- java.sql.SQLException
- See Also:
- main(java.lang.String[])
 
 - 
runpublic static boolean run(JDBCConfiguration conf, java.lang.String[] args, MappingTool.Flags flags, java.lang.ClassLoader loader) throws java.io.IOException, java.sql.SQLException Run the tool. Return false if an invalid option was given.- Throws:
- java.io.IOException
- java.sql.SQLException
 
 
- 
 
-