diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2022-11-11 08:54:35 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2022-11-11 08:54:35 +0000 |
commit | d1f00706bff58b863b0a1c5bf4adf39d36049d4c (patch) | |
tree | 3a8ecc5d1509d655d5df6b1455bc1e309da2c02c /README.md | |
parent | Releasing debian version 9.0.6-1. (diff) | |
download | sqlglot-d1f00706bff58b863b0a1c5bf4adf39d36049d4c.tar.xz sqlglot-d1f00706bff58b863b0a1c5bf4adf39d36049d4c.zip |
Merging upstream version 10.0.1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'README.md')
-rw-r--r-- | README.md | 49 |
1 files changed, 35 insertions, 14 deletions
@@ -14,7 +14,7 @@ Contributions are very welcome in SQLGlot; read the [contribution guide](https:/ * [Install](#install) * [Documentation](#documentation) -* [Run Tests & Lint](#run-tests-and-lint) +* [Run Tests and Lint](#run-tests-and-lint) * [Examples](#examples) * [Formatting and Transpiling](#formatting-and-transpiling) * [Metadata](#metadata) @@ -22,7 +22,6 @@ Contributions are very welcome in SQLGlot; read the [contribution guide](https:/ * [Unsupported Errors](#unsupported-errors) * [Build and Modify SQL](#build-and-modify-sql) * [SQL Optimizer](#sql-optimizer) - * [SQL Annotations](#sql-annotations) * [AST Introspection](#ast-introspection) * [AST Diff](#ast-diff) * [Custom Dialects](#custom-dialects) @@ -51,7 +50,7 @@ pip3 install -r dev-requirements.txt ## Documentation -SQLGlot's uses [pdocs](https://pdoc.dev/) to serve its API documentation: +SQLGlot uses [pdocs](https://pdoc.dev/) to serve its API documentation: ``` pdoc sqlglot --docformat google @@ -121,6 +120,39 @@ LEFT JOIN `baz` ON `f`.`a` = `baz`.`a` ``` +Comments are also preserved in a best-effort basis when transpiling SQL code: + +```python +sql = """ +/* multi + line + comment +*/ +SELECT + tbl.cola /* comment 1 */ + tbl.colb /* comment 2 */, + CAST(x AS INT), # comment 3 + y -- comment 4 +FROM + bar /* comment 5 */, + tbl # comment 6 +""" + +print(sqlglot.transpile(sql, read='mysql', pretty=True)[0]) +``` + +```sql +/* multi + line + comment +*/ +SELECT + tbl.cola /* comment 1 */ + tbl.colb /* comment 2 */, + CAST(x AS INT), -- comment 3 + y -- comment 4 +FROM bar /* comment 5 */, tbl /* comment 6*/ +``` + + ### Metadata You can explore SQL with expression helpers to do things like find columns and tables: @@ -249,17 +281,6 @@ WHERE "x"."Z" = CAST('2021-02-01' AS DATE) ``` -### SQL Annotations - -SQLGlot supports annotations in the sql expression. This is an experimental feature that is not part of any of the SQL standards but it can be useful when needing to annotate what a selected field is supposed to be. Below is an example: - -```sql -SELECT - user # primary_key, - country -FROM users -``` - ### AST Introspection You can see the AST version of the sql by calling `repr`: |