Any way to get query data dynamically while its executing.
A client asked , if it is possible to get query data dynamically while it is executing, in batches for example.
instead of waiting until all the data is fetched and formated, client wants to get each time part of the data that has already been parsed.
for example select * from table limit 10000; (instead of waiting to all the 10000 rows get 1000 each time)
if it exists does it works with the order by clause?
Best Answers
-
marcothesane - Select Field - Administrator
This sounds to me as a front-end functionality rather than a Vertica sided one.
In a JDBC / ODBC front end application, you SQLPrepare and SQLExecute a query - returning maybe 10,000 rows - and then you set the rowset to , say, 100 rows ; then repeated calls of SQLFetch() will return 100 rows at a time.
Is that what you are looking for?5 -
Abhishek_Rana Employee
There is a way in vertica to fetch result sets in batches using OFFSET.
But there can be some tricks to accomplish this depending upon customer's use case too:
1) In client software like DBeaver we have an option to set number of records to fetch by setting "Resultset Fetch Size".
2) I can think of a another way to accomplish that using below trick with rownum:
Set below variables as per need:Suppose I want batch of 10 rows at a time:
\set NumRows 10Now I want 2nd resulset, means rows from 20-30
\set i 2Now use below example query to fetch records: I am using eep as table name.
SELECT * FROM
(
SELECT
row_number() OVER(ORDER BY transaction_id) AS RW,
eep.*
FROM eep
) myAlias
WHERE myAlias.RW BETWEEN (:NumRows * :i) AND ((:NumRows * :i)+ :NumRows)Hope it helps.
5
Answers
Do you want the paging function?
You can refer to OFFSETClause
@qinchaofeng yes the client referred paging function.
Not really sure if offsetclause will help to get query data dynamically.
thanks @marcothesane that actually makes sense.
In addition maybe parallel insert select can provide a way to analyze portions of the result set.
Example 1:
Example 2: