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

Add support for ignoring DDL statements using -- sqlc:ignore. #3130

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

sgielen
Copy link

@sgielen sgielen commented Jan 12, 2024

NOTE: This PR is in a draft state, because it still requires (at the very least) documentation updates.

This PR adds support for commenting out parts of the schema. This is most useful in the case where the schema is defined by migrations, and such migrations contain queries that are not yet supported by sqlc. See for example #3129, #1756.

By wrapping such unsupported queries in sqlc:ignore comments, they are ignored and the rest of the schema can be parsed appropriately.

Example usage in a migration file:

CREATE TABLE person_email (
  email TEXT NOT NULL
);

-- sqlc:ignore until https://github.com/sqlc-dev/sqlc/issues/3129 is resolved
INSERT INTO person_email (`email`)
  SELECT pe.email
  FROM person AS p
  JOIN JSON_TABLE(p.emails, '$[*]' COLUMNS(email TEXT PATH '$')) AS pe;
-- sqlc:ignore end

ALTER TABLE person_email ADD PRIMARY KEY (`email`);

See #3129 for a full use-case.

Since the lines are actually cleared, instead of removed, errors on queries below the sqlc:ignore end marker are still shown with the correct line number.

@sgielen sgielen changed the title Add support for ignoring DDL statements using // sqlc:ignore. Add support for ignoring DDL statements using -- sqlc:ignore. Jan 12, 2024
@sgielen
Copy link
Author

sgielen commented Jan 12, 2024

@kyleconroy if you agree with this addition, then I would propose to add some documentation regarding this in https://docs.sqlc.dev/en/stable/howto/ddl.html. I can do that too within this PR, but wanted to await your thoughts first.

@sgielen
Copy link
Author

sgielen commented Feb 27, 2024

@kyleconroy what do you think about this addition?

@sgielen sgielen marked this pull request as ready for review April 14, 2024 15:29
@sgielen
Copy link
Author

sgielen commented Apr 14, 2024

@kyleconroy another bump - marking as non-draft in case that helps

@lisitsky
Copy link

Hi, @kyleconroy , @sgielen !

Thank you for the feature introduced!
I need the same functionality. How can I help with development? For example, with tests?

@lisitsky
Copy link

Hi, @kyleconroy , @sgielen !

Thank you for the feature introduced! I need the same functionality. How can I help with development? For example, with tests?

Hi! @sgielen I've updated the branch, added tests and rebased onto fresh master (it was relatively old), squashed into 1 commit. Could you please have a look? If you find tests useful, feel free to use them in your PR.
#3458

@sgielen
Copy link
Author

sgielen commented Jun 25, 2024

Hi, @kyleconroy , @sgielen !
Thank you for the feature introduced! I need the same functionality. How can I help with development? For example, with tests?

Hi! @sgielen I've updated the branch, added tests and rebased onto fresh master (it was relatively old), squashed into 1 commit. Could you please have a look? If you find tests useful, feel free to use them in your PR. #3458

Excellent! Thank you for this. I never wrote additional tests or documentation, because I wanted to hear from the maintainers first, but they never responded to my pings (@kyleconroy trying again). I can close this PR in favor of yours? For context, perhaps your PR's description could link to this one and/or the issues mentioned in my description above?

@Nigel2392
Copy link

Any progress on this? Would be a neat addition.

@farhaven
Copy link

farhaven commented Jan 2, 2025

@kyleconroy another ping on this. It'd be really useful as a workaround for more complex migrations that sqlc can't parse but which aren't strictly relevant to the schema itself (such as re-creating stored procedures, modifying constraints, ...)

@sgielen
Copy link
Author

sgielen commented Jan 2, 2025

Please review #3458, not this one, it is improved with regards to this one. I'll close this one as soon as that one is merged.

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

Successfully merging this pull request may close these issues.

4 participants