Sqlfluff

Latest version: v3.3.1

Safety actively analyzes 724004 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 22 of 26

0.3.6

Not secure
Added

- `sqlfluff dialects` command to get a readout of available
dialects [+ associated docs].
- More helpful error messages when trying to run in Python2.
- Window functions now parse with `IGNORE`/`RESPECT` `NULLS`.
- Parsing of `current_timestamp` and similar functions. Thanks [dmateusp](https://github.com/dmateusp).
- Snowflake `QUALIFY` clause.

Changed

- Respect user config directories. Thanks [sethwoodworth](https://github.com/sethwoodworth).
- Fix incorrect reporting of L013 with `*`. Thanks [dmateusp](https://github.com/dmateusp).
- Fix incorrect reporting of L027 with column aliases. Thanks [pwildenhain](https://github.com/pwildenhain).
- Simplification of application of fixes and correction of
a case where fixes could be depleted. Thanks [NiallRees](https://github.com/NiallRees).
- Fix functions with a similar structure to `SUBSTRING`.
- Refactor BigQuery `REPLACE` and `EXCEPT` clauses.
- Bigquery date parts corrected.
- Snowflake array accessors.
- Psotgres `NOTNULL` and `ISNULL`.
- Bugfix in snowflake for keywords used in semistructured
queries.
- Nested `WITH` statements now parse.
- Performance improvements in the `fix` command.
- Numeric literals starting with a decimal now parse.
- Refactor the jinja templater.

0.3.5

Not secure
Added

- Patterns and Anti-patterns in documentation. Thanks [flpezet](https://github.com/flpezet).
- Functions in `GROUP BY`. Thanks [flpezet](https://github.com/flpezet).

Changed

- Deep bugfixes in the parser to handle simple matching better for a few
edge cases. Also added some logging deeper in the parser.
- Added in the `SelectableGrammar` and some related segments to make it
easier to refer to _select-like_ things in other grammars.
- Fixes to `CASE` statement parsing. Thanks [azhard](https://github.com/azhard).
- Fix to snowflake `SAMPLE` implementation. Thanks [rkm3](https://github.com/rkm3).
- Numerous docs fixes. Thanks [SimonStJG](https://github.com/SimonStJG),
[flpezet](https://github.com/flpezet), [s-pace](https://github.com/s-pace),
[nolanbconaway](https://github.com/nolanbconaway).

0.3.4

Not secure
Changed

- Implementation of the bigquery `CREATE MODEL` syntax. Thanks [barrywhart](https://github.com/barrywhart).
- Bugfixes for:
- Edge cases for L006
- False alarms on L025
- `ORDER BY x NULLS FIRST|LAST`
- `FOR` keyword in bigquery `SYSTEM_TIME` syntax.

0.3.3

Not secure
Added

- Added the `--nofail` option to `parse` and `lint` commands to assist
rollout.
- Added the `--version` option to complement the `version` option already
available on the cli.
- Parsing for `ALTER TABLE`.
- Warning for unset dialects when getting parsing errors.
- Configurable line lengths for output.

0.3.2

Not secure
Added

- Support for the Teradata dialect. Thanks [Katzmann1983](https://github.com/Katzmann1983)!
- A much more detailed getting started guide in the docs.
- For the `parse` command, added the `--profiler` and `--bench` options
to help debugging performance issues.
- Support for the `do` command in the jinja templater.
- Proper parsing of the concatenate operator (`||`).
- Proper indent handling of closing brackets.
- Logging and benchmarking of parse performance as part of the CI pipeline.
- Parsing of object references with defaults like `my_db..my_table`.
- Support for the `INTERVAL '4 days'` style interval expression.
- Configurable trailing or leading comma linting.
- Configurable indentation for `JOIN` clauses.
- Rules now have their own logging interface to improve debugging ability.
- Snowflake and Postgres dialects.
- Support for a `.sqlfluffignore` file to ignore certain paths.
- More generic interfaces for managing keywords in dialects, including `set`
interfaces for managing and creating keywords and the `Ref.keyword()` method
to refer to them, and the ability to refer directly to keyword names in
most grammars using strings directly. Includes `SegmentGenerator` objects
to bind dialect objects at runtime from sets. Thanks [Katzmann1983](https://github.com/Katzmann1983)!
- Rule `L029` for using unreserved keywords as variable names.
- The jinja templater now allows macros loaded from files, and the
hydration of variables ending in `_path` in the config files.
- JSON operators and the `DISTINCT ON ()` syntax for the postgres dialect.

Changed

- Refactor of whitespace and non-code handling so that segments are
less greedy and default to not holding whitespace on ends. This allows
more consistent linting rule application.
- Change config file reading to _case-sensitive_ to support case
sensitivity in jinja templating.
- Non-string values (including lists) now function in the python
and jinja templating libraries.
- Validation of the match results of grammars has been reduced. In
production cases the validation will still be done, but only on
_parse_ and not on _match_.
- At low verbosities, python level logging is also reduced.
- Some matcher rules in the parser can now be classified as _simple_
which allows them to shortcut some of the matching routines.
- Yaml output now double quotes values with newlines or tab characters.
- Better handling on hanging and closing indents when linting rule L003.
- More capable handline of multi-line comments so that indentation
and line length parsing works. This involves some deep changes to the
lexer.
- Getting violations from the linter now automatically takes into account
of ignore rules and filters.
- Several bugfixes, including catching potential infinite regress during
fixing of files, if one fix would re-introduce a problem with another.
- Behaviour of the `Bracketed` grammar has been changed to treat its
content as a `Sequence` rather than a `OneOf`.
- Move to `SandboxedEnvironment` rather than `Environment` for jinja
templating for security.
- Improve reporting of templating issues, especially for the jinja templater
so that missing variables are rendered as blanks, but still reported as
templating violations.

0.3.1

Not secure
Added

- Support for `a.b.*` on top of `a.*` in select target expressions.

Page 22 of 26

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.