Class TdbRecordSet
- All Implemented Interfaces:
com.tietoenator.trip.jxp.internal.utils.DOMSink
- Direct Known Subclasses:
TdbGridRecordSet
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoid
clear()
Clear the record set of any content retrieved by a get() operation
This version of the method does not reset the record set to its default state, simply removes any accumulated TdbRecord instances.void
delete()
Delete the records covered by the record set from their database(s)void
get()
Retrieve the record set defined by the various properties of the instance.get
(TdbDataFormat fmt) Retrieve the record set defined by the various properties of the instance.int
Retrieve the number of records affected by the most recent operation
This method will return the number of records (total) hit by the most recent search, or the number of records affected by the most recent insert, update or delete, depending on what the most recent activity was.Retrieve the name of the database that provides the context for the record setReturns a "did-you-mean" suggestion for the query that produced the last retrieved record set.int
getFrom()
Retrieve the lower bound of the record set's domainint
getId()
Retrieve the unique ID of the single record covered by this record setlong
Retrieve the number of terms hitby the last query-driven retrieval.long
Retrieve the number of records affected by the most recent operation.int
Retrieve any maximum value established for performing mapped searches (retrieval only)getName()
Retrieve the name of the single record covered by this record setgetQuery()
Retrieve any query string that has been established as a retrieval contextint
Retrieve the number of terms hit by the last query-driven retrieval.int
Retrieve the number of records (total) hit by the last query-driven retrievalint
Retrieve the ID of the search set with which the record will be associatedRetrieve the comma-separated list of sort keysint
Retrieve any maximum value established for sorting with the record set (retrieval only)Returns the order in which records from different databases should be ordered when sorting a search result from a database cluster.boolean
Check if the record set's retrieval operations are to be sorted by relevance rankRetrieve the name of the thesaurus used with the query for the record set.int
getTo()
Retrieve the upper bound of the record set's domainvoid
insert
(Collection<TdbRecord> records) Insert new records to the database associated with this record setboolean
Check if the provided query statement is in CCLboolean
Check if the provided query statement in is SQLboolean
Check if the provided query statement in is XPathrecordAt
(int offset) Retrieve the TdbRecord at the defined offset within the set
If the provided offset is outside of the bounds of the record set, an INVALID_ARGS exception is thrown.records()
Retrieve the collection of records retrieved most recently by the get() method from the servervoid
reset()
Clear the record set and all associated parameters
All properties of the record set are reset by this method to their default state, rendering the record unusable until properties are reestablishedvoid
setDatabase
(String name) Set the name of the database (or thesaurus, or cluster) that will provide the context for the record setvoid
setFrom
(int from) Establish the lower bound of a ranged record set domain.void
setId
(int id) Establish the unique ID of the single record covered by this record setvoid
setMapMax
(int max) Establish the maximum number of records that will be mapped during a retrieval operationvoid
Establish the name of the record covered by this record set.void
Set a query statement that will be used to retrieve recordsvoid
setQueryCCL
(boolean ccl) Establish whether the query statement is in CCLvoid
setQuerySQL
(boolean sql) Establish whether the query statement is in SQLvoid
setQueryXPath
(boolean xpath) Establish whether the query statement is an XPath expression.void
setRange
(long from, long to) Set range of records to retrieve when the range's end position extends beyond Integer MAX_VALUE.void
setRetrievalTemplate
(TdbRecord template) Set the record set template, i.e. the fields and restrictions that are to be requested from the server.void
setRetrieveReversed
(boolean rev) Set whether to retrieve the result set in reverse.void
setSearchSet
(int srch) Establish the ID of the search set with which the record will be associatedvoid
setSortKeys
(String keys) Establish sort criteria for the record set (retrieval only)void
setSortMax
(int max) Establish the maximum number of records that will be sorted during a retrieval operationvoid
setSortMerge
(TdbSortMergeType mergetype) Define the order in which records from different databases should be ordered when sorting a search result from a database cluster.void
setSortRanked
(boolean rank) Establish whether the record set's retrieval operations are to be sorted by relevance rankvoid
setThesaurus
(String thes) Set the name of a thesaurus to use in the query for the record set.void
setTo
(int to) Establish the upper bound of a ranged record set domain.void
Apply the same update transformation to all records covered by the record setMethods inherited from class com.tietoenator.trip.jxp.TdbMessageProvider
codeList, getLastCode, getLastMessage, hasMessages, messageList, resetMessages
Methods inherited from class com.tietoenator.trip.jxp.session.TdbSessionObject
cancel, getSession, isCancelable, setCancelable
-
Constructor Details
-
TdbRecordSet
Constructor, creates a blank instance- Parameters:
session
- Active session- Throws:
TdbException
-
-
Method Details
-
getQuery
Retrieve any query string that has been established as a retrieval context- Returns:
- Query string
-
setQuery
Set a query statement that will be used to retrieve recordsSetting a query as the domain of the record set works in conjunction with the setDatabase() setting, i.e. the query works within the context of the database. The setting of a record range, using the setFrom(), setTo(), or setId() methods becomes relative to the search set generated by the query. The use of the setName() method is not legal when setting a query, and any attempt to set the value of this property after having established a name will result in an INVALID_ARGS exception being thrown. Also note that if the database property is not set, the query defined here must define its own context, e.g. using the CCL Find Save statement.
- Parameters:
query
- The query statement- Throws:
TdbException
-
isQueryCCL
public boolean isQueryCCL()Check if the provided query statement is in CCL- Returns:
- True if the provided query is CCL
-
setQueryCCL
public void setQueryCCL(boolean ccl) Establish whether the query statement is in CCL- Parameters:
ccl
- True if the provided query is in CCL
-
isQuerySQL
public boolean isQuerySQL()Check if the provided query statement in is SQL- Returns:
- True if the query is in SQL
-
isQueryXPath
public boolean isQueryXPath()Check if the provided query statement in is XPath- Returns:
- True if the query is in XPath
-
setQuerySQL
public void setQuerySQL(boolean sql) Establish whether the query statement is in SQL- Parameters:
sql
- True if the provided query is in SQL, false otherwise
-
setQueryXPath
public void setQueryXPath(boolean xpath) Establish whether the query statement is an XPath expression.- Parameters:
xpath
- True if the provided query is in XPath, false otherwise
-
getQueryRecords
public int getQueryRecords()Retrieve the number of records (total) hit by the last query-driven retrieval- Returns:
- Number of records hit by the last query
-
getAffectedRecords
public int getAffectedRecords()Retrieve the number of records affected by the most recent operation
This method will return the number of records (total) hit by the most recent search, or the number of records affected by the most recent insert, update or delete, depending on what the most recent activity was.- Returns:
- Number of records affected by last operation
-
getLongRecordCount
public long getLongRecordCount()Retrieve the number of records affected by the most recent operation. This property should be used instead of #getAffectedRecords() and #getQueryRecords() in case the result contains more than Integer.MAX_VALUE records.- Since:
- 8.0
-
getQueryHits
public int getQueryHits()Retrieve the number of terms hit by the last query-driven retrieval.- Returns:
- Number of hits
-
getLongHitCount
public long getLongHitCount()Retrieve the number of terms hitby the last query-driven retrieval.- Returns:
- Number of hits This property should be used instead of #getQueryHits() in case the result contains more than Integer.MAX_VALUE hits.
- Since:
- 8.0
-
getDidYouMean
Returns a "did-you-mean" suggestion for the query that produced the last retrieved record set. This is an alternative query that will yield a greater amount of hits. Only the FUZZ command can result in a did-you-mean suggestion, and requires TRIPsystem v6.2 or later in order to do so.- Returns:
- An alternative query or an empty string.
-
getDatabase
Retrieve the name of the database that provides the context for the record set- Returns:
- Database name
-
setDatabase
Set the name of the database (or thesaurus, or cluster) that will provide the context for the record set- Parameters:
name
- Name of database, thesaurus or cluster
-
getThesaurus
Retrieve the name of the thesaurus used with the query for the record set.- Returns:
- Thesaurus name
-
setThesaurus
Set the name of a thesaurus to use in the query for the record set.- Parameters:
thes
- Name of thesaurus
-
getSearchSet
public int getSearchSet()Retrieve the ID of the search set with which the record will be associated- Returns:
- Search set unique ID
-
setSearchSet
public void setSearchSet(int srch) Establish the ID of the search set with which the record will be associated- Parameters:
srch
- Search set unique ID
-
getFrom
public int getFrom()Retrieve the lower bound of the record set's domain- Returns:
- Lower bound
-
setFrom
public void setFrom(int from) Establish the lower bound of a ranged record set domain.
If this property is not set, and no other property is used to define the record set's bounds, the default is the lower limit of whatever context is defined, e.g. the start of the search set, or the first record in the database.- Parameters:
from
- Lower bound
-
getTo
public int getTo()Retrieve the upper bound of the record set's domain- Returns:
- Upper bound
-
setTo
public void setTo(int to) Establish the upper bound of a ranged record set domain.- Parameters:
to
- Upper bound If this property is not set, and no other property is used to define the record set's retrieval range bounds, the default is the upper limit of whatever context is defined, e.g. the end of the search set, or the last record in the database.
-
setRange
public void setRange(long from, long to) Set range of records to retrieve when the range's end position extends beyond Integer MAX_VALUE.- Parameters:
from
- Lower boundto
- Upper bound- Since:
- 8.0
-
getId
public int getId()Retrieve the unique ID of the single record covered by this record set- Returns:
- The record's unique ID
-
setId
public void setId(int id) Establish the unique ID of the single record covered by this record set- Parameters:
id
- The record's unique ID
-
getName
Retrieve the name of the single record covered by this record set- Returns:
- Record name
-
setName
Establish the name of the record covered by this record set.
This property is invalid when the record set is defined as covering the result of a query, using the setQuery() method. Setting the value of this property after having set the query property will result in an INVALID_ARGS exception being thrown.- Parameters:
name
- Record name- Throws:
TdbException
-
getSortKeys
Retrieve the comma-separated list of sort keys- Returns:
- Sort keys
-
setSortKeys
Establish sort criteria for the record set (retrieval only)- Parameters:
keys
- A comma-separated list of keys
-
getSortRanked
public boolean getSortRanked()Check if the record set's retrieval operations are to be sorted by relevance rank- Returns:
- True / false
-
setSortRanked
public void setSortRanked(boolean rank) Establish whether the record set's retrieval operations are to be sorted by relevance rank- Parameters:
rank
- If true, records will be primarily sorted by relevance, with any other sort keys being used as secondary sort criteria
-
setSortMerge
Define the order in which records from different databases should be ordered when sorting a search result from a database cluster.- Parameters:
mergetype
- The merge type to use for the request.
-
getSortMerge
Returns the order in which records from different databases should be ordered when sorting a search result from a database cluster.- Returns:
- A TdbSortMergeType instance definining the merge choice
-
setRetrieveReversed
public void setRetrieveReversed(boolean rev) Set whether to retrieve the result set in reverse.- Parameters:
rev
- If true, records will be returned from the search set in reverse.
-
getSortMax
public int getSortMax()Retrieve any maximum value established for sorting with the record set (retrieval only)- Returns:
- Sort max
-
setSortMax
public void setSortMax(int max) Establish the maximum number of records that will be sorted during a retrieval operation- Parameters:
max
- Sort max
-
getMapMax
public int getMapMax()Retrieve any maximum value established for performing mapped searches (retrieval only)- Returns:
- map max
-
setMapMax
public void setMapMax(int max) Establish the maximum number of records that will be mapped during a retrieval operation- Parameters:
max
- Map max
-
setRetrievalTemplate
Set the record set template, i.e. the fields and restrictions that are to be requested from the server.- Parameters:
template
- The retrieval template
-
records
Retrieve the collection of records retrieved most recently by the get() method from the server- Returns:
- Any available records
-
reset
public void reset()Clear the record set and all associated parameters
All properties of the record set are reset by this method to their default state, rendering the record unusable until properties are reestablished -
clear
public void clear()Clear the record set of any content retrieved by a get() operation
This version of the method does not reset the record set to its default state, simply removes any accumulated TdbRecord instances. -
recordAt
Retrieve the TdbRecord at the defined offset within the set
If the provided offset is outside of the bounds of the record set, an INVALID_ARGS exception is thrown. When a request is made to read the record at one index beyond the end of the set, i.e. the record "after" the last record, an END_OF_DATA exception is thrown.- Parameters:
offset
- The zero-based offset within the set of the record to retrieve- Returns:
- The appropriate record, if available
- Throws:
TdbException
-
get
Retrieve the record set defined by the various properties of the instance.Any records retrieved are deserialized into a collection of TdbRecord objects that can be accessed using the records(), or recordAt() methods.
This method causes network I/O.
- Throws:
TdbException
-
get
Retrieve the record set defined by the various properties of the instance.This method does not deserialize into the record collection, which will be blank after invocation.
Values for any string fields requested are returned inline encoded as base64. This may result in a very large response document and may cause session timeout or lack of enough memory resources to complete processing. Make sure to set up the retrieval template to exclude any unnecessary STRING fields.
This method causes network I/O.
- Parameters:
fmt
- The format of the XML to retrieve- Returns:
- An XML document containing the records suitable for transformation
- Throws:
TdbException
-
delete
Delete the records covered by the record set from their database(s)This method causes network I/O.
- Throws:
TdbException
-
update
Apply the same update transformation to all records covered by the record setThis method causes network I/O.
- Parameters:
values
- A valid record, containing field updates to be applied to all records covered by the record set.- Throws:
TdbException
-
insert
Insert new records to the database associated with this record setOnly the database (see setDatabase()) property is valid for this method. If the record set has been established using the setQuery() method, an INVALID_ARGS exception will be thrown.
This method causes network I/O.
- Parameters:
records
- A collection of TdbRecord objects to be inserted to the named database- Throws:
TdbException
-