public class SchemaImpl extends Object implements Schema
This type is for JOOQ INTERNAL USE only. Do not reference directly
Constructor and Description |
---|
SchemaImpl(Name name) |
SchemaImpl(Name name,
Catalog catalog) |
SchemaImpl(Name name,
Catalog catalog,
Comment comment) |
SchemaImpl(String name) |
SchemaImpl(String name,
Catalog catalog) |
SchemaImpl(String name,
Catalog catalog,
String comment) |
Modifier and Type | Method and Description |
---|---|
void |
accept(Context<?> ctx)
|
void |
bind(BindContext context)
Deprecated.
- 3.4.0 - [#2694] - Use
QueryPartInternal.accept(Context) instead. |
Clause[] |
clauses(Context<?> ctx)
The
Clause s that are represented by this query part. |
protected DSLContext |
create()
Deprecated.
- 3.11.0 - [#6722] - Use
Attachable.configuration()
and Configuration.dsl() instead. |
protected DSLContext |
create(Configuration configuration)
Deprecated.
- 3.11.0 - [#6722] - Use
Attachable.configuration()
and Configuration.dsl() instead. |
protected DSLContext |
create(Context<?> ctx)
Deprecated.
- 3.11.0 - [#6722] - Use
Attachable.configuration()
and Configuration.dsl() instead. |
boolean |
declaresCTE()
Subclasses may override this
|
boolean |
declaresFields()
Subclasses may override this
|
boolean |
declaresTables()
Subclasses may override this
|
boolean |
declaresWindows()
Subclasses may override this
|
boolean |
equals(Object that)
Check whether this
QueryPart can be considered equal to
another QueryPart . |
boolean |
generatesCast()
Subclasses may override this
|
Catalog |
getCatalog()
The catalog of this schema.
|
String |
getComment()
The comment on this object.
|
String |
getName()
The unqualified name of this object.
|
Name |
getQualifiedName()
The qualified name of this object.
|
Sequence<?> |
getSequence(String sequenceName)
Get a sequence by its name (case-sensitive) in this schema, or
null if no such sequence exists. |
List<Sequence<?>> |
getSequences()
List all sequences contained in this schema.
|
Table<?> |
getTable(String tableName)
Get a table by its name (case-sensitive) in this schema, or
null if no such table exists. |
List<Table<?>> |
getTables()
List all tables contained in this schema.
|
UDT<?> |
getUDT(String udtName)
Get a UDT by its name (case-sensitive) in this schema, or
null if no such UDT exists. |
List<UDT<?>> |
getUDTs()
List all UDTs contained in this schema.
|
Name |
getUnqualifiedName()
The unqualified name of this object.
|
int |
hashCode()
Generate a hash code from this
QueryPart . |
Stream<Sequence<?>> |
sequenceStream()
Stream all sequences contained in this schema.
|
Stream<Table<?>> |
tableStream()
Stream all tables contained in this schema.
|
void |
toSQL(RenderContext context)
Deprecated.
- 3.4.0 - [#2694] - Use
QueryPartInternal.accept(Context) instead. |
String |
toString()
Render a SQL string representation of this
QueryPart . |
protected DataAccessException |
translate(String sql,
SQLException e)
Internal convenience method
|
Stream<UDT<?>> |
udtStream()
Stream all UDTs contained in this schema.
|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
getComment
getName, getQualifiedName, getUnqualifiedName
public SchemaImpl(String name)
public SchemaImpl(Name name)
public Catalog getCatalog()
Schema
getCatalog
in interface Schema
public final void accept(Context<?> ctx)
QueryPartInternal
QueryPart
can accept
a Context
object
in order to render a SQL string or to bind its variables.accept
in interface QueryPartInternal
public final Clause[] clauses(Context<?> ctx)
QueryPartInternal
Clause
s that are represented by this query part.
QueryPart
s can specify several Clause
s for which an
event will be emitted before
(in forward
order) and after
(in reverse order) visiting
the the query part through Context.visit(QueryPart)
This method is for JOOQ INTERNAL USE only. Do not reference directly
clauses
in interface QueryPartInternal
Clause
s represented by this query part or
null
or an empty array if this query part does not
represent a clause.public final Table<?> getTable(String tableName)
Schema
null
if no such table exists.public final UDT<?> getUDT(String udtName)
Schema
null
if no such UDT exists.public final Sequence<?> getSequence(String sequenceName)
Schema
null
if no such sequence exists.getSequence
in interface Schema
public List<Table<?>> getTables()
Subclasses should override this method
public List<UDT<?>> getUDTs()
Subclasses should override this method
public List<Sequence<?>> getSequences()
Subclasses should override this method
getSequences
in interface Schema
public final Stream<Table<?>> tableStream()
Schema
tableStream
in interface Schema
public final Stream<UDT<?>> udtStream()
Schema
public final Stream<Sequence<?>> sequenceStream()
Schema
sequenceStream
in interface Schema
public final String getName()
Named
public final Name getQualifiedName()
Named
getQualifiedName
in interface Named
public final Name getUnqualifiedName()
Named
getUnqualifiedName
in interface Named
public final String getComment()
Named
getComment
in interface Named
public int hashCode()
QueryPart
QueryPart
.
In general, QueryPart
hash codes are the same as the hash
codes generated from QueryPart.toString()
. This guarantees consistent
behaviour with QueryPart.equals(Object)
Some QueryPart
implementations may choose to override this
behaviour for improved performance, as QueryPart.toString()
is an
expensive operation, if called many times.
public boolean equals(Object that)
QueryPart
QueryPart
can be considered equal to
another QueryPart
.
In general, QueryPart
equality is defined in terms of
QueryPart.toString()
equality. In other words, two query parts are
considered equal if their rendered SQL (with inlined bind variables) is
equal. This means that the two query parts do not necessarily have to be
of the same type.
Some QueryPart
implementations may choose to override this
behaviour for improved performance, as QueryPart.toString()
is an
expensive operation, if called many times.
@Deprecated public final void toSQL(RenderContext context)
QueryPartInternal.accept(Context)
instead.QueryPartInternal
QueryPart
to a SQL string contained in
context.sql()
. The context
will contain
additional information about how to render this QueryPart
,
e.g. whether this QueryPart
should be rendered as a
declaration or reference, whether this QueryPart
's contained
bind variables should be inlined or replaced by '?'
, etc.toSQL
in interface QueryPartInternal
@Deprecated public final void bind(BindContext context) throws DataAccessException
QueryPartInternal.accept(Context)
instead.QueryPartInternal
QueryPart
to a PreparedStatement
This method is for JOOQ INTERNAL USE only. Do not reference directly
bind
in interface QueryPartInternal
context
- The context holding the next bind index and other information
for variable bindingDataAccessException
- If something went wrong while binding a
variablepublic boolean declaresFields()
declaresFields
in interface QueryPartInternal
public boolean declaresTables()
declaresTables
in interface QueryPartInternal
public boolean declaresWindows()
declaresWindows
in interface QueryPartInternal
public boolean declaresCTE()
declaresCTE
in interface QueryPartInternal
public boolean generatesCast()
generatesCast
in interface QueryPartInternal
public String toString()
QueryPart
QueryPart
.
For improved debugging, this renders a SQL string of this
QueryPart
with inlined bind variables. If this
QueryPart
is Attachable
, then the attached
Configuration
may be used for rendering the SQL string, including
SQLDialect
and Settings
. Do note that most
QueryPart
instances are not attached to a
Configuration
, and thus there is no guarantee that the SQL string
will make sense in the context of a specific database.
If you wish to gain more control over the concrete SQL rendering of this
QueryPart
, use DSLContext.renderContext()
to obtain
a configurable render context for SQL rendering.
@Deprecated protected final DSLContext create()
Attachable.configuration()
and Configuration.dsl()
instead.@Deprecated protected final DSLContext create(Configuration configuration)
Attachable.configuration()
and Configuration.dsl()
instead.@Deprecated protected final DSLContext create(Context<?> ctx)
Attachable.configuration()
and Configuration.dsl()
instead.protected final DataAccessException translate(String sql, SQLException e)
Copyright © 2019. All rights reserved.