File: index.rst

package info (click to toggle)
sqlfluff 1.4.5-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 19,168 kB
  • sloc: python: 66,750; sql: 17,433; makefile: 20; sh: 19
file content (92 lines) | stat: -rw-r--r-- 3,241 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
📜 The SQL Linter for Humans
============================

Bored of not having a good SQL linter that works with whichever dialect
you're working with? Fluff is an extensible and modular linter designed
to help you write good SQL and catch errors and bad SQL before it hits
your database.

Notable changes:

* **0.1.x** involved a major re-write of the parser, completely changing
  the behaviour of the tool with respect to complex parsing.
* **0.2.x** added templating support and a big restructure of rules
  and changed how users might interact with SQLFluff on templated code.
* **0.3.x** drops support for python 2.7 and 3.4, and also reworks the
  handling of indentation linting in a potentially not backward
  compatible way.
* **0.4.x** dropped python 3.5, added the dbt templater, source mapping and
  also introduced the python API.
* **0.5.x** introduced some breaking changes to the API.
* **0.6.x** introduced parallel processing, which necessitated a big re-write
  of several innards.
* **0.7.x** extracted the dbt templater to a separate plugin and removed the
  ``exasol_fs`` dialect (now merged in with the main ``exasol``).
* **0.8.x** an improvement to the performance of the parser, a rebuild of the
  Jinja Templater, and a progress bar for the CLI.
* **0.9.x** refinement of the Simple API, dbt 1.0.0 compatibility,
  and the official SQLFluff Docker image.
* **0.10.x** removed support for older dbt versions < 0.20 and stopped ``fix``
  attempting to fix unparsable SQL.
* **0.11.x** rule L030 changed to use ``extended_capitalisation_policy``.
* **0.12.x** dialect is now mandatory, the ``spark3`` dialect was renamed to
  ``sparksql`` and  datatype capitalisation was extracted from L010 to it's own
  rule L063.
* **0.13.x** new rule for quoted literals, option to remove hanging indents in
  rule L003, and introduction of ``ignore_words_regex``.
* **1.0.0** first *stable* release, no major changes to take advantage of a
  point of relative stability.

Want to see where and how people are using SQLFluff in their projects?
Head over to :ref:`inthewildref` for inspiration.

Getting Started
^^^^^^^^^^^^^^^

To get started just install the package, make a sql file and then run
SQLFluff and point it at the file. For more details or if you don't
have python or pip already installed see :ref:`gettingstartedref`.

.. code-block:: text

    $ pip install sqlfluff
    $ echo "  SELECT a  +  b FROM tbl;  " > test.sql
    $ sqlfluff lint test.sql --dialect ansi
    == [test.sql] FAIL
    L:   1 | P:   1 | L050 | Files must not begin with newlines or whitespace.
    L:   1 | P:   3 | L003 | First line has unexpected indent
    L:   1 | P:  11 | L039 | Unnecessary whitespace found.
    L:   1 | P:  14 | L039 | Unnecessary whitespace found.
    L:   1 | P:  27 | L001 | Unnecessary trailing whitespace.

Contents
^^^^^^^^

.. toctree::
   :maxdepth: 3
   :caption: Documentation for SQLFluff:

   gettingstarted
   realworld
   vision
   teamrollout
   layout
   rules
   dialects
   production
   configuration
   cli
   api
   internals
   developingrules
   developingplugins
   inthewild
   jointhecommunity


Indices and tables
==================

* :ref:`genindex`
* :ref:`modindex`
* :ref:`search`