Re: [HACKERS] proposal: schema variables
David G. Johnston <david.g.johnston@gmail.com>
Commits
GET /api/v1/messages/:b64id/commits
the thread's linked commits as JSON, with link sources.
API reference →
-
Move WAL sequence code into its own file
- a87987cafca6 19 (unreleased) cited
-
Add ExplainState argument to pg_plan_query() and planner().
- c83ac02ec730 19 (unreleased) cited
-
Don't include access/htup_details.h in executor/tuptable.h
- 1a8b5b11e48a 19 (unreleased) cited
-
Refactor to avoid code duplication in transformPLAssignStmt.
- b0fb2c6aa5a4 19 (unreleased) cited
-
Avoid including commands/dbcommands.h in so many places
- 325fc0ab14d1 19 (unreleased) cited
-
Restrict psql meta-commands in plain-text dumps.
- 71ea0d679543 19 (unreleased) cited
-
Split func.sgml into more manageable pieces
- 4e23c9ef65ac 19 (unreleased) cited
-
Fix squashing algorithm for query texts
- 0f65f3eec478 18.0 cited
-
EXPLAIN: Always use two fractional digits for row counts.
- 95dbd827f2ed 18.0 cited
-
Preliminary refactoring of plpgsql expression construction.
- a654af21ae52 18.0 cited
-
plpgsql: pure parser and reentrant scanner
- 7b27f5fd36cb 18.0 cited
-
Add some sanity checks in executor for query ID reporting
- 24f520594809 18.0 cited
-
Fix misleading error message context
- 4af123ad45bd 18.0 cited
-
Add macros for looping through a List without a ListCell.
- 14dd0f27d7cd 17.0 cited
Attachments
- schema-variables-poc--dgj-response-diff.patch (application/octet-stream) patch
- schema-variables-poc--dgj-response-full.patch (application/octet-stream) patch
I've done a non-compilation documentation review, the diff from the poc patch and the diff from master are attached. Comments are inter-twined in the patch in xml comment format; though I reiterate (some of?) them below. On Fri, Feb 2, 2018 at 3:06 PM, Pavel Stehule <pavel.stehule@gmail.com> wrote: > Hi > > I wrote proof concept of schema variables. The patch is not nice, but the > functionality is almost complete (for scalars only) and can be good enough > for playing with this concept. > > I recap a goals (the order is random): > > 1. feature like PL/SQL package variables (with similar content life cycle) > 2. available from any PL used by PostgreSQL, data can be shared between > different PL > 3. possibility to store short life data in fast secured storage > The generic use of the word secure here bothers me. I'm taking it to be "protected by grant/revoke"-based privileges; plus session-locality. 4. possibility to pass parameters and results to/from anonymous blocks > 5. session variables with possibility to process static code check > What does "process static code check" means here? > 6. multiple API available from different environments - SQL commands, SQL > functions, internal functions > I made the public aspect of this explicit in the CREATE VARIABLE doc (though as noted below it probably belongs in section II) > 7. data are stored in binary form > Thoughts during my review: There is, for me, a cognitive dissonance between "schema variable" and "variable value" - I'm partial to the later. Since we use "setting" for GUCs the term variable here hopefully wouldn't cause ambiguity... I've noticed that we don't seem to have or enforce any policy on how to communicate "SQL standards compatibility" to the user... We are missing the ability to alter ownership (or at least its undocumented), and if that brings into existing ALTER VARIABLE we should probably add ALTER TYPE TO new_type USING (cast) for completeness. Its left for the reader to presume that because these are schema "relations" that namespace resolution via search_path works the same as any other relation. I think I've answered my own question regarding DISCARD in that "variables" discards values while if TEMP is in effect all temp variables are dropped. Examples abound though it doesn't feel like too much: but saying "The usage is very simple:" before giving the example in the function section seems to be outside of our general style. A better preamble than "An example:" would be nice but the example is so simple I could not think of anything worth writing. Its worth considering how both: https://www.postgresql.org/docs/10/static/ddl.html and https://www.postgresql.org/docs/10/static/queries.html could be updated to incorporate the broad picture of schema variables, with examples, and leave the reference (SQL and functions) sections mainly relegated to syntax and reminders. A moderate number of lines changed are for typos and minor grammar edits. David J.