Search result pages
No edit summary
(Automatically adding template at the end of the page.)
 
(19 intermediate revisions by 4 users not shown)
Line 1: Line 1:
Using the multivariable seeker to search the database you can configure the seeker to return the number of search result pages if the search does not fit within the MaxFetch setting.
This article explains the paging functionality available for [[Training:Seeker view|Seeking_the_database_with_OCLps]].


To set this up the seeker logic looks for a set of known variable names to communicate the results in:
Using the multivariable seeker to search the database, you can configure the seeker to return the number of search result pages if the search does not fit within the MaxFetch setting.


/// If this variable is found in a seeker - it controls what the search shows , on what page it is - vSeekerResultCount/vSeekerPageLength
To set this up, the seeker logic looks for a set of known variable names to communicate the results in:


''vSeekerPage''
{| class="wikitable"
!Variable name
!Type
!Use
|-
|''vSeekerPage''
|Integer
|'''''You set:''' If this variable is found in a seeker - it controls what the search shows, on what page it is - vSeekerResultCount/vSeekerPageLength''
|-
|''vSeekerPageLength'' 
|Integer
|'''''You set:''' The number of items you want on a page''
|-
|''vSeekerPageCount'' 
|Integer
|'''''Logic sets:''' The number of pages is set by the search logic for you to use, add variable, and use type integer''
|-
|''vSeekerResultCount'' 
|Int64
|'''''Logic sets:''' Total number of results by the search. The count of the SQL query is set by search logic''
|-
|
|
|<code>'''IsSeekerResultGrid=true'''</code> on the Nesting of your grid to know where paging buttons should go
|}
See also: [[MaxFetch]]. MaxFetch controls the maximum number of records returned. '''The default if not using MaxFetch is 20 records.''' MaxFetch doesn't need the above variables to work. Note that MaxFetch is a ''tagged value''.


/// The number of pages is set by the search logic for you to use, add variable and use type integer
The Autoforms construct seeker that makes use of paging refers to an Autoform-generated seeker to see details.


''vSeekerPageCount''
Currently, this is available in the WPF-client and '''Angular-Turnkey-client (new 2020-Aug)'''. 


/// The number of items you want on a page
To let the Framework know which grid on the page handles your search result, you must also add the tagged value <code>'''IsSeekerResultGrid=true'''</code> on the Nesting of your grid - again this is done by the AutoForms seekers.


''vSeekerPageLength''
==== Same Explained in Other Words  ====
When paging is turned on (define the variables above to turn it on), you will first execute the query with "select count(*) ...." to get the total count of hits in the DB - this value is assigned to the variable <code>vSeekerResultCount</code>.


/// The count of the sql query is set by search logic - you must add a variable of this name of type longint
You should set a desired page length - or expose this to your end users in the variable <code>vSeekerPageLength</code>.


''vSeekerResultCount''
The total number of pages available after the search is then <code>vSeekerPageCount:=vSeekerResultCount/vSeekerPageLength</code>


The Autoforms construct seeker that make use of paging - refer to an autoform generated seeker to see details.
If there are X pages available, you control what page is actually fetched from the DB by setting a value in vSeekerPage between 1 and X prior to the search.  


Currently this available in the WPF-client and '''Angular-Turnkey-client (new 2020-Aug)'''.  
UI is now generated in both WPF and Angular.  


For letting the framework know which grid on the page that handles your search result you must also add the tagged value IsSeekerResultGrid=true on the Nesting of your grid - again this is done by the AutoForms seekers.
a.k.a Seekmore, seek more  
 
[[Category:Searching]]
==== Same explained with other words ====
{{Edited|July|12|2024}}
When paging is turned on (define the variables above to turn it on) we will first execute the query with "select count(*) ...." to get the total count of hits in the db - this value is assigned to variable vSeekerResultCount.
 
You should set a desired page length - or expose this to your end users in the variable vSeekerPageLength.
 
The total number of pages available after search is then vSeekerPageCount:=vSeekerResultCount/vSeekerPageLength
 
If there a X pages available you control what page is actually fetched from db by setting a value in vSeekerPage between 1 and X prior to search.
 
<s>Even if the UI is not generated today - you can easily add "next" and "prev" buttons that change vSeekerPage by +/- one and do selfVM.Search.</s> UI is now generated in both WPF and Angular.
 
a.k.a Seekmore, seek more

Latest revision as of 15:46, 10 February 2024

This article explains the paging functionality available for Seeking_the_database_with_OCLps.

Using the multivariable seeker to search the database, you can configure the seeker to return the number of search result pages if the search does not fit within the MaxFetch setting.

To set this up, the seeker logic looks for a set of known variable names to communicate the results in:

Variable name Type Use
vSeekerPage Integer You set: If this variable is found in a seeker - it controls what the search shows, on what page it is - vSeekerResultCount/vSeekerPageLength
vSeekerPageLength Integer You set: The number of items you want on a page
vSeekerPageCount Integer Logic sets: The number of pages is set by the search logic for you to use, add variable, and use type integer
vSeekerResultCount Int64 Logic sets: Total number of results by the search. The count of the SQL query is set by search logic
IsSeekerResultGrid=true on the Nesting of your grid to know where paging buttons should go

See also: MaxFetch. MaxFetch controls the maximum number of records returned. The default if not using MaxFetch is 20 records. MaxFetch doesn't need the above variables to work. Note that MaxFetch is a tagged value.

The Autoforms construct seeker that makes use of paging refers to an Autoform-generated seeker to see details.

Currently, this is available in the WPF-client and Angular-Turnkey-client (new 2020-Aug).

To let the Framework know which grid on the page handles your search result, you must also add the tagged value IsSeekerResultGrid=true on the Nesting of your grid - again this is done by the AutoForms seekers.

Same Explained in Other Words

When paging is turned on (define the variables above to turn it on), you will first execute the query with "select count(*) ...." to get the total count of hits in the DB - this value is assigned to the variable vSeekerResultCount.

You should set a desired page length - or expose this to your end users in the variable vSeekerPageLength.

The total number of pages available after the search is then vSeekerPageCount:=vSeekerResultCount/vSeekerPageLength

If there are X pages available, you control what page is actually fetched from the DB by setting a value in vSeekerPage between 1 and X prior to the search.

UI is now generated in both WPF and Angular.

a.k.a Seekmore, seek more

This page was edited 97 days ago on 02/10/2024. What links here