|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectnet.java.ao.DatabaseProvider
net.java.ao.db.MySQLDatabaseProvider
public final class MySQLDatabaseProvider
Field Summary |
---|
Fields inherited from class net.java.ao.DatabaseProvider |
---|
eventManager |
Constructor Summary | |
---|---|
MySQLDatabaseProvider(DisposableDataSource dataSource)
|
Method Summary | |
---|---|
protected java.lang.String |
convertTypeToString(DatabaseType<?> type)
Converts the specified type into the database-specific DDL String value. |
protected java.util.Set<java.lang.String> |
getReservedWords()
Retrieves the set of all reserved words for the underlying database. |
protected java.lang.String |
renderAppend()
Generates any database-specific options which must be appended to the end of a table definition. |
protected java.lang.String |
renderAutoIncrement()
Generates the DDL fragment required to specify an INTEGER field as auto-incremented. |
protected java.lang.String |
renderCreateIndex(DDLIndex index)
Generates the database-specific DDL statement required to create a new index. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public MySQLDatabaseProvider(DisposableDataSource dataSource)
Method Detail |
---|
protected java.lang.String convertTypeToString(DatabaseType<?> type)
DatabaseProvider
DatabaseType#getDefaultName()
method. Subclass implementations should be sure to make a super
call in order to ensure that both default naming and future special
cases are handled appropriately.
convertTypeToString
in class DatabaseProvider
type
- The type instance to convert to a DDL string.
DatabaseType.getDefaultName()
protected java.lang.String renderAutoIncrement()
DatabaseProvider
Generates the DDL fragment required to specify an INTEGER field as
auto-incremented. For databases which do not support such flags (which
is just about every database exception MySQL), ""
is an
acceptable return value. This method should never return null
as it would cause the field rendering method to throw a NullPointerException
.
renderAutoIncrement
in class DatabaseProvider
protected java.lang.String renderAppend()
DatabaseProvider
Generates any database-specific options which must be appended to the end of a table definition. The only database I am aware of which requires this is MySQL. For example:
CREATE TABLE test ( id INTEGER NOT NULL AUTO_INCREMENT, name VARCHAR(45), PRIMARY KEY(id) ) ENGINE=InnoDB;
The "ENGINE=InnoDB
" clause is what is returned by
this method. The default implementation simply returns
null
, signifying that no append should be rendered.
renderAppend
in class DatabaseProvider
null
protected java.lang.String renderCreateIndex(DDLIndex index)
DatabaseProvider
null
returned.
renderCreateIndex
in class DatabaseProvider
index
- The index to create. This single instance contains all
of the data necessary to create the index, thus no separate
parameters (such as a DDLTable
) are required.
null
.protected java.util.Set<java.lang.String> getReservedWords()
DatabaseProvider
Set
instance returned from this
method should guarentee O(1) lookup times, otherwise ORM performance
will suffer greatly.
getReservedWords
in class DatabaseProvider
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |