Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Loading database schema files, revisited #118

Open
paurkedal opened this issue Aug 8, 2024 · 1 comment
Open

Loading database schema files, revisited #118

paurkedal opened this issue Aug 8, 2024 · 1 comment

Comments

@paurkedal
Copy link
Owner

paurkedal commented Aug 8, 2024

Caqti currently provides a variant of the query parser angstrom_list_parser which can be used to split up a schema file into individual statements, which can be committed. However, since Caqti does not parse SQL apart from the lexical level, it cannot always know whether a semicolon terminates a top-level statement. The case which motivated this issue comes from #87:

CREATE TRIGGER no_update_stream_events BEFORE UPDATE ON stream_events
BEGIN
  SELECT RAISE (FAIL, 'cannot update stream_events');
END

Note that the BEGIN-END block can contain multiple statements (and thus bare semicolons).

The first question is maybe whether angstrom_list_parser is the right approach. Note here that the input is parsed as a Caqti template, not as a plain SQL schema. This is good in the sense that it allows parametrising schema names or other parts, but doing that means loosing compatibility with other tools (such as psql). This also provides en escaping mechanism which could be used to avoid the issue, though writing $(semicolon) in place of ; is rather verbose and would force non-compatibility.

A better approach if the intention is to load a plain (non-template) SQL schema would be to use a function or parser which merely splits the code at right points, or to allow multiple statements to be submitted in the same commit. The support for the latter must be investigated for MariaDB, while it already seems to work for Sqlite3, and could be supported for PostgreSQL non-prepared statements.

@anmonteiro
Copy link

the intention is to load a plain (non-template) SQL schema

this is my use case. I currently have .sql files that represent migrations and may have multiple statements. On my system startup, I load the migration files that need to be applied and execute each within a logical transaction.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants