| From: | Tatsuo Ishii <ishii(at)sraoss(dot)co(dot)jp> | 
|---|---|
| To: | vik(at)postgresfriends(dot)org | 
| Cc: | pgsql-hackers(at)postgresql(dot)org | 
| Subject: | Re: Row pattern recognition | 
| Date: | 2023-06-26 08:45:07 | 
| Message-ID: | 20230626.174507.2071661484706170221.t-ishii@sranhm.sra.co.jp | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
>> In this case, we should require the user to specify AFTER MATCH SKIP
>> TO NEXT ROW so that behavior doesn't change when we implement the
>> standard default.  (Your patch might do this already.)
> 
> Agreed. I will implement AFTER MATCH SKIP PAST LAST ROW in the next
> patch and I will change the default to AFTER MATCH SKIP PAST LAST ROW.
Attached is the v2 patch to add support for AFTER MATCH SKIP PAST LAST
ROW and AFTER MATCH SKIP PAST LAST ROW. The default is AFTER MATCH
SKIP PAST LAST ROW as the standard default. Here are some examples to
demonstrate how those clauses affect the query result.
SELECT i, rpr(i) OVER w
  FROM (VALUES (1), (2), (3), (4)) AS v (i)
  WINDOW w AS (
   ROWS BETWEEN CURRENT ROW AND UNBOUNDED FOLLOWING
   AFTER MATCH SKIP PAST LAST ROW
   PATTERN (A B)
   DEFINE
    A AS i <= 2,
    B AS i <= 3
);
 i | rpr 
---+-----
 1 |   1
 2 |    
 3 |    
 4 |    
(4 rows)
In this example rpr starts from i = 1 and find that row i = 1
satisfies A, and row i = 2 satisfies B. Then rpr moves to row i = 3
and find that it does not satisfy A, thus the result is NULL. Same
thing can be said to row i = 4.
SELECT i, rpr(i) OVER w
  FROM (VALUES (1), (2), (3), (4)) AS v (i)
  WINDOW w AS (
   ROWS BETWEEN CURRENT ROW AND UNBOUNDED FOLLOWING
   AFTER MATCH SKIP TO NEXT ROW
   PATTERN (A B)
   DEFINE
    A AS i <= 2,
    B AS i <= 3
);
 i | rpr 
---+-----
 1 |   1
 2 |   2
 3 |    
 4 |    
(4 rows)
In this example rpr starts from i = 1 and find that row i = 1
satisfies A, and row i = 2 satisfies B (same as above). Then rpr moves
to row i = 2, rather than 3 because AFTER MATCH SKIP TO NEXT ROW is
specified.
Best reagards,
--
Tatsuo Ishii
SRA OSS LLC
English: http://www.sraoss.co.jp/index_en/
Japanese:http://www.sraoss.co.jp
| Attachment | Content-Type | Size | 
|---|---|---|
| v2-0001-Row-pattern-recognition-patch-for-raw-parser.patch | text/x-patch | 21.1 KB | 
| v2-0002-Row-pattern-recognition-patch-parse-analysis.patch | text/x-patch | 8.6 KB | 
| v2-0003-Row-pattern-recognition-patch-planner.patch | text/x-patch | 3.6 KB | 
| v2-0004-Row-pattern-recognition-patch-executor.patch | text/x-patch | 21.8 KB | 
| v2-0005-Row-pattern-recognition-patch-docs.patch | text/x-patch | 8.5 KB | 
| v2-0006-Row-pattern-recognition-patch-tests.patch | text/x-patch | 15.6 KB | 
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Heikki Linnakangas | 2023-06-26 08:59:06 | Re: 'converts internal representation to "..."' comment is confusing | 
| Previous Message | Michael Paquier | 2023-06-26 08:44:49 | Clean up JumbleQuery() from query text |