Class MySqlAntlrDdlParser
java.lang.Object
io.debezium.relational.ddl.AbstractDdlParser
io.debezium.antlr.AntlrDdlParser<MySqlLexer,MySqlParser>
io.debezium.connector.mysql.antlr.MySqlAntlrDdlParser
- All Implemented Interfaces:
DdlParser
An ANTLR based parser for MySQL DDL statements.
- Author:
- Roman Kuchár <[email protected]>.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final ConcurrentMap<String,
String> private final MySqlValueConverters
private final Tables.TableFilter
Fields inherited from class io.debezium.antlr.AntlrDdlParser
databaseTables, dataTypeResolver
Fields inherited from class io.debezium.relational.ddl.AbstractDdlParser
ddlChanges, logger, skipComments, skipViews, systemVariables
-
Constructor Summary
ConstructorsConstructorDescriptionMySqlAntlrDdlParser
(boolean throwErrorsFromTreeWalk, boolean includeViews, boolean includeComments, MySqlValueConverters converters, Tables.TableFilter tableFilter) MySqlAntlrDdlParser
(MySqlValueConverters converters) MySqlAntlrDdlParser
(MySqlValueConverters converters, Tables.TableFilter tableFilter) -
Method Summary
Modifier and TypeMethodDescriptioncharsetForTable
(TableId tableId) Get the name of the character set for the give table name.Provides a map of default character sets by database/schema name.protected MySqlLexer
createNewLexerInstance
(org.antlr.v4.runtime.CharStream charStreams) protected MySqlParser
createNewParserInstance
(org.antlr.v4.runtime.CommonTokenStream commonTokenStream) protected SystemVariables
protected AntlrDdlParserListener
Get the name of the character set for the current database, via the "character_set_database" system property.static String
escapeOption
(String option) extractCharset
(MySqlParser.CharsetNameContext charsetNode, MySqlParser.CollationNameContext collationNode) Obtains the charset name either form charset if present or from collation.extractEnumAndSetOptions
(List<String> enumValues) Extracts the enumeration values properly parsed and escaped.getIndexColumns
(MySqlParser.IndexColumnNamesContext indexColumnNamesContext, TableEditor tableEditor) protected DataTypeResolver
protected boolean
boolean
isTableUniqueIndexIncluded
(MySqlParser.IndexColumnNamesContext indexColumnNamesContext, TableEditor tableEditor) Determine if a table's unique index should be included when parsing relative unique index statement.parseName
(MySqlParser.UidContext uidContext) Parse a name fromMySqlParser.UidContext
.void
parsePrimaryIndexColumnNames
(MySqlParser.IndexColumnNamesContext indexColumnNamesContext, TableEditor tableEditor) Parse column names for primary index fromMySqlParser.IndexColumnNamesContext
.parseQualifiedTableId
(MySqlParser.FullIdContext fullIdContext) Parse qualified table identification fromMySqlParser.FullIdContext
.protected org.antlr.v4.runtime.tree.ParseTree
parseTree
(MySqlParser parser) void
parseUniqueIndexColumnNames
(MySqlParser.IndexColumnNamesContext indexColumnNamesContext, TableEditor tableEditor) Parse column names for unique index fromMySqlParser.IndexColumnNamesContext
.void
runIfNotNull
(Runnable function, Object... nullableObjects) Runs a function if all given object are not null.void
signalAlterTable
(TableId id, TableId previousId, MySqlParser.RenameTableClauseContext ctx) Signal an alter table event to ddl changes listener.Methods inherited from class io.debezium.antlr.AntlrDdlParser
databaseTables, dataTypeResolver, debugParsed, debugSkipped, getParsingExceptionsFromWalker, getText, getText, parse, signalAlterDatabase, signalAlterTable, signalAlterView, signalCreateDatabase, signalCreateIndex, signalCreateTable, signalCreateView, signalDropDatabase, signalDropIndex, signalDropTable, signalDropTable, signalDropView, signalSetVariable, signalTruncateTable, signalUseDatabase, skipComments, skipViews, withoutQuotes
Methods inherited from class io.debezium.relational.ddl.AbstractDdlParser
accumulateParsingFailure, accumulateParsingFailure, commentParsed, createColumnFromConstant, currentSchema, debugParsed, debugSkipped, getDdlChanges, isQuote, isQuoted, removeLineFeeds, resolveTableId, setCurrentDatabase, setCurrentSchema, setTypeInfoForConstant, signalAlterDatabase, signalAlterTable, signalAlterView, signalChangeEvent, signalCreateDatabase, signalCreateIndex, signalCreateTable, signalCreateView, signalDropDatabase, signalDropIndex, signalDropView, signalSetVariable, signalTruncateTable, signalUseDatabase, systemVariables, withoutQuotes
-
Field Details
-
charsetNameForDatabase
-
converters
-
tableFilter
-
-
Constructor Details
-
MySqlAntlrDdlParser
public MySqlAntlrDdlParser() -
MySqlAntlrDdlParser
-
MySqlAntlrDdlParser
-
MySqlAntlrDdlParser
public MySqlAntlrDdlParser(boolean throwErrorsFromTreeWalk, boolean includeViews, boolean includeComments, MySqlValueConverters converters, Tables.TableFilter tableFilter)
-
-
Method Details
-
parseTree
- Specified by:
parseTree
in classAntlrDdlParser<MySqlLexer,
MySqlParser>
-
createParseTreeWalkerListener
- Specified by:
createParseTreeWalkerListener
in classAntlrDdlParser<MySqlLexer,
MySqlParser>
-
createNewLexerInstance
- Specified by:
createNewLexerInstance
in classAntlrDdlParser<MySqlLexer,
MySqlParser>
-
createNewParserInstance
protected MySqlParser createNewParserInstance(org.antlr.v4.runtime.CommonTokenStream commonTokenStream) - Specified by:
createNewParserInstance
in classAntlrDdlParser<MySqlLexer,
MySqlParser>
-
createNewSystemVariablesInstance
- Specified by:
createNewSystemVariablesInstance
in classAbstractDdlParser
-
isGrammarInUpperCase
protected boolean isGrammarInUpperCase()- Specified by:
isGrammarInUpperCase
in classAntlrDdlParser<MySqlLexer,
MySqlParser>
-
initializeDataTypeResolver
- Specified by:
initializeDataTypeResolver
in classAntlrDdlParser<MySqlLexer,
MySqlParser>
-
charsetNameForDatabase
Provides a map of default character sets by database/schema name.- Returns:
- map of default character sets.
-
parseName
Parse a name fromMySqlParser.UidContext
.- Parameters:
uidContext
- uid context- Returns:
- name without quotes.
-
parseQualifiedTableId
Parse qualified table identification fromMySqlParser.FullIdContext
.AbstractDdlParser.currentSchema()
will be used if definition of schema name is not part of the context.- Parameters:
fullIdContext
- full id context.- Returns:
- qualified
TableId
.
-
parsePrimaryIndexColumnNames
public void parsePrimaryIndexColumnNames(MySqlParser.IndexColumnNamesContext indexColumnNamesContext, TableEditor tableEditor) Parse column names for primary index fromMySqlParser.IndexColumnNamesContext
. This method will update column to be not optional and set primary key column names to table.- Parameters:
indexColumnNamesContext
- primary key index column names context.tableEditor
- editor for table where primary key index is parsed.
-
parseUniqueIndexColumnNames
public void parseUniqueIndexColumnNames(MySqlParser.IndexColumnNamesContext indexColumnNamesContext, TableEditor tableEditor) Parse column names for unique index fromMySqlParser.IndexColumnNamesContext
. This method will set unique key column names to table if there are no optional.- Parameters:
indexColumnNamesContext
- unique key index column names context.tableEditor
- editor for table where primary key index is parsed.
-
isTableUniqueIndexIncluded
public boolean isTableUniqueIndexIncluded(MySqlParser.IndexColumnNamesContext indexColumnNamesContext, TableEditor tableEditor) Determine if a table's unique index should be included when parsing relative unique index statement.- Parameters:
indexColumnNamesContext
- unique index column names context.tableEditor
- editor for table where unique index is parsed.- Returns:
- true if the index is to be included; false otherwise.
-
getIndexColumns
private List<Column> getIndexColumns(MySqlParser.IndexColumnNamesContext indexColumnNamesContext, TableEditor tableEditor) -
currentDatabaseCharset
Get the name of the character set for the current database, via the "character_set_database" system property.- Returns:
- the name of the character set for the current database, or null if not known ...
-
charsetForTable
Get the name of the character set for the give table name.- Returns:
- the name of the character set for the given table, or null if not known ...
-
runIfNotNull
Runs a function if all given object are not null.- Parameters:
function
- function to run; may not be nullnullableObjects
- object to be tested, if they are null.
-
extractEnumAndSetOptions
Extracts the enumeration values properly parsed and escaped.- Parameters:
enumValues
- the raw enumeration values from the parsed column definition- Returns:
- the list of options allowed for the
ENUM
orSET
; never null.
-
escapeOption
-
getConverters
-
getTableFilter
-
extractCharset
public String extractCharset(MySqlParser.CharsetNameContext charsetNode, MySqlParser.CollationNameContext collationNode) Obtains the charset name either form charset if present or from collation.- Parameters:
charsetNode
-collationNode
-- Returns:
- character set
-
signalAlterTable
public void signalAlterTable(TableId id, TableId previousId, MySqlParser.RenameTableClauseContext ctx) Signal an alter table event to ddl changes listener.- Parameters:
id
- the table identifier; may not be nullpreviousId
- the previous name of the view if it was renamed, or null if it was not renamedctx
- the start of the statement; may not be null
-