类 LegacyLimitHandler
- java.lang.Object
-
- org.hibernate.dialect.pagination.AbstractLimitHandler
-
- org.hibernate.dialect.pagination.LegacyLimitHandler
-
- 所有已实现的接口:
LimitHandler
public class LegacyLimitHandler extends AbstractLimitHandler
Limit handler that delegates all operations to the underlying dialect.- 作者:
- Lukasz Antoniak (lukasz dot antoniak at gmail dot com)
-
-
构造器概要
构造器 构造器 说明 LegacyLimitHandler(Dialect dialect)Constructs a LegacyLimitHandler
-
方法概要
所有方法 实例方法 具体方法 修饰符和类型 方法 说明 booleanbindLimitParametersFirst()Does the LIMIT clause come at the start of the SELECT statement, rather than at the end?booleanbindLimitParametersInReverseOrder()ANSI SQL defines the LIMIT clause to be in the form LIMIT offset, limit.intconvertToFirstRowValue(int zeroBasedFirstResult)Hibernate APIs explicitly state that setFirstResult() should be a zero-based offset.booleanforceLimitUsage()Generally, if there is no limit applied to a Hibernate query we do not apply any limits to the SQL query.StringprocessSql(String sql, RowSelection selection)Return processed SQL query.booleansupportsLimit()Does this handler support some form of limiting query results via a SQL clause?booleansupportsLimitOffset()Does this handler's LIMIT support (if any) additionally support specifying an offset?booleansupportsVariableLimit()Does this handler support bind variables (i.e., prepared statement parameters) for its limit/offset?booleanuseMaxForLimit()Does the LIMIT clause take a "maximum" row number instead of a total number of returned rows?-
从类继承的方法 org.hibernate.dialect.pagination.AbstractLimitHandler
bindLimitParameters, bindLimitParametersAtEndOfQuery, bindLimitParametersAtStartOfQuery, getMaxOrLimit, setMaxRows
-
-
-
-
构造器详细资料
-
LegacyLimitHandler
public LegacyLimitHandler(Dialect dialect)
Constructs a LegacyLimitHandler- 参数:
dialect- The dialect
-
-
方法详细资料
-
supportsLimit
public boolean supportsLimit()
从接口复制的说明:LimitHandlerDoes this handler support some form of limiting query results via a SQL clause?- 指定者:
supportsLimit在接口中LimitHandler- 覆盖:
supportsLimit在类中AbstractLimitHandler- 返回:
- True if this handler supports some form of LIMIT.
-
supportsLimitOffset
public boolean supportsLimitOffset()
从接口复制的说明:LimitHandlerDoes this handler's LIMIT support (if any) additionally support specifying an offset?- 指定者:
supportsLimitOffset在接口中LimitHandler- 覆盖:
supportsLimitOffset在类中AbstractLimitHandler- 返回:
- True if the handler supports an offset within the limit support.
-
supportsVariableLimit
public boolean supportsVariableLimit()
从类复制的说明:AbstractLimitHandlerDoes this handler support bind variables (i.e., prepared statement parameters) for its limit/offset?- 覆盖:
supportsVariableLimit在类中AbstractLimitHandler- 返回:
- True if bind variables can be used; false otherwise.
-
bindLimitParametersInReverseOrder
public boolean bindLimitParametersInReverseOrder()
从类复制的说明:AbstractLimitHandlerANSI SQL defines the LIMIT clause to be in the form LIMIT offset, limit. Does this dialect require us to bind the parameters in reverse order?- 覆盖:
bindLimitParametersInReverseOrder在类中AbstractLimitHandler- 返回:
- true if the correct order is limit, offset
-
bindLimitParametersFirst
public boolean bindLimitParametersFirst()
从类复制的说明:AbstractLimitHandlerDoes the LIMIT clause come at the start of the SELECT statement, rather than at the end?- 覆盖:
bindLimitParametersFirst在类中AbstractLimitHandler- 返回:
- true if limit parameters should come before other parameters
-
useMaxForLimit
public boolean useMaxForLimit()
从类复制的说明:AbstractLimitHandlerDoes the LIMIT clause take a "maximum" row number instead of a total number of returned rows? This is easiest understood via an example. Consider you have a table with 20 rows, but you only want to retrieve rows number 11 through 20. Generally, a limit with offset would say that the offset = 11 and the limit = 10 (we only want 10 rows at a time); this is specifying the total number of returned rows. Some dialects require that we instead specify offset = 11 and limit = 20, where 20 is the "last" row we want relative to offset (i.e. total number of rows = 20 - 11 = 9) So essentially, is limit relative from offset? Or is limit absolute?- 覆盖:
useMaxForLimit在类中AbstractLimitHandler- 返回:
- True if limit is relative from offset; false otherwise.
-
forceLimitUsage
public boolean forceLimitUsage()
从类复制的说明:AbstractLimitHandlerGenerally, if there is no limit applied to a Hibernate query we do not apply any limits to the SQL query. This option forces that the limit be written to the SQL query.- 覆盖:
forceLimitUsage在类中AbstractLimitHandler- 返回:
- True to force limit into SQL query even if none specified in Hibernate query; false otherwise.
-
convertToFirstRowValue
public int convertToFirstRowValue(int zeroBasedFirstResult)
从类复制的说明:AbstractLimitHandlerHibernate APIs explicitly state that setFirstResult() should be a zero-based offset. Here we allow the Dialect a chance to convert that value based on what the underlying db or driver will expect. NOTE: what gets passed intoAbstractLimitHandler.processSql(String, org.hibernate.engine.spi.RowSelection)is the zero-based offset. Dialects which do notAbstractLimitHandler.supportsVariableLimit()should take care to perform any needed first-row-conversion calls prior to injecting the limit values into the SQL string.- 覆盖:
convertToFirstRowValue在类中AbstractLimitHandler- 参数:
zeroBasedFirstResult- The user-supplied, zero-based first row offset.- 返回:
- The corresponding db/dialect specific offset.
- 另请参阅:
Query.setFirstResult(int),Criteria.setFirstResult(int)
-
processSql
public String processSql(String sql, RowSelection selection)
从接口复制的说明:LimitHandlerReturn processed SQL query.- 指定者:
processSql在接口中LimitHandler- 覆盖:
processSql在类中AbstractLimitHandler- 参数:
sql- the SQL query to process.selection- the selection criteria for rows.- 返回:
- Query statement with LIMIT clause applied.
-
-