Saturday, 20 February 2021

Modifiable rowsets

In V7 of Pyrrho I plan to have a more systematic approach to modifiable rowsets, which are useful in view-mediated data integration. Comments on the following proposals are welcome. Update: (12 April 2021) Working implementations of these ideas (alpha code) have now been posted to GitHub.

V7 uses immutable, shareable  rowsets (all typed values are also immutable and shareable). Compiled objects including table-valued functions and views have precompiled rowsets that are instantiated when accessed. Such instantiations are merged into the surrounding context, so that Pyrrho uses rowset review where other DBMS (and previous versions of Pyrrho) use query optimisation.

Some rowsets can be used to make changes to their base tables, and this feature is useful for views. As a rule of thumb this requires rowsets whose results expose simple rows and columns, possibly with a monotonic invertible adapter function, and thus all Yes entries in this table depend on this kind of additional requirement and the need to satisfy constraints and authorisation requirements. Such an operation adds to the transaction results a set of modifications for each of the individual tables involved. There are no entries below for rowsets with 0 or 1 base tables:

SubClass

Insert

Update

Delete

DistinctRowSet

No

No

No

DocArrayRowSet

Yes

Yes

Yes

EmptyRowSet

 

 

 

EvalRowSet

No

No

No

ExplicitRowSet

 

 

 

GroupingRowSet

No

No

Yes

IndexRowSet

(Yes)

(Yes)(Yes)

JoinRowSet

Yes

Yes

Yes

MergeRowSet

Intersection only

Yes

Yes

OldTableRowSet

 

 

 

OrderedRowSet

Yes

Yes

Yes

RestRowSet

Yes

Yes

Yes

RoutineCallRowSet

 

 

 

RowSetSection

No

Yes

Yes

SelectRowSet

See below

See below

Yes

SelectedRowSet

Yes

Yes

Yes

SqlRowSet

 

 

 

SystemRowSet

 

 

 

TableRowSet

(Yes)

(Yes)(Yes)

TransitionRowSet

 

 

 

TrivialRowSet

 

 

 

ValueRowSet

 

 

 

WindowRowSet

No

No

No 

 It will be obvious in most cases what these RowSet classes are for. TransitionRowSet and OldTableRowSet are used in trigger implementation and are not directly accessible. A SelectRowSet has columns that are expressions, and only certain expressions are invertible to retrieve the underlying column values, while a SelectedRowSet picks and re-arranges columns from its source. RestRowSets are used in the implementation of RESTViews.