Search result pages
No edit summary
(Automatically adding template at the end of the page.)
 
(18 intermediate revisions by 4 users not shown)
Line 1: Line 1:
This article explains the paging functionality available for Seeking_the_database_with_OCLps.
This article explains the paging functionality available for [[Training:Seeker view|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.
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:
To set this up, the seeker logic looks for a set of known variable names to communicate the results in:  


/// If this variable is found in a seeker - it controls what the search shows , on what page it is - vSeekerResultCount/vSeekerPageLength
{| 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''.


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


/// The number of pages is set by the search logic for you to use, add variable and use type integer
Currently, this is available in the WPF-client and '''Angular-Turnkey-client (new 2020-Aug)'''. 


''vSeekerPageCount''
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.


/// The number of items you want on a page
==== 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>.


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


/// The count of the sql query is set by search logic - you must add a variable of this name of type longint
The total number of pages available after the search is then <code>vSeekerPageCount:=vSeekerResultCount/vSeekerPageLength</code>


''vSeekerResultCount''
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.


The Autoforms construct seeker that make use of paging - refer to an autoform generated seeker to see details.
UI is now generated in both WPF and Angular.  


Currently this available in the WPF-client and '''Angular-Turnkey-client (new 2020-Aug)'''.
a.k.a Seekmore, seek more  
 
[[Category:Searching]]
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.
{{Edited|July|12|2024}}
 
==== Same explained with other words ====
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