org.jooq.meta.jaxb.Database Maven / Gradle / Ivy
package org.jooq.meta.jaxb;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlElementWrapper;
import javax.xml.bind.annotation.XmlList;
import javax.xml.bind.annotation.XmlType;
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
import org.jooq.util.jaxb.tools.StringAdapter;
import org.jooq.util.jaxb.tools.XMLAppendable;
import org.jooq.util.jaxb.tools.XMLBuilder;
/**
* Configuration of the database meta data source.
*
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "Database", propOrder = {
})
@SuppressWarnings({
"all"
})
public class Database implements Serializable, XMLAppendable
{
private final static long serialVersionUID = 31200L;
@XmlJavaTypeAdapter(StringAdapter.class)
protected String name;
@XmlList
@XmlElement(defaultValue = "COMMENTS CASE_INSENSITIVE")
protected List regexFlags;
@XmlElement(defaultValue = "true")
protected Boolean regexMatchesPartialQualification = true;
@XmlElement(defaultValue = "true")
protected Boolean sqlMatchesPartialQualification = true;
@XmlElement(defaultValue = ".*")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String includes = ".*";
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String excludes = "";
@XmlElement(defaultValue = "false")
protected Boolean includeExcludeColumns = false;
@XmlElement(defaultValue = "true")
protected Boolean includeTables = true;
@XmlElement(defaultValue = "true")
protected Boolean includeEmbeddables = true;
@XmlElement(defaultValue = "true")
protected Boolean includeRoutines = true;
@XmlElement(defaultValue = "false")
protected Boolean includeTriggerRoutines = false;
@XmlElement(defaultValue = "true")
protected Boolean includePackages = true;
@XmlElement(defaultValue = "true")
protected Boolean includePackageRoutines = true;
@XmlElement(defaultValue = "true")
protected Boolean includePackageUDTs = true;
@XmlElement(defaultValue = "true")
protected Boolean includePackageConstants = true;
@XmlElement(defaultValue = "true")
protected Boolean includeUDTs = true;
@XmlElement(defaultValue = "true")
protected Boolean includeSequences = true;
@XmlElement(defaultValue = "true")
protected Boolean includeIndexes = true;
@XmlElement(defaultValue = "true")
protected Boolean includePrimaryKeys = true;
@XmlElement(defaultValue = "true")
protected Boolean includeUniqueKeys = true;
@XmlElement(defaultValue = "true")
protected Boolean includeForeignKeys = true;
@XmlElement(defaultValue = "true")
protected Boolean includeCheckConstraints = true;
@XmlElement(defaultValue = "false")
protected Boolean includeSystemIndexes = false;
@XmlElement(defaultValue = "false")
protected Boolean includeSystemCheckConstraints = false;
@XmlElement(defaultValue = "true")
protected Boolean includeInvisibleColumns = true;
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String recordVersionFields = "";
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String recordTimestampFields = "";
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String syntheticIdentities = "";
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String syntheticPrimaryKeys = "";
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String overridePrimaryKeys = "";
@XmlElement(defaultValue = "false")
protected Boolean dateAsTimestamp = false;
@XmlElement(defaultValue = "false")
protected Boolean ignoreProcedureReturnValues = false;
@XmlElement(defaultValue = "true")
protected Boolean unsignedTypes = true;
@XmlElement(defaultValue = "true")
protected Boolean integerDisplayWidths = true;
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String inputCatalog = "";
@XmlJavaTypeAdapter(StringAdapter.class)
protected String outputCatalog;
@XmlElement(defaultValue = "false")
protected Boolean outputCatalogToDefault = false;
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String inputSchema = "";
@XmlJavaTypeAdapter(StringAdapter.class)
protected String outputSchema;
@XmlElement(defaultValue = "false")
protected Boolean outputSchemaToDefault = false;
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String schemaVersionProvider = "";
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String catalogVersionProvider = "";
@XmlElement(defaultValue = "")
@XmlJavaTypeAdapter(StringAdapter.class)
protected String orderProvider = "";
@XmlElement(defaultValue = "true")
protected Boolean forceIntegerTypesOnZeroScaleDecimals = true;
protected Boolean tableValuedFunctions;
@XmlElement(defaultValue = "5")
protected Integer logSlowQueriesAfterSeconds = 5;
@XmlElement(defaultValue = "5")
protected Integer logSlowResultsAfterSeconds = 5;
@XmlElementWrapper(name = "properties")
@XmlElement(name = "property")
protected List properties;
@XmlElementWrapper(name = "catalogs")
@XmlElement(name = "catalog")
protected List catalogs;
@XmlElementWrapper(name = "schemata")
@XmlElement(name = "schema")
protected List schemata;
@XmlElementWrapper(name = "embeddables")
@XmlElement(name = "embeddable")
protected List embeddables;
@XmlElementWrapper(name = "customTypes")
@XmlElement(name = "customType")
protected List customTypes;
@XmlElementWrapper(name = "enumTypes")
@XmlElement(name = "enumType")
protected List enumTypes;
@XmlElementWrapper(name = "forcedTypes")
@XmlElement(name = "forcedType")
protected List forcedTypes;
/**
* The database dialect from jooq-meta.
* Available dialects are named org.util.[database].[database]Database
.
*
* Natively supported values are:
*
* - {@link org.jooq.meta.ase.ASEDatabase}
* - {@link org.jooq.meta.cockroachdb.CockroachDBDatabase}
* - {@link org.jooq.meta.db2.DB2Database}
* - {@link org.jooq.meta.derby.DerbyDatabase}
* - {@link org.jooq.meta.firebird.FirebirdDatabase}
* - {@link org.jooq.meta.h2.H2Database}
* - {@link org.jooq.meta.hana.HanaDatabase}
* - {@link org.jooq.meta.hsqldb.HSQLDBDatabase}
* - {@link org.jooq.meta.informix.InformixDatabase}
* - {@link org.jooq.meta.ingres.IngresDatabase}
* - {@link org.jooq.meta.mariadb.MariaDBDatabase}
* - {@link org.jooq.meta.mysql.MySQLDatabase}
* - {@link org.jooq.meta.oracle.OracleDatabase}
* - {@link org.jooq.meta.postgres.PostgresDatabase}
* - {@link org.jooq.meta.redshift.RedshiftDatabase}
* - {@link org.jooq.meta.sqlite.SQLiteDatabase}
* - {@link org.jooq.meta.sqlserver.SQLServerDatabase}
* - {@link org.jooq.meta.sybase.SybaseDatabase}
* - {@link org.jooq.meta.vertica.VerticaDatabase}
*
*
* This value can be used to reverse-engineer generic JDBC DatabaseMetaData (e.g. for MS Access).
*
* - {@link org.jooq.meta.jdbc.JDBCDatabase}
*
*
* This value can be used to reverse-engineer standard jOOQ-meta XML formats.
*
* - {@link org.jooq.meta.xml.XMLDatabase}
*
*
* This value can be used to reverse-engineer JPA annotated entities
*
* - {@link org.jooq.meta.extensions.jpa.JPADatabase}
*
*
* You can also provide your own org.jooq.meta.Database implementation
* here, if your database is currently not supported
*
*/
public String getName() {
return name;
}
/**
* The database dialect from jooq-meta.
* Available dialects are named org.util.[database].[database]Database
.
*
* Natively supported values are:
*
* - {@link org.jooq.meta.ase.ASEDatabase}
* - {@link org.jooq.meta.cockroachdb.CockroachDBDatabase}
* - {@link org.jooq.meta.db2.DB2Database}
* - {@link org.jooq.meta.derby.DerbyDatabase}
* - {@link org.jooq.meta.firebird.FirebirdDatabase}
* - {@link org.jooq.meta.h2.H2Database}
* - {@link org.jooq.meta.hana.HanaDatabase}
* - {@link org.jooq.meta.hsqldb.HSQLDBDatabase}
* - {@link org.jooq.meta.informix.InformixDatabase}
* - {@link org.jooq.meta.ingres.IngresDatabase}
* - {@link org.jooq.meta.mariadb.MariaDBDatabase}
* - {@link org.jooq.meta.mysql.MySQLDatabase}
* - {@link org.jooq.meta.oracle.OracleDatabase}
* - {@link org.jooq.meta.postgres.PostgresDatabase}
* - {@link org.jooq.meta.redshift.RedshiftDatabase}
* - {@link org.jooq.meta.sqlite.SQLiteDatabase}
* - {@link org.jooq.meta.sqlserver.SQLServerDatabase}
* - {@link org.jooq.meta.sybase.SybaseDatabase}
* - {@link org.jooq.meta.vertica.VerticaDatabase}
*
*
* This value can be used to reverse-engineer generic JDBC DatabaseMetaData (e.g. for MS Access).
*
* - {@link org.jooq.meta.jdbc.JDBCDatabase}
*
*
* This value can be used to reverse-engineer standard jOOQ-meta XML formats.
*
* - {@link org.jooq.meta.xml.XMLDatabase}
*
*
* This value can be used to reverse-engineer JPA annotated entities
*
* - {@link org.jooq.meta.extensions.jpa.JPADatabase}
*
*
* You can also provide your own org.jooq.meta.Database implementation
* here, if your database is currently not supported
*
*/
public void setName(String value) {
this.name = value;
}
/**
* The flags that will be applied to all regular expressions from this configuration by default.
*
* The default value is "COMMENTS CASE_INSENSITIVE"Gets the value of the regexFlags property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a set
method for the regexFlags property.
*
*
* For example, to add a new item, do as follows:
*
* getRegexFlags().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link RegexFlag }
*
*
*/
public List getRegexFlags() {
if (regexFlags == null) {
regexFlags = new ArrayList();
}
return this.regexFlags;
}
/**
* Whether regular expressions that match qualified object names also match partial qualifications (e.g. `table\.column` matches `schema.table.column`) or only full and/or no qualifications (e.g. `schema\.table\.column` and `column` match `schema.table.column`)
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isRegexMatchesPartialQualification() {
return regexMatchesPartialQualification;
}
/**
* Sets the value of the regexMatchesPartialQualification property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setRegexMatchesPartialQualification(Boolean value) {
this.regexMatchesPartialQualification = value;
}
/**
* Whether SQL queries that match qualified object names also match partial qualifications (e.g. `table\.column` matches `schema.table.column`) or only full and/or no qualifications (e.g. `schema\.table\.column` and `column` match `schema.table.column`)
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isSqlMatchesPartialQualification() {
return sqlMatchesPartialQualification;
}
/**
* Sets the value of the sqlMatchesPartialQualification property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setSqlMatchesPartialQualification(Boolean value) {
this.sqlMatchesPartialQualification = value;
}
/**
* All elements that are generated from your schema.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* Watch out for case-sensitivity. Depending on your database, this might be
* important!
*
* You can create case-insensitive regular expressions
* using this syntax: (?i:expr)
*
* Whitespace is ignored and comments are possible unless overridden in {@link #getRegexFlags()}.
*
*/
public String getIncludes() {
return includes;
}
/**
* All elements that are generated from your schema.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* Watch out for case-sensitivity. Depending on your database, this might be
* important!
*
* You can create case-insensitive regular expressions
* using this syntax: (?i:expr)
*
* Whitespace is ignored and comments are possible unless overridden in {@link #getRegexFlags()}.
*
*/
public void setIncludes(String value) {
this.includes = value;
}
/**
* All elements that are excluded from your schema.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* Excludes match before includes, i.e. excludes have a higher priority.
*
*/
public String getExcludes() {
return excludes;
}
/**
* All elements that are excluded from your schema.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* Excludes match before includes, i.e. excludes have a higher priority.
*
*/
public void setExcludes(String value) {
this.excludes = value;
}
/**
* This flag indicates whether include / exclude patterns should also match columns within tables.
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeExcludeColumns() {
return includeExcludeColumns;
}
/**
* Sets the value of the includeExcludeColumns property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeExcludeColumns(Boolean value) {
this.includeExcludeColumns = value;
}
/**
* This flag indicates whether tables should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeTables() {
return includeTables;
}
/**
* Sets the value of the includeTables property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeTables(Boolean value) {
this.includeTables = value;
}
/**
* This flag indicates whether embeddable types should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeEmbeddables() {
return includeEmbeddables;
}
/**
* Sets the value of the includeEmbeddables property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeEmbeddables(Boolean value) {
this.includeEmbeddables = value;
}
/**
* This flag indicates whether routines should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeRoutines() {
return includeRoutines;
}
/**
* Sets the value of the includeRoutines property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeRoutines(Boolean value) {
this.includeRoutines = value;
}
/**
* This flag indicates whether trigger implementation routines should be included in output produced by this database (e.g. in PostgreSQL)
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeTriggerRoutines() {
return includeTriggerRoutines;
}
/**
* Sets the value of the includeTriggerRoutines property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeTriggerRoutines(Boolean value) {
this.includeTriggerRoutines = value;
}
/**
* This flag indicates whether packages should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludePackages() {
return includePackages;
}
/**
* Sets the value of the includePackages property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludePackages(Boolean value) {
this.includePackages = value;
}
/**
* This flag indicates whether routines contained in packages should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludePackageRoutines() {
return includePackageRoutines;
}
/**
* Sets the value of the includePackageRoutines property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludePackageRoutines(Boolean value) {
this.includePackageRoutines = value;
}
/**
* This flag indicates whether UDTs contained in packages should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludePackageUDTs() {
return includePackageUDTs;
}
/**
* Sets the value of the includePackageUDTs property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludePackageUDTs(Boolean value) {
this.includePackageUDTs = value;
}
/**
* This flag indicates whether constants contained in packages should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludePackageConstants() {
return includePackageConstants;
}
/**
* Sets the value of the includePackageConstants property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludePackageConstants(Boolean value) {
this.includePackageConstants = value;
}
/**
* This flag indicates whether udts should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeUDTs() {
return includeUDTs;
}
/**
* Sets the value of the includeUDTs property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeUDTs(Boolean value) {
this.includeUDTs = value;
}
/**
* This flag indicates whether sequences should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeSequences() {
return includeSequences;
}
/**
* Sets the value of the includeSequences property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeSequences(Boolean value) {
this.includeSequences = value;
}
/**
* This flag indicates whether indexes should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeIndexes() {
return includeIndexes;
}
/**
* Sets the value of the includeIndexes property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeIndexes(Boolean value) {
this.includeIndexes = value;
}
/**
* This flag indicates whether primary keys should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludePrimaryKeys() {
return includePrimaryKeys;
}
/**
* Sets the value of the includePrimaryKeys property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludePrimaryKeys(Boolean value) {
this.includePrimaryKeys = value;
}
/**
* This flag indicates whether unique keys should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeUniqueKeys() {
return includeUniqueKeys;
}
/**
* Sets the value of the includeUniqueKeys property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeUniqueKeys(Boolean value) {
this.includeUniqueKeys = value;
}
/**
* This flag indicates whether foreign keys should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeForeignKeys() {
return includeForeignKeys;
}
/**
* Sets the value of the includeForeignKeys property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeForeignKeys(Boolean value) {
this.includeForeignKeys = value;
}
/**
* This flag indicates whether check constraints should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeCheckConstraints() {
return includeCheckConstraints;
}
/**
* Sets the value of the includeCheckConstraints property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeCheckConstraints(Boolean value) {
this.includeCheckConstraints = value;
}
/**
* This flag indicates whether system generated indexes should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeSystemIndexes() {
return includeSystemIndexes;
}
/**
* Sets the value of the includeSystemIndexes property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeSystemIndexes(Boolean value) {
this.includeSystemIndexes = value;
}
/**
* This flag indicates whether system generated check constraints should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeSystemCheckConstraints() {
return includeSystemCheckConstraints;
}
/**
* Sets the value of the includeSystemCheckConstraints property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeSystemCheckConstraints(Boolean value) {
this.includeSystemCheckConstraints = value;
}
/**
* This flag indicates whether invisible columns should be included in output produced by this database
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIncludeInvisibleColumns() {
return includeInvisibleColumns;
}
/**
* Sets the value of the includeInvisibleColumns property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIncludeInvisibleColumns(Boolean value) {
this.includeInvisibleColumns = value;
}
/**
* All table and view columns that are used as "version" fields for optimistic locking.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* See {@link org.jooq.UpdatableRecord#store()} and {@link org.jooq.UpdatableRecord#delete()} for details about optimistic locking.
*
*/
public String getRecordVersionFields() {
return recordVersionFields;
}
/**
* All table and view columns that are used as "version" fields for optimistic locking.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* See {@link org.jooq.UpdatableRecord#store()} and {@link org.jooq.UpdatableRecord#delete()} for details about optimistic locking.
*
*/
public void setRecordVersionFields(String value) {
this.recordVersionFields = value;
}
/**
* All table and view columns that are used as "timestamp" fields for optimistic locking.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* See {@link org.jooq.UpdatableRecord#store()} and {@link org.jooq.UpdatableRecord#delete()} for details about optimistic locking.
*
*/
public String getRecordTimestampFields() {
return recordTimestampFields;
}
/**
* All table and view columns that are used as "timestamp" fields for optimistic locking.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* See {@link org.jooq.UpdatableRecord#store()} and {@link org.jooq.UpdatableRecord#delete()} for details about optimistic locking.
*
*/
public void setRecordTimestampFields(String value) {
this.recordTimestampFields = value;
}
/**
* A regular expression matching all columns that represent identities.
*
* To be used if columns are not detected as automatically as identities.
*
*/
public String getSyntheticIdentities() {
return syntheticIdentities;
}
/**
* A regular expression matching all columns that represent identities.
*
* To be used if columns are not detected as automatically as identities.
*
*/
public void setSyntheticIdentities(String value) {
this.syntheticIdentities = value;
}
/**
* A regular expression matching all columns that participate in "synthetic" primary keys,
* which should be placed on generated {@link org.jooq.UpdatableRecord}
*
* To be used with:
*
* - {@link org.jooq.UpdatableRecord#store()}
* - {@link org.jooq.UpdatableRecord#update()}
* - {@link org.jooq.UpdatableRecord#delete()}
* - {@link org.jooq.UpdatableRecord#refresh()}
*
*
* Synthetic primary keys will override existing primary keys.
*
*/
public String getSyntheticPrimaryKeys() {
return syntheticPrimaryKeys;
}
/**
* A regular expression matching all columns that participate in "synthetic" primary keys,
* which should be placed on generated {@link org.jooq.UpdatableRecord}
*
* To be used with:
*
* - {@link org.jooq.UpdatableRecord#store()}
* - {@link org.jooq.UpdatableRecord#update()}
* - {@link org.jooq.UpdatableRecord#delete()}
* - {@link org.jooq.UpdatableRecord#refresh()}
*
*
* Synthetic primary keys will override existing primary keys.
*
*/
public void setSyntheticPrimaryKeys(String value) {
this.syntheticPrimaryKeys = value;
}
/**
* All (UNIQUE) key names that should be used instead of primary keys on
* generated {@link org.jooq.UpdatableRecord}.
*
* To be used with:
*
* - {@link org.jooq.UpdatableRecord#store()}
* - {@link org.jooq.UpdatableRecord#update()}
* - {@link org.jooq.UpdatableRecord#delete()}
* - {@link org.jooq.UpdatableRecord#refresh()}
*
*
* If several keys match, a warning is emitted and the first one encountered will be used.
*
* This flag will also replace synthetic primary keys, if it matches.
*
*/
public String getOverridePrimaryKeys() {
return overridePrimaryKeys;
}
/**
* All (UNIQUE) key names that should be used instead of primary keys on
* generated {@link org.jooq.UpdatableRecord}.
*
* To be used with:
*
* - {@link org.jooq.UpdatableRecord#store()}
* - {@link org.jooq.UpdatableRecord#update()}
* - {@link org.jooq.UpdatableRecord#delete()}
* - {@link org.jooq.UpdatableRecord#refresh()}
*
*
* If several keys match, a warning is emitted and the first one encountered will be used.
*
* This flag will also replace synthetic primary keys, if it matches.
*
*/
public void setOverridePrimaryKeys(String value) {
this.overridePrimaryKeys = value;
}
/**
* Generate {@link java.sql.Timestamp} fields for DATE columns. This is particularly useful for Oracle databases
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isDateAsTimestamp() {
return dateAsTimestamp;
}
/**
* Sets the value of the dateAsTimestamp property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setDateAsTimestamp(Boolean value) {
this.dateAsTimestamp = value;
}
/**
* Ignore procedure return values in Transact-SQL generated code.
*
* In jOOQ 3.6.0, #4106 was implemented to support Transact-SQL's
* optional return values from stored procedures. This turns all procedures
* into Routine (instead of Routine). For backwards-
* compatibility reasons, users can suppress this change in jOOQ 3.x
*
* @deprecated This feature is deprecated as of jOOQ 3.6.0 and will be removed again in
* jOOQ 4.0.
*
* @return
* possible object is
* {@link Boolean }
*
*/
@Deprecated
public Boolean isIgnoreProcedureReturnValues() {
return ignoreProcedureReturnValues;
}
/**
* Sets the value of the ignoreProcedureReturnValues property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
@Deprecated
public void setIgnoreProcedureReturnValues(Boolean value) {
this.ignoreProcedureReturnValues = value;
}
/**
* Generate jOOU data types for your unsigned data types, which are not natively supported in Java
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isUnsignedTypes() {
return unsignedTypes;
}
/**
* Sets the value of the unsignedTypes property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setUnsignedTypes(Boolean value) {
this.unsignedTypes = value;
}
/**
* Include display width in type declaration. In some RDBMS (e.g. MariaDB, MySQL), fixed width integer types are optionally accompanied by a display width. This is sometimes abused to model BOOLEAN types via TINYINT(1). This flag allows for including that display width in the type declaration exposed by jOOQ-meta code, as if it were a numeric precision.
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isIntegerDisplayWidths() {
return integerDisplayWidths;
}
/**
* Sets the value of the integerDisplayWidths property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setIntegerDisplayWidths(Boolean value) {
this.integerDisplayWidths = value;
}
/**
* The catalog that is used locally as a source for meta information.
*
* This cannot be combined with the {@link #getCatalogs()} configuration element.
* If left empty (and without any {@link #getCatalogs()} configuration element), jOOQ will generate all available catalogs.
*
*/
public String getInputCatalog() {
return inputCatalog;
}
/**
* The catalog that is used locally as a source for meta information.
*
* This cannot be combined with the {@link #getCatalogs()} configuration element.
* If left empty (and without any {@link #getCatalogs()} configuration element), jOOQ will generate all available catalogs.
*
*/
public void setInputCatalog(String value) {
this.inputCatalog = value;
}
/**
* The catalog that is used in generated source code.
*
* Use this to override your local development
* catalog name for source code generation. If not specified, this
* will be the same as {@link #getInputCatalog()}
*
* This will be ignored if {@link #isOutputCatalogToDefault()} is set to true
*
*/
public String getOutputCatalog() {
return outputCatalog;
}
/**
* The catalog that is used in generated source code.
*
* Use this to override your local development
* catalog name for source code generation. If not specified, this
* will be the same as {@link #getInputCatalog()}
*
* This will be ignored if {@link #isOutputCatalogToDefault()} is set to true
*
*/
public void setOutputCatalog(String value) {
this.outputCatalog = value;
}
/**
* A flag to indicate that the outputCatalog should be the "default" catalog,
* which generates catalog-less, unqualified tables, procedures, etc.
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isOutputCatalogToDefault() {
return outputCatalogToDefault;
}
/**
* Sets the value of the outputCatalogToDefault property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setOutputCatalogToDefault(Boolean value) {
this.outputCatalogToDefault = value;
}
/**
* The schema that is used locally as a source for meta information.
*
* This cannot be combined with the {@link #getSchemata()} configuration element.
* If left empty (and without any {@link #getSchemata()} configuration element), jOOQ will generate all available schemata.
*
*/
public String getInputSchema() {
return inputSchema;
}
/**
* The schema that is used locally as a source for meta information.
*
* This cannot be combined with the {@link #getSchemata()} configuration element.
* If left empty (and without any {@link #getSchemata()} configuration element), jOOQ will generate all available schemata.
*
*/
public void setInputSchema(String value) {
this.inputSchema = value;
}
/**
* The schema that is used in generated source code.
*
* Use this to override your local development
* schema name for source code generation. If not specified, this
* will be the same as {@link #getInputSchema()}.
*
* This will be ignored if {@link #isOutputSchemaToDefault()} is set to true
*
*/
public String getOutputSchema() {
return outputSchema;
}
/**
* The schema that is used in generated source code.
*
* Use this to override your local development
* schema name for source code generation. If not specified, this
* will be the same as {@link #getInputSchema()}.
*
* This will be ignored if {@link #isOutputSchemaToDefault()} is set to true
*
*/
public void setOutputSchema(String value) {
this.outputSchema = value;
}
/**
* A flag to indicate that the outputSchema should be the "default" schema,
* which generates schema-less, unqualified tables, procedures, etc.
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isOutputSchemaToDefault() {
return outputSchemaToDefault;
}
/**
* Sets the value of the outputSchemaToDefault property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setOutputSchemaToDefault(Boolean value) {
this.outputSchemaToDefault = value;
}
/**
* A custom version number that, if available, will be used to assess whether the
* {@link #getInputSchema()} will need to be regenerated.
*
* There are three operation modes for this element:
*
* - The value is a class that can be found on the classpath and that implements
* {@link org.jooq.meta.SchemaVersionProvider}. Such classes must provide a default constructor
* - The value is a SELECT statement that returns one record with one column. The
* SELECT statement may contain a named variable called :schema_name
* - The value is a constant, such as a Maven property
*
*
* Schema versions will be generated into the {@link javax.annotation.Generated} annotation on
* generated artefacts.
*
*/
public String getSchemaVersionProvider() {
return schemaVersionProvider;
}
/**
* A custom version number that, if available, will be used to assess whether the
* {@link #getInputSchema()} will need to be regenerated.
*
* There are three operation modes for this element:
*
* - The value is a class that can be found on the classpath and that implements
* {@link org.jooq.meta.SchemaVersionProvider}. Such classes must provide a default constructor
* - The value is a SELECT statement that returns one record with one column. The
* SELECT statement may contain a named variable called :schema_name
* - The value is a constant, such as a Maven property
*
*
* Schema versions will be generated into the {@link javax.annotation.Generated} annotation on
* generated artefacts.
*
*/
public void setSchemaVersionProvider(String value) {
this.schemaVersionProvider = value;
}
/**
* A custom version number that, if available, will be used to assess whether the
* {@link #getInputCatalog()} from a given catalog will need to be regenerated.
*
* There are three operation modes for this element:
*
* - The value is a class that can be found on the classpath and that implements
* {@link org.jooq.meta.CatalogVersionProvider}. Such classes must provide a default constructor
* - The value is a SELECT statement that returns one record with one column. The
* SELECT statement may contain a named variable called :catalog_name
* - The value is a constant, such as a Maven property
*
* Catalog versions will be generated into the {@link javax.annotation.Generated} annotation on
* generated artefacts.
*
*/
public String getCatalogVersionProvider() {
return catalogVersionProvider;
}
/**
* A custom version number that, if available, will be used to assess whether the
* {@link #getInputCatalog()} from a given catalog will need to be regenerated.
*
* There are three operation modes for this element:
*
* - The value is a class that can be found on the classpath and that implements
* {@link org.jooq.meta.CatalogVersionProvider}. Such classes must provide a default constructor
* - The value is a SELECT statement that returns one record with one column. The
* SELECT statement may contain a named variable called :catalog_name
* - The value is a constant, such as a Maven property
*
* Catalog versions will be generated into the {@link javax.annotation.Generated} annotation on
* generated artefacts.
*
*/
public void setCatalogVersionProvider(String value) {
this.catalogVersionProvider = value;
}
/**
* A custom {@link java.util.Comparator} that can compare two {@link org.jooq.meta.Definition} objects to determine their order.
*
* This comparator can be used to influence the order of any object that is produced by jOOQ meta, and thus, indirectly, the order of declared objects in generated code.
*
*/
public String getOrderProvider() {
return orderProvider;
}
/**
* A custom {@link java.util.Comparator} that can compare two {@link org.jooq.meta.Definition} objects to determine their order.
*
* This comparator can be used to influence the order of any object that is produced by jOOQ meta, and thus, indirectly, the order of declared objects in generated code.
*
*/
public void setOrderProvider(String value) {
this.orderProvider = value;
}
/**
* Historically, zero-scale decimal types are generated as their most appropriate, corresponding integer type (e.g. NUMBER(2, 0) and less: Byte). This allows for turning off this feature. In case of conflict between this rule and actual {@link #getForcedTypes()}, the latter will win.
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isForceIntegerTypesOnZeroScaleDecimals() {
return forceIntegerTypesOnZeroScaleDecimals;
}
/**
* Sets the value of the forceIntegerTypesOnZeroScaleDecimals property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setForceIntegerTypesOnZeroScaleDecimals(Boolean value) {
this.forceIntegerTypesOnZeroScaleDecimals = value;
}
/**
* Whether table valued functions should be reported as tables.
*
* If this is deactivated, such functions are not generated as tables, but
* as ordinary routines. This is particularly useful for backwards-
* compatibility between jOOQ 3.8 and previous versions, when using TABLE
* and VARRAY types in Oracle.
*
* While this flag defaults to true for most databases, it defaults to false
* for Oracle.
*
* @return
* possible object is
* {@link Boolean }
*
*/
public Boolean isTableValuedFunctions() {
return tableValuedFunctions;
}
/**
* Sets the value of the tableValuedFunctions property.
*
* @param value
* allowed object is
* {@link Boolean }
*
*/
public void setTableValuedFunctions(Boolean value) {
this.tableValuedFunctions = value;
}
/**
* The number of seconds that are considered "slow" before a query is logged to indicate a bug, 0 for not logging.
*
*/
public Integer getLogSlowQueriesAfterSeconds() {
return logSlowQueriesAfterSeconds;
}
/**
* The number of seconds that are considered "slow" before a query is logged to indicate a bug, 0 for not logging.
*
*/
public void setLogSlowQueriesAfterSeconds(Integer value) {
this.logSlowQueriesAfterSeconds = value;
}
/**
* The number of seconds that are considered "slow" before a result set is logged to indicate a bug, 0 for not logging.
*
*/
public Integer getLogSlowResultsAfterSeconds() {
return logSlowResultsAfterSeconds;
}
/**
* The number of seconds that are considered "slow" before a result set is logged to indicate a bug, 0 for not logging.
*
*/
public void setLogSlowResultsAfterSeconds(Integer value) {
this.logSlowResultsAfterSeconds = value;
}
public List getProperties() {
if (properties == null) {
properties = new ArrayList();
}
return properties;
}
public void setProperties(List properties) {
this.properties = properties;
}
public List getCatalogs() {
if (catalogs == null) {
catalogs = new ArrayList();
}
return catalogs;
}
public void setCatalogs(List catalogs) {
this.catalogs = catalogs;
}
public List getSchemata() {
if (schemata == null) {
schemata = new ArrayList();
}
return schemata;
}
public void setSchemata(List schemata) {
this.schemata = schemata;
}
public List getEmbeddables() {
if (embeddables == null) {
embeddables = new ArrayList();
}
return embeddables;
}
public void setEmbeddables(List embeddables) {
this.embeddables = embeddables;
}
@Deprecated
public List getCustomTypes() {
if (customTypes == null) {
customTypes = new ArrayList();
}
return customTypes;
}
@Deprecated
public void setCustomTypes(List customTypes) {
this.customTypes = customTypes;
}
@Deprecated
public List getEnumTypes() {
if (enumTypes == null) {
enumTypes = new ArrayList();
}
return enumTypes;
}
@Deprecated
public void setEnumTypes(List enumTypes) {
this.enumTypes = enumTypes;
}
public List getForcedTypes() {
if (forcedTypes == null) {
forcedTypes = new ArrayList();
}
return forcedTypes;
}
public void setForcedTypes(List forcedTypes) {
this.forcedTypes = forcedTypes;
}
/**
* The database dialect from jooq-meta.
* Available dialects are named org.util.[database].[database]Database
.
*
* Natively supported values are:
*
* - {@link org.jooq.meta.ase.ASEDatabase}
* - {@link org.jooq.meta.cockroachdb.CockroachDBDatabase}
* - {@link org.jooq.meta.db2.DB2Database}
* - {@link org.jooq.meta.derby.DerbyDatabase}
* - {@link org.jooq.meta.firebird.FirebirdDatabase}
* - {@link org.jooq.meta.h2.H2Database}
* - {@link org.jooq.meta.hana.HanaDatabase}
* - {@link org.jooq.meta.hsqldb.HSQLDBDatabase}
* - {@link org.jooq.meta.informix.InformixDatabase}
* - {@link org.jooq.meta.ingres.IngresDatabase}
* - {@link org.jooq.meta.mariadb.MariaDBDatabase}
* - {@link org.jooq.meta.mysql.MySQLDatabase}
* - {@link org.jooq.meta.oracle.OracleDatabase}
* - {@link org.jooq.meta.postgres.PostgresDatabase}
* - {@link org.jooq.meta.redshift.RedshiftDatabase}
* - {@link org.jooq.meta.sqlite.SQLiteDatabase}
* - {@link org.jooq.meta.sqlserver.SQLServerDatabase}
* - {@link org.jooq.meta.sybase.SybaseDatabase}
* - {@link org.jooq.meta.vertica.VerticaDatabase}
*
*
* This value can be used to reverse-engineer generic JDBC DatabaseMetaData (e.g. for MS Access).
*
* - {@link org.jooq.meta.jdbc.JDBCDatabase}
*
*
* This value can be used to reverse-engineer standard jOOQ-meta XML formats.
*
* - {@link org.jooq.meta.xml.XMLDatabase}
*
*
* This value can be used to reverse-engineer JPA annotated entities
*
* - {@link org.jooq.meta.extensions.jpa.JPADatabase}
*
*
* You can also provide your own org.jooq.meta.Database implementation
* here, if your database is currently not supported
*
*/
public Database withName(String value) {
setName(value);
return this;
}
/**
* The flags that will be applied to all regular expressions from this configuration by default.
*
* The default value is "COMMENTS CASE_INSENSITIVE"Gets the value of the regexFlags property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a set
method for the regexFlags property.
*
*
* For example, to add a new item, do as follows:
*
* getRegexFlags().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link RegexFlag }
*
*
*/
public Database withRegexFlags(RegexFlag... values) {
if (values!= null) {
for (RegexFlag value: values) {
getRegexFlags().add(value);
}
}
return this;
}
/**
* The flags that will be applied to all regular expressions from this configuration by default.
*
* The default value is "COMMENTS CASE_INSENSITIVE"Gets the value of the regexFlags property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a set
method for the regexFlags property.
*
*
* For example, to add a new item, do as follows:
*
* getRegexFlags().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link RegexFlag }
*
*
*/
public Database withRegexFlags(Collection values) {
if (values!= null) {
getRegexFlags().addAll(values);
}
return this;
}
public Database withRegexMatchesPartialQualification(Boolean value) {
setRegexMatchesPartialQualification(value);
return this;
}
public Database withSqlMatchesPartialQualification(Boolean value) {
setSqlMatchesPartialQualification(value);
return this;
}
/**
* All elements that are generated from your schema.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* Watch out for case-sensitivity. Depending on your database, this might be
* important!
*
* You can create case-insensitive regular expressions
* using this syntax: (?i:expr)
*
* Whitespace is ignored and comments are possible unless overridden in {@link #getRegexFlags()}.
*
*/
public Database withIncludes(String value) {
setIncludes(value);
return this;
}
/**
* All elements that are excluded from your schema.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* Excludes match before includes, i.e. excludes have a higher priority.
*
*/
public Database withExcludes(String value) {
setExcludes(value);
return this;
}
public Database withIncludeExcludeColumns(Boolean value) {
setIncludeExcludeColumns(value);
return this;
}
public Database withIncludeTables(Boolean value) {
setIncludeTables(value);
return this;
}
public Database withIncludeEmbeddables(Boolean value) {
setIncludeEmbeddables(value);
return this;
}
public Database withIncludeRoutines(Boolean value) {
setIncludeRoutines(value);
return this;
}
public Database withIncludeTriggerRoutines(Boolean value) {
setIncludeTriggerRoutines(value);
return this;
}
public Database withIncludePackages(Boolean value) {
setIncludePackages(value);
return this;
}
public Database withIncludePackageRoutines(Boolean value) {
setIncludePackageRoutines(value);
return this;
}
public Database withIncludePackageUDTs(Boolean value) {
setIncludePackageUDTs(value);
return this;
}
public Database withIncludePackageConstants(Boolean value) {
setIncludePackageConstants(value);
return this;
}
public Database withIncludeUDTs(Boolean value) {
setIncludeUDTs(value);
return this;
}
public Database withIncludeSequences(Boolean value) {
setIncludeSequences(value);
return this;
}
public Database withIncludeIndexes(Boolean value) {
setIncludeIndexes(value);
return this;
}
public Database withIncludePrimaryKeys(Boolean value) {
setIncludePrimaryKeys(value);
return this;
}
public Database withIncludeUniqueKeys(Boolean value) {
setIncludeUniqueKeys(value);
return this;
}
public Database withIncludeForeignKeys(Boolean value) {
setIncludeForeignKeys(value);
return this;
}
public Database withIncludeCheckConstraints(Boolean value) {
setIncludeCheckConstraints(value);
return this;
}
public Database withIncludeSystemIndexes(Boolean value) {
setIncludeSystemIndexes(value);
return this;
}
public Database withIncludeSystemCheckConstraints(Boolean value) {
setIncludeSystemCheckConstraints(value);
return this;
}
public Database withIncludeInvisibleColumns(Boolean value) {
setIncludeInvisibleColumns(value);
return this;
}
/**
* All table and view columns that are used as "version" fields for optimistic locking.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* See {@link org.jooq.UpdatableRecord#store()} and {@link org.jooq.UpdatableRecord#delete()} for details about optimistic locking.
*
*/
public Database withRecordVersionFields(String value) {
setRecordVersionFields(value);
return this;
}
/**
* All table and view columns that are used as "timestamp" fields for optimistic locking.
*
* This is a Java regular expression. Use the pipe to separate several expressions.
* See {@link org.jooq.UpdatableRecord#store()} and {@link org.jooq.UpdatableRecord#delete()} for details about optimistic locking.
*
*/
public Database withRecordTimestampFields(String value) {
setRecordTimestampFields(value);
return this;
}
/**
* A regular expression matching all columns that represent identities.
*
* To be used if columns are not detected as automatically as identities.
*
*/
public Database withSyntheticIdentities(String value) {
setSyntheticIdentities(value);
return this;
}
/**
* A regular expression matching all columns that participate in "synthetic" primary keys,
* which should be placed on generated {@link org.jooq.UpdatableRecord}
*
* To be used with:
*
* - {@link org.jooq.UpdatableRecord#store()}
* - {@link org.jooq.UpdatableRecord#update()}
* - {@link org.jooq.UpdatableRecord#delete()}
* - {@link org.jooq.UpdatableRecord#refresh()}
*
*
* Synthetic primary keys will override existing primary keys.
*
*/
public Database withSyntheticPrimaryKeys(String value) {
setSyntheticPrimaryKeys(value);
return this;
}
/**
* All (UNIQUE) key names that should be used instead of primary keys on
* generated {@link org.jooq.UpdatableRecord}.
*
* To be used with:
*
* - {@link org.jooq.UpdatableRecord#store()}
* - {@link org.jooq.UpdatableRecord#update()}
* - {@link org.jooq.UpdatableRecord#delete()}
* - {@link org.jooq.UpdatableRecord#refresh()}
*
*
* If several keys match, a warning is emitted and the first one encountered will be used.
*
* This flag will also replace synthetic primary keys, if it matches.
*
*/
public Database withOverridePrimaryKeys(String value) {
setOverridePrimaryKeys(value);
return this;
}
public Database withDateAsTimestamp(Boolean value) {
setDateAsTimestamp(value);
return this;
}
public Database withIgnoreProcedureReturnValues(Boolean value) {
setIgnoreProcedureReturnValues(value);
return this;
}
public Database withUnsignedTypes(Boolean value) {
setUnsignedTypes(value);
return this;
}
public Database withIntegerDisplayWidths(Boolean value) {
setIntegerDisplayWidths(value);
return this;
}
/**
* The catalog that is used locally as a source for meta information.
*
* This cannot be combined with the {@link #getCatalogs()} configuration element.
* If left empty (and without any {@link #getCatalogs()} configuration element), jOOQ will generate all available catalogs.
*
*/
public Database withInputCatalog(String value) {
setInputCatalog(value);
return this;
}
/**
* The catalog that is used in generated source code.
*
* Use this to override your local development
* catalog name for source code generation. If not specified, this
* will be the same as {@link #getInputCatalog()}
*
* This will be ignored if {@link #isOutputCatalogToDefault()} is set to true
*
*/
public Database withOutputCatalog(String value) {
setOutputCatalog(value);
return this;
}
public Database withOutputCatalogToDefault(Boolean value) {
setOutputCatalogToDefault(value);
return this;
}
/**
* The schema that is used locally as a source for meta information.
*
* This cannot be combined with the {@link #getSchemata()} configuration element.
* If left empty (and without any {@link #getSchemata()} configuration element), jOOQ will generate all available schemata.
*
*/
public Database withInputSchema(String value) {
setInputSchema(value);
return this;
}
/**
* The schema that is used in generated source code.
*
* Use this to override your local development
* schema name for source code generation. If not specified, this
* will be the same as {@link #getInputSchema()}.
*
* This will be ignored if {@link #isOutputSchemaToDefault()} is set to true
*
*/
public Database withOutputSchema(String value) {
setOutputSchema(value);
return this;
}
public Database withOutputSchemaToDefault(Boolean value) {
setOutputSchemaToDefault(value);
return this;
}
/**
* A custom version number that, if available, will be used to assess whether the
* {@link #getInputSchema()} will need to be regenerated.
*
* There are three operation modes for this element:
*
* - The value is a class that can be found on the classpath and that implements
* {@link org.jooq.meta.SchemaVersionProvider}. Such classes must provide a default constructor
* - The value is a SELECT statement that returns one record with one column. The
* SELECT statement may contain a named variable called :schema_name
* - The value is a constant, such as a Maven property
*
*
* Schema versions will be generated into the {@link javax.annotation.Generated} annotation on
* generated artefacts.
*
*/
public Database withSchemaVersionProvider(String value) {
setSchemaVersionProvider(value);
return this;
}
/**
* A custom version number that, if available, will be used to assess whether the
* {@link #getInputCatalog()} from a given catalog will need to be regenerated.
*
* There are three operation modes for this element:
*
* - The value is a class that can be found on the classpath and that implements
* {@link org.jooq.meta.CatalogVersionProvider}. Such classes must provide a default constructor
* - The value is a SELECT statement that returns one record with one column. The
* SELECT statement may contain a named variable called :catalog_name
* - The value is a constant, such as a Maven property
*
* Catalog versions will be generated into the {@link javax.annotation.Generated} annotation on
* generated artefacts.
*
*/
public Database withCatalogVersionProvider(String value) {
setCatalogVersionProvider(value);
return this;
}
/**
* A custom {@link java.util.Comparator} that can compare two {@link org.jooq.meta.Definition} objects to determine their order.
*
* This comparator can be used to influence the order of any object that is produced by jOOQ meta, and thus, indirectly, the order of declared objects in generated code.
*
*/
public Database withOrderProvider(String value) {
setOrderProvider(value);
return this;
}
public Database withForceIntegerTypesOnZeroScaleDecimals(Boolean value) {
setForceIntegerTypesOnZeroScaleDecimals(value);
return this;
}
public Database withTableValuedFunctions(Boolean value) {
setTableValuedFunctions(value);
return this;
}
/**
* The number of seconds that are considered "slow" before a query is logged to indicate a bug, 0 for not logging.
*
*/
public Database withLogSlowQueriesAfterSeconds(Integer value) {
setLogSlowQueriesAfterSeconds(value);
return this;
}
/**
* The number of seconds that are considered "slow" before a result set is logged to indicate a bug, 0 for not logging.
*
*/
public Database withLogSlowResultsAfterSeconds(Integer value) {
setLogSlowResultsAfterSeconds(value);
return this;
}
public Database withProperties(Property... values) {
if (values!= null) {
for (Property value: values) {
getProperties().add(value);
}
}
return this;
}
public Database withProperties(Collection values) {
if (values!= null) {
getProperties().addAll(values);
}
return this;
}
public Database withProperties(List properties) {
setProperties(properties);
return this;
}
public Database withCatalogs(CatalogMappingType... values) {
if (values!= null) {
for (CatalogMappingType value: values) {
getCatalogs().add(value);
}
}
return this;
}
public Database withCatalogs(Collection values) {
if (values!= null) {
getCatalogs().addAll(values);
}
return this;
}
public Database withCatalogs(List catalogs) {
setCatalogs(catalogs);
return this;
}
public Database withSchemata(SchemaMappingType... values) {
if (values!= null) {
for (SchemaMappingType value: values) {
getSchemata().add(value);
}
}
return this;
}
public Database withSchemata(Collection values) {
if (values!= null) {
getSchemata().addAll(values);
}
return this;
}
public Database withSchemata(List schemata) {
setSchemata(schemata);
return this;
}
public Database withEmbeddables(Embeddable... values) {
if (values!= null) {
for (Embeddable value: values) {
getEmbeddables().add(value);
}
}
return this;
}
public Database withEmbeddables(Collection values) {
if (values!= null) {
getEmbeddables().addAll(values);
}
return this;
}
public Database withEmbeddables(List embeddables) {
setEmbeddables(embeddables);
return this;
}
@Deprecated
public Database withCustomTypes(CustomType... values) {
if (values!= null) {
for (CustomType value: values) {
getCustomTypes().add(value);
}
}
return this;
}
@Deprecated
public Database withCustomTypes(Collection values) {
if (values!= null) {
getCustomTypes().addAll(values);
}
return this;
}
@Deprecated
public Database withCustomTypes(List customTypes) {
setCustomTypes(customTypes);
return this;
}
@Deprecated
public Database withEnumTypes(EnumType... values) {
if (values!= null) {
for (EnumType value: values) {
getEnumTypes().add(value);
}
}
return this;
}
@Deprecated
public Database withEnumTypes(Collection values) {
if (values!= null) {
getEnumTypes().addAll(values);
}
return this;
}
@Deprecated
public Database withEnumTypes(List enumTypes) {
setEnumTypes(enumTypes);
return this;
}
public Database withForcedTypes(ForcedType... values) {
if (values!= null) {
for (ForcedType value: values) {
getForcedTypes().add(value);
}
}
return this;
}
public Database withForcedTypes(Collection values) {
if (values!= null) {
getForcedTypes().addAll(values);
}
return this;
}
public Database withForcedTypes(List forcedTypes) {
setForcedTypes(forcedTypes);
return this;
}
@Override
public final void appendTo(XMLBuilder builder) {
builder.append("name", name);
builder.append("regexFlags", "regexFlags", regexFlags);
builder.append("regexMatchesPartialQualification", regexMatchesPartialQualification);
builder.append("sqlMatchesPartialQualification", sqlMatchesPartialQualification);
builder.append("includes", includes);
builder.append("excludes", excludes);
builder.append("includeExcludeColumns", includeExcludeColumns);
builder.append("includeTables", includeTables);
builder.append("includeEmbeddables", includeEmbeddables);
builder.append("includeRoutines", includeRoutines);
builder.append("includeTriggerRoutines", includeTriggerRoutines);
builder.append("includePackages", includePackages);
builder.append("includePackageRoutines", includePackageRoutines);
builder.append("includePackageUDTs", includePackageUDTs);
builder.append("includePackageConstants", includePackageConstants);
builder.append("includeUDTs", includeUDTs);
builder.append("includeSequences", includeSequences);
builder.append("includeIndexes", includeIndexes);
builder.append("includePrimaryKeys", includePrimaryKeys);
builder.append("includeUniqueKeys", includeUniqueKeys);
builder.append("includeForeignKeys", includeForeignKeys);
builder.append("includeCheckConstraints", includeCheckConstraints);
builder.append("includeSystemIndexes", includeSystemIndexes);
builder.append("includeSystemCheckConstraints", includeSystemCheckConstraints);
builder.append("includeInvisibleColumns", includeInvisibleColumns);
builder.append("recordVersionFields", recordVersionFields);
builder.append("recordTimestampFields", recordTimestampFields);
builder.append("syntheticIdentities", syntheticIdentities);
builder.append("syntheticPrimaryKeys", syntheticPrimaryKeys);
builder.append("overridePrimaryKeys", overridePrimaryKeys);
builder.append("dateAsTimestamp", dateAsTimestamp);
builder.append("ignoreProcedureReturnValues", ignoreProcedureReturnValues);
builder.append("unsignedTypes", unsignedTypes);
builder.append("integerDisplayWidths", integerDisplayWidths);
builder.append("inputCatalog", inputCatalog);
builder.append("outputCatalog", outputCatalog);
builder.append("outputCatalogToDefault", outputCatalogToDefault);
builder.append("inputSchema", inputSchema);
builder.append("outputSchema", outputSchema);
builder.append("outputSchemaToDefault", outputSchemaToDefault);
builder.append("schemaVersionProvider", schemaVersionProvider);
builder.append("catalogVersionProvider", catalogVersionProvider);
builder.append("orderProvider", orderProvider);
builder.append("forceIntegerTypesOnZeroScaleDecimals", forceIntegerTypesOnZeroScaleDecimals);
builder.append("tableValuedFunctions", tableValuedFunctions);
builder.append("logSlowQueriesAfterSeconds", logSlowQueriesAfterSeconds);
builder.append("logSlowResultsAfterSeconds", logSlowResultsAfterSeconds);
builder.append("properties", "property", properties);
builder.append("catalogs", "catalog", catalogs);
builder.append("schemata", "schema", schemata);
builder.append("embeddables", "embeddable", embeddables);
builder.append("customTypes", "customType", customTypes);
builder.append("enumTypes", "enumType", enumTypes);
builder.append("forcedTypes", "forcedType", forcedTypes);
}
@Override
public String toString() {
XMLBuilder builder = XMLBuilder.nonFormatting();
appendTo(builder);
return builder.toString();
}
@Override
public boolean equals(Object that) {
if (this == that) {
return true;
}
if (that == null) {
return false;
}
if (getClass()!= that.getClass()) {
return false;
}
Database other = ((Database) that);
if (name == null) {
if (other.name!= null) {
return false;
}
} else {
if (!name.equals(other.name)) {
return false;
}
}
if (regexFlags == null) {
if (other.regexFlags!= null) {
return false;
}
} else {
if (!regexFlags.equals(other.regexFlags)) {
return false;
}
}
if (regexMatchesPartialQualification == null) {
if (other.regexMatchesPartialQualification!= null) {
return false;
}
} else {
if (!regexMatchesPartialQualification.equals(other.regexMatchesPartialQualification)) {
return false;
}
}
if (sqlMatchesPartialQualification == null) {
if (other.sqlMatchesPartialQualification!= null) {
return false;
}
} else {
if (!sqlMatchesPartialQualification.equals(other.sqlMatchesPartialQualification)) {
return false;
}
}
if (includes == null) {
if (other.includes!= null) {
return false;
}
} else {
if (!includes.equals(other.includes)) {
return false;
}
}
if (excludes == null) {
if (other.excludes!= null) {
return false;
}
} else {
if (!excludes.equals(other.excludes)) {
return false;
}
}
if (includeExcludeColumns == null) {
if (other.includeExcludeColumns!= null) {
return false;
}
} else {
if (!includeExcludeColumns.equals(other.includeExcludeColumns)) {
return false;
}
}
if (includeTables == null) {
if (other.includeTables!= null) {
return false;
}
} else {
if (!includeTables.equals(other.includeTables)) {
return false;
}
}
if (includeEmbeddables == null) {
if (other.includeEmbeddables!= null) {
return false;
}
} else {
if (!includeEmbeddables.equals(other.includeEmbeddables)) {
return false;
}
}
if (includeRoutines == null) {
if (other.includeRoutines!= null) {
return false;
}
} else {
if (!includeRoutines.equals(other.includeRoutines)) {
return false;
}
}
if (includeTriggerRoutines == null) {
if (other.includeTriggerRoutines!= null) {
return false;
}
} else {
if (!includeTriggerRoutines.equals(other.includeTriggerRoutines)) {
return false;
}
}
if (includePackages == null) {
if (other.includePackages!= null) {
return false;
}
} else {
if (!includePackages.equals(other.includePackages)) {
return false;
}
}
if (includePackageRoutines == null) {
if (other.includePackageRoutines!= null) {
return false;
}
} else {
if (!includePackageRoutines.equals(other.includePackageRoutines)) {
return false;
}
}
if (includePackageUDTs == null) {
if (other.includePackageUDTs!= null) {
return false;
}
} else {
if (!includePackageUDTs.equals(other.includePackageUDTs)) {
return false;
}
}
if (includePackageConstants == null) {
if (other.includePackageConstants!= null) {
return false;
}
} else {
if (!includePackageConstants.equals(other.includePackageConstants)) {
return false;
}
}
if (includeUDTs == null) {
if (other.includeUDTs!= null) {
return false;
}
} else {
if (!includeUDTs.equals(other.includeUDTs)) {
return false;
}
}
if (includeSequences == null) {
if (other.includeSequences!= null) {
return false;
}
} else {
if (!includeSequences.equals(other.includeSequences)) {
return false;
}
}
if (includeIndexes == null) {
if (other.includeIndexes!= null) {
return false;
}
} else {
if (!includeIndexes.equals(other.includeIndexes)) {
return false;
}
}
if (includePrimaryKeys == null) {
if (other.includePrimaryKeys!= null) {
return false;
}
} else {
if (!includePrimaryKeys.equals(other.includePrimaryKeys)) {
return false;
}
}
if (includeUniqueKeys == null) {
if (other.includeUniqueKeys!= null) {
return false;
}
} else {
if (!includeUniqueKeys.equals(other.includeUniqueKeys)) {
return false;
}
}
if (includeForeignKeys == null) {
if (other.includeForeignKeys!= null) {
return false;
}
} else {
if (!includeForeignKeys.equals(other.includeForeignKeys)) {
return false;
}
}
if (includeCheckConstraints == null) {
if (other.includeCheckConstraints!= null) {
return false;
}
} else {
if (!includeCheckConstraints.equals(other.includeCheckConstraints)) {
return false;
}
}
if (includeSystemIndexes == null) {
if (other.includeSystemIndexes!= null) {
return false;
}
} else {
if (!includeSystemIndexes.equals(other.includeSystemIndexes)) {
return false;
}
}
if (includeSystemCheckConstraints == null) {
if (other.includeSystemCheckConstraints!= null) {
return false;
}
} else {
if (!includeSystemCheckConstraints.equals(other.includeSystemCheckConstraints)) {
return false;
}
}
if (includeInvisibleColumns == null) {
if (other.includeInvisibleColumns!= null) {
return false;
}
} else {
if (!includeInvisibleColumns.equals(other.includeInvisibleColumns)) {
return false;
}
}
if (recordVersionFields == null) {
if (other.recordVersionFields!= null) {
return false;
}
} else {
if (!recordVersionFields.equals(other.recordVersionFields)) {
return false;
}
}
if (recordTimestampFields == null) {
if (other.recordTimestampFields!= null) {
return false;
}
} else {
if (!recordTimestampFields.equals(other.recordTimestampFields)) {
return false;
}
}
if (syntheticIdentities == null) {
if (other.syntheticIdentities!= null) {
return false;
}
} else {
if (!syntheticIdentities.equals(other.syntheticIdentities)) {
return false;
}
}
if (syntheticPrimaryKeys == null) {
if (other.syntheticPrimaryKeys!= null) {
return false;
}
} else {
if (!syntheticPrimaryKeys.equals(other.syntheticPrimaryKeys)) {
return false;
}
}
if (overridePrimaryKeys == null) {
if (other.overridePrimaryKeys!= null) {
return false;
}
} else {
if (!overridePrimaryKeys.equals(other.overridePrimaryKeys)) {
return false;
}
}
if (dateAsTimestamp == null) {
if (other.dateAsTimestamp!= null) {
return false;
}
} else {
if (!dateAsTimestamp.equals(other.dateAsTimestamp)) {
return false;
}
}
if (ignoreProcedureReturnValues == null) {
if (other.ignoreProcedureReturnValues!= null) {
return false;
}
} else {
if (!ignoreProcedureReturnValues.equals(other.ignoreProcedureReturnValues)) {
return false;
}
}
if (unsignedTypes == null) {
if (other.unsignedTypes!= null) {
return false;
}
} else {
if (!unsignedTypes.equals(other.unsignedTypes)) {
return false;
}
}
if (integerDisplayWidths == null) {
if (other.integerDisplayWidths!= null) {
return false;
}
} else {
if (!integerDisplayWidths.equals(other.integerDisplayWidths)) {
return false;
}
}
if (inputCatalog == null) {
if (other.inputCatalog!= null) {
return false;
}
} else {
if (!inputCatalog.equals(other.inputCatalog)) {
return false;
}
}
if (outputCatalog == null) {
if (other.outputCatalog!= null) {
return false;
}
} else {
if (!outputCatalog.equals(other.outputCatalog)) {
return false;
}
}
if (outputCatalogToDefault == null) {
if (other.outputCatalogToDefault!= null) {
return false;
}
} else {
if (!outputCatalogToDefault.equals(other.outputCatalogToDefault)) {
return false;
}
}
if (inputSchema == null) {
if (other.inputSchema!= null) {
return false;
}
} else {
if (!inputSchema.equals(other.inputSchema)) {
return false;
}
}
if (outputSchema == null) {
if (other.outputSchema!= null) {
return false;
}
} else {
if (!outputSchema.equals(other.outputSchema)) {
return false;
}
}
if (outputSchemaToDefault == null) {
if (other.outputSchemaToDefault!= null) {
return false;
}
} else {
if (!outputSchemaToDefault.equals(other.outputSchemaToDefault)) {
return false;
}
}
if (schemaVersionProvider == null) {
if (other.schemaVersionProvider!= null) {
return false;
}
} else {
if (!schemaVersionProvider.equals(other.schemaVersionProvider)) {
return false;
}
}
if (catalogVersionProvider == null) {
if (other.catalogVersionProvider!= null) {
return false;
}
} else {
if (!catalogVersionProvider.equals(other.catalogVersionProvider)) {
return false;
}
}
if (orderProvider == null) {
if (other.orderProvider!= null) {
return false;
}
} else {
if (!orderProvider.equals(other.orderProvider)) {
return false;
}
}
if (forceIntegerTypesOnZeroScaleDecimals == null) {
if (other.forceIntegerTypesOnZeroScaleDecimals!= null) {
return false;
}
} else {
if (!forceIntegerTypesOnZeroScaleDecimals.equals(other.forceIntegerTypesOnZeroScaleDecimals)) {
return false;
}
}
if (tableValuedFunctions == null) {
if (other.tableValuedFunctions!= null) {
return false;
}
} else {
if (!tableValuedFunctions.equals(other.tableValuedFunctions)) {
return false;
}
}
if (logSlowQueriesAfterSeconds == null) {
if (other.logSlowQueriesAfterSeconds!= null) {
return false;
}
} else {
if (!logSlowQueriesAfterSeconds.equals(other.logSlowQueriesAfterSeconds)) {
return false;
}
}
if (logSlowResultsAfterSeconds == null) {
if (other.logSlowResultsAfterSeconds!= null) {
return false;
}
} else {
if (!logSlowResultsAfterSeconds.equals(other.logSlowResultsAfterSeconds)) {
return false;
}
}
if (properties == null) {
if (other.properties!= null) {
return false;
}
} else {
if (!properties.equals(other.properties)) {
return false;
}
}
if (catalogs == null) {
if (other.catalogs!= null) {
return false;
}
} else {
if (!catalogs.equals(other.catalogs)) {
return false;
}
}
if (schemata == null) {
if (other.schemata!= null) {
return false;
}
} else {
if (!schemata.equals(other.schemata)) {
return false;
}
}
if (embeddables == null) {
if (other.embeddables!= null) {
return false;
}
} else {
if (!embeddables.equals(other.embeddables)) {
return false;
}
}
if (customTypes == null) {
if (other.customTypes!= null) {
return false;
}
} else {
if (!customTypes.equals(other.customTypes)) {
return false;
}
}
if (enumTypes == null) {
if (other.enumTypes!= null) {
return false;
}
} else {
if (!enumTypes.equals(other.enumTypes)) {
return false;
}
}
if (forcedTypes == null) {
if (other.forcedTypes!= null) {
return false;
}
} else {
if (!forcedTypes.equals(other.forcedTypes)) {
return false;
}
}
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = ((prime*result)+((name == null)? 0 :name.hashCode()));
result = ((prime*result)+((regexFlags == null)? 0 :regexFlags.hashCode()));
result = ((prime*result)+((regexMatchesPartialQualification == null)? 0 :regexMatchesPartialQualification.hashCode()));
result = ((prime*result)+((sqlMatchesPartialQualification == null)? 0 :sqlMatchesPartialQualification.hashCode()));
result = ((prime*result)+((includes == null)? 0 :includes.hashCode()));
result = ((prime*result)+((excludes == null)? 0 :excludes.hashCode()));
result = ((prime*result)+((includeExcludeColumns == null)? 0 :includeExcludeColumns.hashCode()));
result = ((prime*result)+((includeTables == null)? 0 :includeTables.hashCode()));
result = ((prime*result)+((includeEmbeddables == null)? 0 :includeEmbeddables.hashCode()));
result = ((prime*result)+((includeRoutines == null)? 0 :includeRoutines.hashCode()));
result = ((prime*result)+((includeTriggerRoutines == null)? 0 :includeTriggerRoutines.hashCode()));
result = ((prime*result)+((includePackages == null)? 0 :includePackages.hashCode()));
result = ((prime*result)+((includePackageRoutines == null)? 0 :includePackageRoutines.hashCode()));
result = ((prime*result)+((includePackageUDTs == null)? 0 :includePackageUDTs.hashCode()));
result = ((prime*result)+((includePackageConstants == null)? 0 :includePackageConstants.hashCode()));
result = ((prime*result)+((includeUDTs == null)? 0 :includeUDTs.hashCode()));
result = ((prime*result)+((includeSequences == null)? 0 :includeSequences.hashCode()));
result = ((prime*result)+((includeIndexes == null)? 0 :includeIndexes.hashCode()));
result = ((prime*result)+((includePrimaryKeys == null)? 0 :includePrimaryKeys.hashCode()));
result = ((prime*result)+((includeUniqueKeys == null)? 0 :includeUniqueKeys.hashCode()));
result = ((prime*result)+((includeForeignKeys == null)? 0 :includeForeignKeys.hashCode()));
result = ((prime*result)+((includeCheckConstraints == null)? 0 :includeCheckConstraints.hashCode()));
result = ((prime*result)+((includeSystemIndexes == null)? 0 :includeSystemIndexes.hashCode()));
result = ((prime*result)+((includeSystemCheckConstraints == null)? 0 :includeSystemCheckConstraints.hashCode()));
result = ((prime*result)+((includeInvisibleColumns == null)? 0 :includeInvisibleColumns.hashCode()));
result = ((prime*result)+((recordVersionFields == null)? 0 :recordVersionFields.hashCode()));
result = ((prime*result)+((recordTimestampFields == null)? 0 :recordTimestampFields.hashCode()));
result = ((prime*result)+((syntheticIdentities == null)? 0 :syntheticIdentities.hashCode()));
result = ((prime*result)+((syntheticPrimaryKeys == null)? 0 :syntheticPrimaryKeys.hashCode()));
result = ((prime*result)+((overridePrimaryKeys == null)? 0 :overridePrimaryKeys.hashCode()));
result = ((prime*result)+((dateAsTimestamp == null)? 0 :dateAsTimestamp.hashCode()));
result = ((prime*result)+((ignoreProcedureReturnValues == null)? 0 :ignoreProcedureReturnValues.hashCode()));
result = ((prime*result)+((unsignedTypes == null)? 0 :unsignedTypes.hashCode()));
result = ((prime*result)+((integerDisplayWidths == null)? 0 :integerDisplayWidths.hashCode()));
result = ((prime*result)+((inputCatalog == null)? 0 :inputCatalog.hashCode()));
result = ((prime*result)+((outputCatalog == null)? 0 :outputCatalog.hashCode()));
result = ((prime*result)+((outputCatalogToDefault == null)? 0 :outputCatalogToDefault.hashCode()));
result = ((prime*result)+((inputSchema == null)? 0 :inputSchema.hashCode()));
result = ((prime*result)+((outputSchema == null)? 0 :outputSchema.hashCode()));
result = ((prime*result)+((outputSchemaToDefault == null)? 0 :outputSchemaToDefault.hashCode()));
result = ((prime*result)+((schemaVersionProvider == null)? 0 :schemaVersionProvider.hashCode()));
result = ((prime*result)+((catalogVersionProvider == null)? 0 :catalogVersionProvider.hashCode()));
result = ((prime*result)+((orderProvider == null)? 0 :orderProvider.hashCode()));
result = ((prime*result)+((forceIntegerTypesOnZeroScaleDecimals == null)? 0 :forceIntegerTypesOnZeroScaleDecimals.hashCode()));
result = ((prime*result)+((tableValuedFunctions == null)? 0 :tableValuedFunctions.hashCode()));
result = ((prime*result)+((logSlowQueriesAfterSeconds == null)? 0 :logSlowQueriesAfterSeconds.hashCode()));
result = ((prime*result)+((logSlowResultsAfterSeconds == null)? 0 :logSlowResultsAfterSeconds.hashCode()));
result = ((prime*result)+((properties == null)? 0 :properties.hashCode()));
result = ((prime*result)+((catalogs == null)? 0 :catalogs.hashCode()));
result = ((prime*result)+((schemata == null)? 0 :schemata.hashCode()));
result = ((prime*result)+((embeddables == null)? 0 :embeddables.hashCode()));
result = ((prime*result)+((customTypes == null)? 0 :customTypes.hashCode()));
result = ((prime*result)+((enumTypes == null)? 0 :enumTypes.hashCode()));
result = ((prime*result)+((forcedTypes == null)? 0 :forcedTypes.hashCode()));
return result;
}
}