No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
===== The problem ===== | |||
It's easy to think that all tables of information is the same and has the same needs, but as soon as you dive into the details many needs merge. | It's easy to think that all tables of information is the same and has the same needs, but as soon as you dive into the details many needs merge. | ||
Revision as of 16:50, 4 February 2021
The problem
It's easy to think that all tables of information is the same and has the same needs, but as soon as you dive into the details many needs merge.
What to show
Lets start with these two types of getting records/rows/objects onto the user interface;
- You need to find and show a list of something out of tens of thousands in the database
- You need to show records related to something you already have on screen
For 1 you need to use SQL (oclPS) to find only as subset of rows and load only these into memory
For 2 you might be able to load all into the server memory, but it's often to many rows to send all of them to the client
Let's continue complicating the picture with search or filtering.
Search or Filter?
Search is when the user has written a search word.
Filter is when the user has selected a parameter to filter on, when the context suggests it or when a reduction is needed to make the result set manageble.
Ordering
Ordering is separate from searching and filtering
Ordering is obviously the order you present the rows found when searching och looking at something from a given context.
But, ordering complicated search when you work with only a partial result loaded into memory.
For example, let's say you have search for "Adam" in a customer database. There are a 1000 Adams' in the database, but we only load 100 and display on screen. Most likely you have ordered the persons on screen in order after the First name.
What needs to happen when the user wants to sort the table on screen in Last name order?
Your first thought might be: Just sort the rows on screen in the web browser.
But that won't be correct, because there is only 10% of the available person rows available and they don't represent the first rows if you were to look at the last names of all rows.
So, by asking for a different Sorting, the Search needs to be rerun in the database.
Combinations of Search/Filter and Ordering
- Search with oclPS requires rerunning the query if you show only a partial result set
- Showing a list of things based on an existing context
- If all rows are sent to the client and shown in one list, ordering client-side works
- I pagination or filtering is done server side, ordering needs also to be done server side, otherwise the client will not be sorting the correct set of row.
Turnkey includes logic for ordering/sorting rows using AngularJS without any additional work.
More reading;
Seeking the database with OCLps
Pagination: Search result pages