You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@airflow.apache.org by gi...@apache.org on 2022/08/18 10:17:01 UTC

[airflow-site] branch gh-pages updated: Deploying to gh-pages from @ 7ad3b3ff6ccb71f3ab993dd10fc936a42efe1223 🚀

This is an automated email from the ASF dual-hosted git repository.

github-bot pushed a commit to branch gh-pages
in repository https://gitbox.apache.org/repos/asf/airflow-site.git


The following commit(s) were added to refs/heads/gh-pages by this push:
     new 8e81b68954 Deploying to gh-pages from  @ 7ad3b3ff6ccb71f3ab993dd10fc936a42efe1223 🚀
8e81b68954 is described below

commit 8e81b68954ca5f1f68fea43b2fdec3282b3257b1
Author: potiuk <ja...@potiuk.com>
AuthorDate: Thu Aug 18 10:16:56 2022 +0000

    Deploying to gh-pages from  @ 7ad3b3ff6ccb71f3ab993dd10fc936a42efe1223 🚀
---
 _gen/packages-metadata.json                        |  1334 +--
 blog/airflow-1.10.10/index.html                    |     4 +-
 blog/airflow-1.10.12/index.html                    |     4 +-
 blog/airflow-1.10.8-1.10.9/index.html              |     4 +-
 blog/airflow-2.2.0/index.html                      |     4 +-
 blog/airflow-2.3.0/index.html                      |     4 +-
 blog/airflow-survey-2020/index.html                |     4 +-
 blog/airflow-survey-2022/index.html                |     4 +-
 blog/airflow-survey/index.html                     |     4 +-
 blog/airflow-two-point-oh-is-here/index.html       |     4 +-
 blog/airflow_summit_2021/index.html                |     4 +-
 blog/airflow_summit_2022/index.html                |     4 +-
 blog/announcing-new-website/index.html             |     4 +-
 blog/apache-airflow-for-newcomers/index.html       |     4 +-
 .../index.html                                     |     4 +-
 .../index.html                                     |     4 +-
 .../index.html                                     |     4 +-
 .../index.html                                     |     4 +-
 .../index.html                                     |     4 +-
 .../index.html                                     |     4 +-
 .../1.1.0/.buildinfo                               |     4 +
 .../airflow/providers/common/sql/hooks/index.html  |     5 +-
 .../providers/common/sql/hooks/sql/index.html      |   133 +-
 .../_api/airflow/providers/common/sql/index.html   |     5 +-
 .../providers/common/sql/operators/index.html      |     5 +-
 .../providers/common/sql/operators/sql/index.html  |   454 +-
 .../providers/common/sql/sensors/index.html        |     5 +-
 .../providers/common/sql/sensors/sql/index.html    |     7 +-
 .../sql/example_sql_column_table_check/index.html  |     5 +-
 .../tests/system/providers/common/sql/index.html   |     5 +-
 .../airflow/providers/common/sql/hooks/sql.html    |    99 +-
 .../providers/common/sql/operators/sql.html        |   633 +-
 .../airflow/providers/common/sql/sensors/sql.html  |     5 +-
 .../{stable => 1.1.0}/_modules/index.html          |     5 +-
 .../common/sql/example_sql_column_table_check.html |     7 +-
 .../providers/common/sql/hooks/index.rst.txt       |    15 +
 .../providers/common/sql/hooks/sql/index.rst.txt   |    77 +-
 .../airflow/providers/common/sql/index.rst.txt     |    17 +
 .../providers/common/sql/operators/index.rst.txt   |    15 +
 .../common/sql/operators/sql/index.rst.txt         |   457 +
 .../providers/common/sql/sensors/index.rst.txt     |    15 +
 .../providers/common/sql/sensors/sql/index.rst.txt |     2 +-
 .../example_sql_column_table_check/index.rst.txt   |    29 +
 .../system/providers/common/sql/index.rst.txt      |    15 +
 .../1.1.0/_sources/commits.rst.txt                 |    59 +
 .../1.1.0/_sources/connections.rst.txt             |    32 +
 .../{stable => 1.1.0}/_sources/index.rst.txt       |    11 +-
 .../installing-providers-from-sources.rst.txt      |    18 +
 .../1.1.0/_sources/operators.rst.txt               |   112 +
 .../1.1.0/_static/_gen/css/main-custom.min.css     |     1 +
 .../1.1.0/_static/_gen/css/main.min.css            |     7 +
 .../{stable => 1.1.0}/_static/_gen/js/docs.js      |     2 +-
 .../_sphinx_javascript_frameworks_compat.js        |   134 +
 .../1.1.0}/_static/basic.css                       |    31 +-
 .../1.1.0/_static/check-solid.svg                  |     4 +
 .../1.1.0/_static/clipboard.min.js                 |     7 +
 .../1.1.0/_static/copy-button.svg                  |     5 +
 .../1.1.0/_static/copybutton.css                   |    93 +
 .../1.1.0/_static/copybutton.js                    |   220 +
 .../1.1.0/_static/copybutton_funcs.js              |    58 +
 .../1.1.0/_static/doctools.js                      |   264 +
 .../_static/documentation_options.js               |     4 +-
 .../1.1.0/_static/file.png                         |   Bin 0 -> 286 bytes
 .../1.1.0/_static/graphviz.css                     |    19 +
 .../1.1.0/_static/jquery-3.6.0.js                  | 10881 +++++++++++++++++++
 .../1.1.0/_static/jquery.js                        |     2 +
 .../1.1.0/_static/language_data.js                 |   199 +
 .../1.1.0/_static/minus.png                        |   Bin 0 -> 90 bytes
 .../1.1.0/_static/pin_32.png                       |   Bin 0 -> 1201 bytes
 .../1.1.0/_static/plus.png                         |   Bin 0 -> 90 bytes
 .../1.1.0/_static/pygments.css                     |    74 +
 .../{stable => 1.1.0}/_static/searchtools.js       |    17 +-
 .../1.1.0/_static/underscore-1.13.1.js             |  2042 ++++
 .../1.1.0/_static/underscore.js                    |     6 +
 .../{stable => 1.1.0}/commits.html                 |    65 +-
 .../{stable => 1.1.0}/connections.html             |     5 +-
 .../{stable => 1.1.0}/genindex.html                |   137 +-
 .../{stable => 1.1.0}/index.html                   |    58 +-
 .../installing-providers-from-sources.html         |    27 +-
 .../1.1.0/objects.inv                              |   Bin 0 -> 1387 bytes
 .../{stable => 1.1.0}/operators.html               |     5 +-
 .../{stable => 1.1.0}/py-modindex.html             |     5 +-
 .../{stable => 1.1.0}/search.html                  |     5 +-
 .../1.1.0/searchindex.js                           |     1 +
 .../airflow/providers/common/sql/hooks/index.html  |     5 +-
 .../providers/common/sql/hooks/sql/index.html      |   133 +-
 .../_api/airflow/providers/common/sql/index.html   |     5 +-
 .../providers/common/sql/operators/index.html      |     5 +-
 .../providers/common/sql/operators/sql/index.html  |   454 +-
 .../providers/common/sql/sensors/index.html        |     5 +-
 .../providers/common/sql/sensors/sql/index.html    |     7 +-
 .../sql/example_sql_column_table_check/index.html  |     5 +-
 .../tests/system/providers/common/sql/index.html   |     5 +-
 .../airflow/providers/common/sql/hooks/sql.html    |    99 +-
 .../providers/common/sql/operators/sql.html        |   633 +-
 .../airflow/providers/common/sql/sensors/sql.html  |     5 +-
 .../stable/_modules/index.html                     |     5 +-
 .../common/sql/example_sql_column_table_check.html |     7 +-
 .../providers/common/sql/hooks/sql/index.rst.txt   |    77 +-
 .../common/sql/operators/sql/index.rst.txt         |   343 +-
 .../providers/common/sql/sensors/sql/index.rst.txt |     2 +-
 .../stable/_sources/commits.rst.txt                |    19 +
 .../stable/_sources/index.rst.txt                  |    11 +-
 .../stable/_static/_gen/css/main-custom.min.css    |     2 +-
 .../stable/_static/_gen/css/main.min.css           |     8 +-
 .../stable/_static/_gen/js/docs.js                 |     2 +-
 .../stable/_static/basic.css                       |    31 +-
 .../stable/_static/documentation_options.js        |     4 +-
 .../stable/_static/searchtools.js                  |    17 +-
 .../stable/commits.html                            |    65 +-
 .../stable/connections.html                        |     5 +-
 .../stable/genindex.html                           |   137 +-
 .../stable/index.html                              |    58 +-
 .../stable/installing-providers-from-sources.html  |    27 +-
 .../stable/objects.inv                             |   Bin 1120 -> 1387 bytes
 .../stable/operators.html                          |     5 +-
 .../stable/py-modindex.html                        |     5 +-
 .../stable/search.html                             |     5 +-
 .../stable/searchindex.js                          |     2 +-
 .../3.2.0/.buildinfo                               |     4 +
 .../databricks/hooks/databricks/index.html         |   113 +-
 .../databricks/hooks/databricks_base/index.html    |    58 +-
 .../databricks/hooks/databricks_sql/index.html     |    62 +-
 .../airflow/providers/databricks/hooks/index.html  |     5 +-
 .../_api/airflow/providers/databricks/index.html   |     5 +-
 .../databricks/operators/databricks/index.html     |    97 +-
 .../operators/databricks_repos/index.html          |    23 +-
 .../databricks/operators/databricks_sql/index.html |    22 +-
 .../providers/databricks/operators/index.html      |     5 +-
 .../databricks/triggers/databricks/index.html      |     9 +-
 .../providers/databricks/triggers/index.html       |     5 +-
 .../databricks/utils/databricks/index.html         |    21 +-
 .../airflow/providers/databricks/utils/index.html  |     5 +-
 .../databricks/example_databricks/index.html       |     5 +-
 .../databricks/example_databricks_repos/index.html |     5 +-
 .../databricks/example_databricks_sql/index.html   |     5 +-
 .../tests/system/providers/databricks/index.html   |     5 +-
 .../providers/databricks/hooks/databricks.html     |    34 +-
 .../databricks/hooks/databricks_base.html          |    43 +-
 .../providers/databricks/hooks/databricks_sql.html |    88 +-
 .../providers/databricks/operators/databricks.html |   144 +-
 .../databricks/operators/databricks_repos.html     |    49 +-
 .../databricks/operators/databricks_sql.html       |    36 +-
 .../providers/databricks/triggers/databricks.html  |     5 +-
 .../providers/databricks/utils/databricks.html     |    22 +-
 .../{stable => 3.2.0}/_modules/index.html          |     5 +-
 .../providers/databricks/example_databricks.html   |     7 +-
 .../databricks/example_databricks_repos.html       |     7 +-
 .../databricks/example_databricks_sql.html         |     7 +-
 .../databricks/hooks/databricks/index.rst.txt      |    87 +-
 .../databricks/hooks/databricks_base/index.rst.txt |    26 +-
 .../databricks/hooks/databricks_sql/index.rst.txt  |    32 +-
 .../providers/databricks/hooks/index.rst.txt       |    17 +
 .../airflow/providers/databricks/index.rst.txt     |    18 +
 .../databricks/operators/databricks/index.rst.txt  |    88 +-
 .../operators/databricks_repos/index.rst.txt       |    18 +-
 .../operators/databricks_sql/index.rst.txt         |    13 +-
 .../providers/databricks/operators/index.rst.txt   |    17 +
 .../databricks/triggers/databricks/index.rst.txt   |     4 +-
 .../providers/databricks/triggers/index.rst.txt    |    15 +
 .../databricks/utils/databricks/index.rst.txt      |    11 +-
 .../providers/databricks/utils/index.rst.txt       |    15 +
 .../databricks/example_databricks/index.rst.txt    |    46 +
 .../example_databricks_repos/index.rst.txt         |    34 +
 .../example_databricks_sql/index.rst.txt           |    46 +
 .../system/providers/databricks/index.rst.txt      |    17 +
 .../{stable => 3.2.0}/_sources/commits.rst.txt     |    23 +-
 .../_sources/connections/databricks.rst.txt        |     3 +-
 .../{stable => 3.2.0}/_sources/index.rst.txt       |     6 +-
 .../installing-providers-from-sources.rst.txt      |    18 +
 .../3.2.0/_sources/operators/copy_into.rst.txt     |    52 +
 .../3.2.0/_sources/operators/index.rst.txt         |    28 +
 .../3.2.0/_sources/operators/repos_create.rst.txt  |    69 +
 .../3.2.0/_sources/operators/repos_delete.rst.txt  |    61 +
 .../3.2.0/_sources/operators/repos_update.rst.txt  |    66 +
 .../3.2.0/_sources/operators/run_now.rst.txt       |    54 +
 .../3.2.0/_sources/operators/sql.rst.txt           |    86 +
 .../_sources/operators/submit_run.rst.txt          |    54 +-
 .../3.2.0/_static/_gen/css/main-custom.min.css     |     1 +
 .../3.2.0/_static/_gen/css/main.min.css            |     7 +
 .../3.2.0}/_static/_gen/js/docs.js                 |     2 +-
 .../_sphinx_javascript_frameworks_compat.js        |   134 +
 .../{stable => 3.2.0}/_static/basic.css            |    31 +-
 .../3.2.0/_static/check-solid.svg                  |     4 +
 .../3.2.0/_static/clipboard.min.js                 |     7 +
 .../3.2.0/_static/copy-button.svg                  |     5 +
 .../3.2.0/_static/copybutton.css                   |    93 +
 .../3.2.0/_static/copybutton.js                    |   220 +
 .../3.2.0/_static/copybutton_funcs.js              |    58 +
 .../3.2.0/_static/doctools.js                      |   264 +
 .../3.2.0}/_static/documentation_options.js        |     4 +-
 .../3.2.0/_static/file.png                         |   Bin 0 -> 286 bytes
 .../3.2.0/_static/graphviz.css                     |    19 +
 .../3.2.0/_static/jquery-3.6.0.js                  | 10881 +++++++++++++++++++
 .../3.2.0/_static/jquery.js                        |     2 +
 .../3.2.0/_static/language_data.js                 |   199 +
 .../3.2.0/_static/minus.png                        |   Bin 0 -> 90 bytes
 .../3.2.0/_static/pin_32.png                       |   Bin 0 -> 1201 bytes
 .../3.2.0/_static/plus.png                         |   Bin 0 -> 90 bytes
 .../3.2.0/_static/pygments.css                     |    74 +
 .../3.2.0}/_static/searchtools.js                  |    17 +-
 .../3.2.0/_static/underscore-1.13.1.js             |  2042 ++++
 .../3.2.0/_static/underscore.js                    |     6 +
 .../{stable => 3.2.0}/commits.html                 |   169 +-
 .../{stable => 3.2.0}/connections/databricks.html  |     8 +-
 .../{stable => 3.2.0}/genindex.html                |    27 +-
 .../{stable => 3.2.0}/index.html                   |   221 +-
 .../installing-providers-from-sources.html         |    27 +-
 .../3.2.0/objects.inv                              |   Bin 0 -> 2344 bytes
 .../{stable => 3.2.0}/operators/copy_into.html     |     5 +-
 .../{stable => 3.2.0}/operators/index.html         |     5 +-
 .../{stable => 3.2.0}/operators/repos_create.html  |     5 +-
 .../{stable => 3.2.0}/operators/repos_delete.html  |     5 +-
 .../{stable => 3.2.0}/operators/repos_update.html  |     5 +-
 .../{stable => 3.2.0}/operators/run_now.html       |     5 +-
 .../{stable => 3.2.0}/operators/sql.html           |     5 +-
 .../{stable => 3.2.0}/operators/submit_run.html    |    57 +-
 .../{stable => 3.2.0}/py-modindex.html             |     5 +-
 .../{stable => 3.2.0}/search.html                  |     5 +-
 .../3.2.0/searchindex.js                           |     1 +
 .../databricks/hooks/databricks/index.html         |   113 +-
 .../databricks/hooks/databricks_base/index.html    |    58 +-
 .../databricks/hooks/databricks_sql/index.html     |    62 +-
 .../airflow/providers/databricks/hooks/index.html  |     5 +-
 .../_api/airflow/providers/databricks/index.html   |     5 +-
 .../databricks/operators/databricks/index.html     |    97 +-
 .../operators/databricks_repos/index.html          |    23 +-
 .../databricks/operators/databricks_sql/index.html |    22 +-
 .../providers/databricks/operators/index.html      |     5 +-
 .../databricks/triggers/databricks/index.html      |     9 +-
 .../providers/databricks/triggers/index.html       |     5 +-
 .../databricks/utils/databricks/index.html         |    21 +-
 .../airflow/providers/databricks/utils/index.html  |     5 +-
 .../databricks/example_databricks/index.html       |     5 +-
 .../databricks/example_databricks_repos/index.html |     5 +-
 .../databricks/example_databricks_sql/index.html   |     5 +-
 .../tests/system/providers/databricks/index.html   |     5 +-
 .../providers/databricks/hooks/databricks.html     |    34 +-
 .../databricks/hooks/databricks_base.html          |    43 +-
 .../providers/databricks/hooks/databricks_sql.html |    88 +-
 .../providers/databricks/operators/databricks.html |   144 +-
 .../databricks/operators/databricks_repos.html     |    49 +-
 .../databricks/operators/databricks_sql.html       |    36 +-
 .../providers/databricks/triggers/databricks.html  |     5 +-
 .../providers/databricks/utils/databricks.html     |    22 +-
 .../stable/_modules/index.html                     |     5 +-
 .../providers/databricks/example_databricks.html   |     7 +-
 .../databricks/example_databricks_repos.html       |     7 +-
 .../databricks/example_databricks_sql.html         |     7 +-
 .../databricks/hooks/databricks/index.rst.txt      |    87 +-
 .../databricks/hooks/databricks_base/index.rst.txt |    26 +-
 .../databricks/hooks/databricks_sql/index.rst.txt  |    32 +-
 .../databricks/operators/databricks/index.rst.txt  |    88 +-
 .../operators/databricks_repos/index.rst.txt       |    18 +-
 .../operators/databricks_sql/index.rst.txt         |    13 +-
 .../databricks/triggers/databricks/index.rst.txt   |     4 +-
 .../databricks/utils/databricks/index.rst.txt      |    11 +-
 .../stable/_sources/commits.rst.txt                |    23 +-
 .../stable/_sources/connections/databricks.rst.txt |     3 +-
 .../stable/_sources/index.rst.txt                  |     6 +-
 .../stable/_sources/operators/submit_run.rst.txt   |    54 +-
 .../stable/_static/_gen/css/main-custom.min.css    |     2 +-
 .../stable/_static/_gen/css/main.min.css           |     8 +-
 .../stable/_static/_gen/js/docs.js                 |     2 +-
 .../stable/_static/basic.css                       |    31 +-
 .../stable/_static/documentation_options.js        |     4 +-
 .../stable/_static/searchtools.js                  |    17 +-
 .../stable/commits.html                            |   169 +-
 .../stable/connections/databricks.html             |     8 +-
 .../stable/genindex.html                           |    27 +-
 .../stable/index.html                              |   221 +-
 .../stable/installing-providers-from-sources.html  |    27 +-
 .../stable/objects.inv                             |   Bin 2352 -> 2344 bytes
 .../stable/operators/copy_into.html                |     5 +-
 .../stable/operators/index.html                    |     5 +-
 .../stable/operators/repos_create.html             |     5 +-
 .../stable/operators/repos_delete.html             |     5 +-
 .../stable/operators/repos_update.html             |     5 +-
 .../stable/operators/run_now.html                  |     5 +-
 .../stable/operators/sql.html                      |     5 +-
 .../stable/operators/submit_run.html               |    57 +-
 .../stable/py-modindex.html                        |     5 +-
 .../stable/search.html                             |     5 +-
 .../stable/searchindex.js                          |     2 +-
 index.html                                         |    26 +-
 search/index.html                                  |     4 +-
 sitemap.xml                                        |    98 +-
 use-cases/adobe/index.html                         |     4 +-
 use-cases/adyen/index.html                         |     4 +-
 use-cases/big-fish-games/index.html                |     4 +-
 use-cases/dish/index.html                          |     4 +-
 use-cases/experity/index.html                      |     4 +-
 use-cases/onefootball/index.html                   |     4 +-
 use-cases/plarium-krasnodar/index.html             |     4 +-
 use-cases/seniorlink/index.html                    |     4 +-
 use-cases/sift/index.html                          |     4 +-
 296 files changed, 35920 insertions(+), 2913 deletions(-)

diff --git a/_gen/packages-metadata.json b/_gen/packages-metadata.json
index 697d4f85ce..c6a0458169 100644
--- a/_gen/packages-metadata.json
+++ b/_gen/packages-metadata.json
@@ -1,7 +1,7 @@
 [
   {
-    "package-name": "apache-airflow-providers-jira",
-    "stable-version": "3.0.1",
+    "package-name": "apache-airflow-providers-sendgrid",
+    "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
@@ -11,117 +11,92 @@
       "2.0.2",
       "2.0.3",
       "2.0.4",
-      "2.0.5",
-      "3.0.0",
-      "3.0.1"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-airbyte",
-    "stable-version": "3.1.0",
-    "all-versions": [
-      "1.0.0",
-      "2.0.0",
-      "2.1.0",
-      "2.1.1",
-      "2.1.2",
-      "2.1.3",
-      "2.1.4",
-      "3.0.0",
-      "3.1.0"
+      "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-elasticsearch",
-    "stable-version": "4.2.0",
+    "package-name": "apache-airflow-providers-papermill",
+    "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "1.0.2",
-      "1.0.3",
-      "1.0.4",
+      "2.0.0",
       "2.0.1",
-      "2.0.2",
-      "2.0.3",
       "2.1.0",
       "2.2.0",
-      "3.0.0",
-      "3.0.1",
-      "3.0.2",
-      "3.0.3",
-      "4.0.0",
-      "4.1.0",
-      "4.2.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-openfaas",
-    "stable-version": "3.0.0",
-    "all-versions": [
-      "1.0.0",
-      "1.1.0",
-      "1.1.1",
-      "2.0.0",
-      "2.0.1",
-      "2.0.2",
-      "2.0.3",
+      "2.2.1",
+      "2.2.2",
+      "2.2.3",
       "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-opsgenie",
-    "stable-version": "4.0.0",
+    "package-name": "apache-airflow-providers-neo4j",
+    "stable-version": "3.1.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.0.2",
       "2.0.0",
       "2.0.1",
+      "2.0.2",
+      "2.1.0",
+      "2.1.1",
+      "2.1.2",
+      "2.1.3",
       "3.0.0",
-      "3.0.1",
-      "3.0.2",
-      "3.0.3",
-      "3.1.0",
-      "4.0.0"
+      "3.1.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-apache-beam",
-    "stable-version": "4.0.0",
+    "package-name": "apache-airflow-providers-snowflake",
+    "stable-version": "3.2.0",
     "all-versions": [
       "1.0.0",
-      "1.0.1",
+      "1.1.0",
+      "1.1.1",
+      "1.2.0",
+      "1.3.0",
       "2.0.0",
+      "2.1.0",
+      "2.1.1",
+      "2.2.0",
+      "2.3.0",
+      "2.3.1",
+      "2.4.0",
+      "2.5.0",
+      "2.5.1",
+      "2.5.2",
+      "2.6.0",
+      "2.7.0",
       "3.0.0",
-      "3.0.1",
       "3.1.0",
-      "3.2.0",
-      "3.2.1",
-      "3.3.0",
-      "3.4.0",
-      "4.0.0"
+      "3.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-microsoft-mssql",
+    "package-name": "apache-airflow-providers-databricks",
     "stable-version": "3.2.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.1.0",
       "2.0.0",
       "2.0.1",
+      "2.0.2",
       "2.1.0",
-      "2.1.1",
-      "2.1.2",
-      "2.1.3",
+      "2.2.0",
+      "2.3.0",
+      "2.4.0",
+      "2.5.0",
+      "2.6.0",
+      "2.7.0",
       "3.0.0",
       "3.1.0",
       "3.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-apache-sqoop",
+    "package-name": "apache-airflow-providers-segment",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
@@ -129,144 +104,140 @@
       "2.0.0",
       "2.0.1",
       "2.0.2",
-      "2.1.0",
-      "2.1.1",
-      "2.1.2",
-      "2.1.3",
+      "2.0.3",
+      "2.0.4",
       "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-salesforce",
-    "stable-version": "5.1.0",
+    "package-name": "apache-airflow-providers-microsoft-psrp",
+    "stable-version": "2.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "2.0.0",
-      "3.0.0",
-      "3.1.0",
-      "3.2.0",
-      "3.3.0",
-      "3.4.0",
-      "3.4.1",
-      "3.4.2",
-      "3.4.3",
-      "3.4.4",
-      "4.0.0",
-      "5.0.0",
-      "5.1.0"
+      "1.1.0",
+      "1.1.1",
+      "1.1.2",
+      "1.1.3",
+      "1.1.4",
+      "2.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-zendesk",
-    "stable-version": "4.0.0",
+    "package-name": "apache-airflow-providers-apache-kylin",
+    "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "2.0.0",
       "2.0.1",
-      "3.0.0",
-      "3.0.1",
-      "3.0.2",
-      "3.0.3",
-      "4.0.0"
+      "2.0.2",
+      "2.0.3",
+      "2.0.4",
+      "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-microsoft-winrm",
+    "package-name": "apache-airflow-providers-telegram",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.1.0",
-      "1.2.0",
+      "1.0.2",
       "2.0.0",
       "2.0.1",
       "2.0.2",
       "2.0.3",
       "2.0.4",
-      "2.0.5",
       "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-apache-hive",
-    "stable-version": "4.0.0",
+    "package-name": "apache-airflow-providers-cloudant",
+    "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.0.2",
-      "1.0.3",
       "2.0.0",
       "2.0.1",
       "2.0.2",
       "2.0.3",
-      "2.1.0",
-      "2.2.0",
-      "2.3.0",
-      "2.3.1",
-      "2.3.2",
-      "2.3.3",
-      "3.0.0",
-      "3.1.0",
-      "4.0.0"
+      "2.0.4",
+      "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-sftp",
-    "stable-version": "4.0.0",
+    "package-name": "apache-airflow-providers-influxdb",
+    "stable-version": "2.0.0",
     "all-versions": [
       "1.0.0",
       "1.1.0",
       "1.1.1",
-      "1.2.0",
+      "1.1.2",
+      "1.1.3",
+      "2.0.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-apache-drill",
+    "stable-version": "2.2.0",
+    "all-versions": [
+      "1.0.0",
+      "1.0.1",
+      "1.0.2",
+      "1.0.3",
+      "1.0.4",
       "2.0.0",
       "2.1.0",
-      "2.1.1",
-      "2.2.0",
-      "2.3.0",
-      "2.4.0",
-      "2.4.1",
-      "2.5.0",
-      "2.5.1",
-      "2.5.2",
-      "2.6.0",
-      "3.0.0",
-      "4.0.0"
+      "2.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-samba",
+    "package-name": "apache-airflow-providers-apache-hive",
     "stable-version": "4.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
+      "1.0.2",
+      "1.0.3",
       "2.0.0",
+      "2.0.1",
+      "2.0.2",
+      "2.0.3",
+      "2.1.0",
+      "2.2.0",
+      "2.3.0",
+      "2.3.1",
+      "2.3.2",
+      "2.3.3",
       "3.0.0",
-      "3.0.1",
-      "3.0.2",
-      "3.0.3",
-      "3.0.4",
+      "3.1.0",
       "4.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-apache-cassandra",
-    "stable-version": "3.0.0",
+    "package-name": "apache-airflow-providers-salesforce",
+    "stable-version": "5.1.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "2.0.0",
-      "2.0.1",
-      "2.1.0",
-      "2.1.1",
-      "2.1.2",
-      "2.1.3",
-      "3.0.0"
+      "3.0.0",
+      "3.1.0",
+      "3.2.0",
+      "3.3.0",
+      "3.4.0",
+      "3.4.1",
+      "3.4.2",
+      "3.4.3",
+      "3.4.4",
+      "4.0.0",
+      "5.0.0",
+      "5.1.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-plexus",
+    "package-name": "apache-airflow-providers-datadog",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
@@ -280,160 +251,186 @@
     ]
   },
   {
-    "package-name": "apache-airflow-providers-imap",
-    "stable-version": "3.0.0",
+    "package-name": "apache-airflow-providers-alibaba",
+    "stable-version": "2.0.1",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "2.0.0",
-      "2.0.1",
-      "2.1.0",
-      "2.2.0",
-      "2.2.1",
-      "2.2.2",
-      "2.2.3",
-      "3.0.0"
+      "1.1.0",
+      "1.1.1",
+      "2.0.0",
+      "2.0.1"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-apache-druid",
-    "stable-version": "3.2.0",
+    "package-name": "apache-airflow-providers-slack",
+    "stable-version": "5.1.0",
+    "all-versions": [
+      "1.0.0",
+      "2.0.0",
+      "3.0.0",
+      "4.0.0",
+      "4.0.1",
+      "4.1.0",
+      "4.2.0",
+      "4.2.1",
+      "4.2.2",
+      "4.2.3",
+      "5.0.0",
+      "5.1.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-openfaas",
+    "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
-      "1.0.1",
       "1.1.0",
+      "1.1.1",
       "2.0.0",
       "2.0.1",
       "2.0.2",
-      "2.1.0",
-      "2.2.0",
-      "2.3.0",
-      "2.3.1",
-      "2.3.2",
-      "2.3.3",
-      "3.0.0",
-      "3.1.0",
-      "3.2.0"
+      "2.0.3",
+      "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-amazon",
-    "stable-version": "5.0.0",
+    "package-name": "apache-airflow-providers-samba",
+    "stable-version": "4.0.0",
     "all-versions": [
       "1.0.0",
-      "1.1.0",
-      "1.2.0",
-      "1.3.0",
-      "1.4.0",
+      "1.0.1",
       "2.0.0",
-      "2.1.0",
-      "2.2.0",
-      "2.3.0",
-      "2.4.0",
-      "2.5.0",
-      "2.6.0",
       "3.0.0",
-      "3.1.1",
-      "3.2.0",
-      "3.3.0",
-      "3.4.0",
-      "4.0.0",
-      "4.1.0",
-      "5.0.0"
+      "3.0.1",
+      "3.0.2",
+      "3.0.3",
+      "3.0.4",
+      "4.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-oracle",
-    "stable-version": "3.3.0",
+    "package-name": "apache-airflow-providers-dbt-cloud",
+    "stable-version": "2.1.0",
     "all-versions": [
-      "1.0.0",
       "1.0.1",
-      "1.1.0",
+      "1.0.2",
       "2.0.0",
       "2.0.1",
-      "2.1.0",
-      "2.2.0",
-      "2.2.1",
-      "2.2.2",
-      "2.2.3",
-      "3.0.0",
-      "3.1.0",
-      "3.2.0",
-      "3.3.0"
+      "2.1.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-mysql",
+    "package-name": "apache-airflow-providers-microsoft-mssql",
     "stable-version": "3.2.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.0.2",
       "1.1.0",
       "2.0.0",
+      "2.0.1",
       "2.1.0",
       "2.1.1",
-      "2.2.0",
-      "2.2.1",
-      "2.2.2",
-      "2.2.3",
+      "2.1.2",
+      "2.1.3",
       "3.0.0",
       "3.1.0",
       "3.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-neo4j",
-    "stable-version": "3.1.0",
+    "package-name": "apache-airflow-providers-jenkins",
+    "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
+      "1.1.0",
       "2.0.0",
       "2.0.1",
       "2.0.2",
+      "2.0.3",
+      "2.0.4",
+      "2.0.5",
+      "2.0.6",
+      "2.0.7",
       "2.1.0",
-      "2.1.1",
-      "2.1.2",
-      "2.1.3",
-      "3.0.0",
-      "3.1.0"
+      "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-papermill",
-    "stable-version": "3.0.0",
+    "package-name": "apache-airflow",
+    "stable-version": "2.3.3",
     "all-versions": [
-      "1.0.0",
-      "1.0.1",
-      "1.0.2",
+      "1.10.1",
+      "1.10.2",
+      "1.10.3",
+      "1.10.4",
+      "1.10.5",
+      "1.10.6",
+      "1.10.7",
+      "1.10.8",
+      "1.10.9",
+      "1.10.10",
+      "1.10.11",
+      "1.10.12",
+      "1.10.13",
+      "1.10.14",
+      "1.10.15",
       "2.0.0",
       "2.0.1",
+      "2.0.2",
       "2.1.0",
+      "2.1.1",
+      "2.1.2",
+      "2.1.3",
+      "2.1.4",
       "2.2.0",
       "2.2.1",
       "2.2.2",
       "2.2.3",
-      "3.0.0"
+      "2.2.4",
+      "2.2.5",
+      "2.3.0",
+      "2.3.1",
+      "2.3.2",
+      "2.3.3"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-apache-pinot",
+    "package-name": "apache-airflow-providers-vertica",
     "stable-version": "3.2.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "2.0.0",
       "2.0.1",
-      "2.0.2",
-      "2.0.3",
-      "2.0.4",
+      "2.1.0",
+      "2.1.1",
+      "2.1.2",
+      "2.1.3",
       "3.0.0",
       "3.1.0",
       "3.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-apache-pig",
+    "package-name": "apache-airflow-providers-yandex",
+    "stable-version": "3.1.0",
+    "all-versions": [
+      "1.0.0",
+      "1.0.1",
+      "2.0.0",
+      "2.1.0",
+      "2.2.0",
+      "2.2.1",
+      "2.2.2",
+      "2.2.3",
+      "3.0.0",
+      "3.1.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-discord",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
@@ -443,82 +440,103 @@
       "2.0.2",
       "2.0.3",
       "2.0.4",
+      "2.1.4",
       "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-hashicorp",
-    "stable-version": "3.1.0",
+    "package-name": "apache-airflow-providers-sqlite",
+    "stable-version": "3.2.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "1.0.2",
       "2.0.0",
+      "2.0.1",
+      "2.1.0",
       "2.1.1",
       "2.1.2",
       "2.1.3",
-      "2.1.4",
-      "2.2.0",
       "3.0.0",
-      "3.0.1",
-      "3.1.0"
+      "3.1.0",
+      "3.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-asana",
-    "stable-version": "2.0.1",
+    "package-name": "apache-airflow-providers-oracle",
+    "stable-version": "3.3.0",
     "all-versions": [
       "1.0.0",
+      "1.0.1",
       "1.1.0",
-      "1.1.1",
-      "1.1.2",
-      "1.1.3",
       "2.0.0",
-      "2.0.1"
+      "2.0.1",
+      "2.1.0",
+      "2.2.0",
+      "2.2.1",
+      "2.2.2",
+      "2.2.3",
+      "3.0.0",
+      "3.1.0",
+      "3.2.0",
+      "3.3.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-mongo",
+    "package-name": "apache-airflow-providers-celery",
+    "stable-version": "3.0.0",
+    "all-versions": [
+      "1.0.0",
+      "1.0.1",
+      "2.0.0",
+      "2.1.0",
+      "2.1.1",
+      "2.1.2",
+      "2.1.3",
+      "2.1.4",
+      "3.0.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-imap",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "2.0.0",
+      "2.0.1",
       "2.1.0",
       "2.2.0",
-      "2.3.0",
-      "2.3.1",
-      "2.3.2",
-      "2.3.3",
+      "2.2.1",
+      "2.2.2",
+      "2.2.3",
       "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-tableau",
-    "stable-version": "3.0.1",
+    "package-name": "apache-airflow-providers-trino",
+    "stable-version": "4.0.0",
     "all-versions": [
       "1.0.0",
       "2.0.0",
+      "2.0.1",
+      "2.0.2",
       "2.1.0",
       "2.1.1",
       "2.1.2",
-      "2.1.3",
-      "2.1.4",
-      "2.1.5",
-      "2.1.6",
-      "2.1.7",
-      "2.1.8",
+      "2.2.0",
+      "2.3.0",
       "3.0.0",
-      "3.0.1"
+      "3.1.0",
+      "4.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-singularity",
+    "package-name": "apache-airflow-providers-apache-pig",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.1.0",
       "2.0.0",
       "2.0.1",
       "2.0.2",
@@ -528,48 +546,83 @@
     ]
   },
   {
-    "package-name": "apache-airflow-providers-sqlite",
+    "package-name": "apache-airflow-providers-apache-pinot",
     "stable-version": "3.2.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.0.2",
       "2.0.0",
       "2.0.1",
-      "2.1.0",
-      "2.1.1",
-      "2.1.2",
-      "2.1.3",
+      "2.0.2",
+      "2.0.3",
+      "2.0.4",
       "3.0.0",
       "3.1.0",
       "3.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-telegram",
+    "package-name": "apache-airflow-providers-mongo",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.0.2",
+      "2.0.0",
+      "2.1.0",
+      "2.2.0",
+      "2.3.0",
+      "2.3.1",
+      "2.3.2",
+      "2.3.3",
+      "3.0.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-microsoft-winrm",
+    "stable-version": "3.0.0",
+    "all-versions": [
+      "1.0.0",
+      "1.0.1",
+      "1.1.0",
+      "1.2.0",
       "2.0.0",
       "2.0.1",
       "2.0.2",
       "2.0.3",
       "2.0.4",
+      "2.0.5",
       "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-influxdb",
-    "stable-version": "2.0.0",
+    "package-name": "apache-airflow-providers-apache-cassandra",
+    "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
-      "1.1.0",
-      "1.1.1",
-      "1.1.2",
-      "1.1.3",
-      "2.0.0"
+      "1.0.1",
+      "2.0.0",
+      "2.0.1",
+      "2.1.0",
+      "2.1.1",
+      "2.1.2",
+      "2.1.3",
+      "3.0.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-apache-sqoop",
+    "stable-version": "3.0.0",
+    "all-versions": [
+      "1.0.0",
+      "1.0.1",
+      "2.0.0",
+      "2.0.1",
+      "2.0.2",
+      "2.1.0",
+      "2.1.1",
+      "2.1.2",
+      "2.1.3",
+      "3.0.0"
     ]
   },
   {
@@ -589,6 +642,24 @@
       "3.1.0"
     ]
   },
+  {
+    "package-name": "apache-airflow-providers-qubole",
+    "stable-version": "3.2.0",
+    "all-versions": [
+      "1.0.0",
+      "1.0.1",
+      "1.0.2",
+      "2.0.0",
+      "2.0.1",
+      "2.1.0",
+      "2.1.1",
+      "2.1.2",
+      "2.1.3",
+      "3.0.0",
+      "3.1.0",
+      "3.2.0"
+    ]
+  },
   {
     "package-name": "apache-airflow-providers-microsoft-azure",
     "stable-version": "4.2.0",
@@ -617,83 +688,129 @@
     ]
   },
   {
-    "package-name": "apache-airflow-providers-discord",
-    "stable-version": "3.0.0",
+    "package-name": "apache-airflow-providers-github",
+    "stable-version": "2.1.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
+      "1.0.2",
+      "1.0.3",
       "2.0.0",
-      "2.0.1",
-      "2.0.2",
-      "2.0.3",
-      "2.0.4",
-      "2.1.4",
-      "3.0.0"
+      "2.1.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-apache-drill",
-    "stable-version": "2.2.0",
+    "package-name": "apache-airflow-providers-apache-beam",
+    "stable-version": "4.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.0.2",
-      "1.0.3",
-      "1.0.4",
       "2.0.0",
-      "2.1.0",
-      "2.2.0"
+      "3.0.0",
+      "3.0.1",
+      "3.1.0",
+      "3.2.0",
+      "3.2.1",
+      "3.3.0",
+      "3.4.0",
+      "4.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-postgres",
-    "stable-version": "5.2.0",
+    "package-name": "apache-airflow-providers-ssh",
+    "stable-version": "3.1.0",
     "all-versions": [
       "1.0.0",
-      "1.0.1",
-      "1.0.2",
+      "1.1.0",
+      "1.2.0",
+      "1.3.0",
       "2.0.0",
       "2.1.0",
+      "2.1.1",
       "2.2.0",
       "2.3.0",
       "2.4.0",
+      "2.4.1",
+      "2.4.2",
+      "2.4.3",
+      "2.4.4",
       "3.0.0",
-      "4.0.0",
-      "4.0.1",
-      "4.1.0",
-      "5.0.0",
-      "5.1.0",
-      "5.2.0"
+      "3.1.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-microsoft-psrp",
-    "stable-version": "2.0.0",
+    "package-name": "apache-airflow-providers-apache-hdfs",
+    "stable-version": "3.1.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.1.0",
-      "1.1.1",
-      "1.1.2",
-      "1.1.3",
-      "1.1.4",
-      "2.0.0"
+      "2.0.0",
+      "2.1.0",
+      "2.1.1",
+      "2.2.0",
+      "2.2.1",
+      "2.2.2",
+      "2.2.3",
+      "3.0.0",
+      "3.0.1",
+      "3.1.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-databricks",
-    "stable-version": "3.1.0",
+    "package-name": "apache-airflow-providers-apache-druid",
+    "stable-version": "3.2.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
+      "1.1.0",
       "2.0.0",
       "2.0.1",
       "2.0.2",
       "2.1.0",
       "2.2.0",
       "2.3.0",
+      "2.3.1",
+      "2.3.2",
+      "2.3.3",
+      "3.0.0",
+      "3.1.0",
+      "3.2.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-airbyte",
+    "stable-version": "3.1.0",
+    "all-versions": [
+      "1.0.0",
+      "2.0.0",
+      "2.1.0",
+      "2.1.1",
+      "2.1.2",
+      "2.1.3",
+      "2.1.4",
+      "3.0.0",
+      "3.1.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-docker",
+    "stable-version": "3.1.0",
+    "all-versions": [
+      "1.0.0",
+      "1.0.1",
+      "1.0.2",
+      "1.1.0",
+      "1.2.0",
+      "2.0.0",
+      "2.1.0",
+      "2.1.1",
+      "2.2.0",
+      "2.3.0",
       "2.4.0",
+      "2.4.1",
       "2.5.0",
+      "2.5.1",
+      "2.5.2",
       "2.6.0",
       "2.7.0",
       "3.0.0",
@@ -701,7 +818,7 @@
     ]
   },
   {
-    "package-name": "apache-airflow-providers-presto",
+    "package-name": "apache-airflow-providers-opsgenie",
     "stable-version": "4.0.0",
     "all-versions": [
       "1.0.0",
@@ -709,18 +826,16 @@
       "1.0.2",
       "2.0.0",
       "2.0.1",
-      "2.1.0",
-      "2.1.1",
-      "2.1.2",
-      "2.2.0",
-      "2.2.1",
       "3.0.0",
+      "3.0.1",
+      "3.0.2",
+      "3.0.3",
       "3.1.0",
       "4.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-sendgrid",
+    "package-name": "apache-airflow-providers-dingding",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
@@ -735,198 +850,119 @@
     ]
   },
   {
-    "package-name": "apache-airflow-providers-cloudant",
-    "stable-version": "3.0.0",
+    "package-name": "apache-airflow-providers-asana",
+    "stable-version": "2.0.1",
     "all-versions": [
       "1.0.0",
-      "1.0.1",
+      "1.1.0",
+      "1.1.1",
+      "1.1.2",
+      "1.1.3",
       "2.0.0",
-      "2.0.1",
-      "2.0.2",
-      "2.0.3",
-      "2.0.4",
-      "3.0.0"
+      "2.0.1"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-exasol",
-    "stable-version": "4.0.0",
+    "package-name": "apache-airflow-providers-hashicorp",
+    "stable-version": "3.1.0",
     "all-versions": [
       "1.0.0",
-      "1.1.0",
-      "1.1.1",
+      "1.0.1",
+      "1.0.2",
       "2.0.0",
-      "2.0.1",
-      "2.1.0",
       "2.1.1",
       "2.1.2",
       "2.1.3",
+      "2.1.4",
+      "2.2.0",
       "3.0.0",
-      "3.1.0",
-      "4.0.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-common-sql",
-    "stable-version": "1.0.0",
-    "all-versions": [
-      "1.0.0"
+      "3.0.1",
+      "3.1.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-redis",
-    "stable-version": "3.0.0",
+    "package-name": "apache-airflow-providers-google",
+    "stable-version": "8.3.0",
     "all-versions": [
+      "0.0.1",
+      "0.0.2",
       "1.0.0",
-      "1.0.1",
-      "2.0.0",
-      "2.0.1",
-      "2.0.2",
-      "2.0.3",
-      "2.0.4",
-      "3.0.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-ssh",
-    "stable-version": "3.1.0",
-    "all-versions": [
-      "1.0.0",
-      "1.1.0",
-      "1.2.0",
-      "1.3.0",
       "2.0.0",
       "2.1.0",
-      "2.1.1",
       "2.2.0",
-      "2.3.0",
-      "2.4.0",
-      "2.4.1",
-      "2.4.2",
-      "2.4.3",
-      "2.4.4",
       "3.0.0",
-      "3.1.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-snowflake",
-    "stable-version": "3.2.0",
-    "all-versions": [
-      "1.0.0",
-      "1.1.0",
-      "1.1.1",
-      "1.2.0",
-      "1.3.0",
-      "2.0.0",
-      "2.1.0",
-      "2.1.1",
-      "2.2.0",
-      "2.3.0",
-      "2.3.1",
-      "2.4.0",
-      "2.5.0",
-      "2.5.1",
-      "2.5.2",
-      "2.6.0",
-      "2.7.0",
-      "3.0.0",
-      "3.1.0",
-      "3.2.0"
+      "4.0.0",
+      "5.0.0",
+      "5.1.0",
+      "6.0.0",
+      "6.1.0",
+      "6.2.0",
+      "6.3.0",
+      "6.4.0",
+      "6.5.0",
+      "6.6.0",
+      "6.7.0",
+      "6.8.0",
+      "7.0.0",
+      "8.0.0",
+      "8.1.0",
+      "8.2.0",
+      "8.3.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-trino",
+    "package-name": "apache-airflow-providers-presto",
     "stable-version": "4.0.0",
     "all-versions": [
       "1.0.0",
+      "1.0.1",
+      "1.0.2",
       "2.0.0",
       "2.0.1",
-      "2.0.2",
       "2.1.0",
       "2.1.1",
       "2.1.2",
       "2.2.0",
-      "2.3.0",
+      "2.2.1",
       "3.0.0",
       "3.1.0",
       "4.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-odbc",
-    "stable-version": "3.1.1",
+    "package-name": "apache-airflow-providers-zendesk",
+    "stable-version": "4.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "2.0.0",
       "2.0.1",
-      "2.0.2",
-      "2.0.3",
-      "2.0.4",
       "3.0.0",
-      "3.1.0",
-      "3.1.1"
+      "3.0.1",
+      "3.0.2",
+      "3.0.3",
+      "4.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-yandex",
+    "package-name": "apache-airflow-providers-ftp",
     "stable-version": "3.1.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "2.0.0",
-      "2.1.0",
-      "2.2.0",
-      "2.2.1",
-      "2.2.2",
-      "2.2.3",
-      "3.0.0",
-      "3.1.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow",
-    "stable-version": "2.3.3",
-    "all-versions": [
-      "1.10.1",
-      "1.10.2",
-      "1.10.3",
-      "1.10.4",
-      "1.10.5",
-      "1.10.6",
-      "1.10.7",
-      "1.10.8",
-      "1.10.9",
-      "1.10.10",
-      "1.10.11",
-      "1.10.12",
-      "1.10.13",
-      "1.10.14",
-      "1.10.15",
+      "1.1.0",
       "2.0.0",
       "2.0.1",
-      "2.0.2",
       "2.1.0",
       "2.1.1",
       "2.1.2",
-      "2.1.3",
-      "2.1.4",
-      "2.2.0",
-      "2.2.1",
-      "2.2.2",
-      "2.2.3",
-      "2.2.4",
-      "2.2.5",
-      "2.3.0",
-      "2.3.1",
-      "2.3.2",
-      "2.3.3"
+      "3.0.0",
+      "3.1.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-pagerduty",
-    "stable-version": "3.0.0",
+    "package-name": "apache-airflow-providers-jdbc",
+    "stable-version": "3.2.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
@@ -936,135 +972,32 @@
       "2.1.1",
       "2.1.2",
       "2.1.3",
-      "3.0.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-grpc",
-    "stable-version": "3.0.0",
-    "all-versions": [
-      "1.0.0",
-      "1.0.1",
-      "1.1.0",
-      "2.0.0",
-      "2.0.1",
-      "2.0.2",
-      "2.0.3",
-      "2.0.4",
-      "3.0.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-http",
-    "stable-version": "4.0.0",
-    "all-versions": [
-      "1.0.0",
-      "1.1.0",
-      "1.1.1",
-      "2.0.0",
-      "2.0.1",
-      "2.0.2",
-      "2.0.3",
-      "2.1.0",
-      "2.1.1",
-      "2.1.2",
       "3.0.0",
-      "4.0.0"
-    ]
-  },
-  {
-    "package-name": "helm-chart",
-    "stable-version": "1.6.0",
-    "all-versions": [
-      "1.0.0",
-      "1.1.0",
-      "1.2.0",
-      "1.3.0",
-      "1.4.0",
-      "1.5.0",
-      "1.6.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-slack",
-    "stable-version": "5.1.0",
-    "all-versions": [
-      "1.0.0",
-      "2.0.0",
-      "3.0.0",
-      "4.0.0",
-      "4.0.1",
-      "4.1.0",
-      "4.2.0",
-      "4.2.1",
-      "4.2.2",
-      "4.2.3",
-      "5.0.0",
-      "5.1.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-cncf-kubernetes",
-    "stable-version": "4.3.0",
-    "all-versions": [
-      "1.0.0",
-      "1.0.1",
-      "1.0.2",
-      "1.1.0",
-      "1.2.0",
-      "2.0.0",
-      "2.0.1",
-      "2.0.2",
-      "2.0.3",
-      "2.1.0",
-      "2.2.0",
-      "3.0.0",
-      "3.0.1",
-      "3.0.2",
       "3.1.0",
-      "3.1.1",
-      "3.1.2",
-      "4.0.0",
-      "4.0.1",
-      "4.0.2",
-      "4.1.0",
-      "4.2.0",
-      "4.3.0"
+      "3.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-vertica",
-    "stable-version": "3.2.0",
+    "package-name": "apache-airflow-providers-tableau",
+    "stable-version": "3.0.1",
     "all-versions": [
       "1.0.0",
-      "1.0.1",
       "2.0.0",
-      "2.0.1",
       "2.1.0",
       "2.1.1",
       "2.1.2",
       "2.1.3",
+      "2.1.4",
+      "2.1.5",
+      "2.1.6",
+      "2.1.7",
+      "2.1.8",
       "3.0.0",
-      "3.1.0",
-      "3.2.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-datadog",
-    "stable-version": "3.0.0",
-    "all-versions": [
-      "1.0.0",
-      "1.0.1",
-      "2.0.0",
-      "2.0.1",
-      "2.0.2",
-      "2.0.3",
-      "2.0.4",
-      "3.0.0"
+      "3.0.1"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-segment",
+    "package-name": "apache-airflow-providers-plexus",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
@@ -1078,117 +1011,131 @@
     ]
   },
   {
-    "package-name": "apache-airflow-providers-arangodb",
-    "stable-version": "2.0.0",
-    "all-versions": [
-      "1.0.0",
-      "2.0.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-dbt-cloud",
-    "stable-version": "2.1.0",
-    "all-versions": [
-      "1.0.1",
-      "1.0.2",
-      "2.0.0",
-      "2.0.1",
-      "2.1.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-qubole",
-    "stable-version": "3.2.0",
+    "package-name": "apache-airflow-providers-postgres",
+    "stable-version": "5.2.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "1.0.2",
       "2.0.0",
-      "2.0.1",
-      "2.1.0",
-      "2.1.1",
-      "2.1.2",
-      "2.1.3",
-      "3.0.0",
-      "3.1.0",
-      "3.2.0"
-    ]
-  },
-  {
-    "package-name": "apache-airflow-providers-jdbc",
-    "stable-version": "3.2.0",
-    "all-versions": [
-      "1.0.0",
-      "1.0.1",
-      "2.0.0",
-      "2.0.1",
       "2.1.0",
-      "2.1.1",
-      "2.1.2",
-      "2.1.3",
+      "2.2.0",
+      "2.3.0",
+      "2.4.0",
       "3.0.0",
-      "3.1.0",
-      "3.2.0"
+      "4.0.0",
+      "4.0.1",
+      "4.1.0",
+      "5.0.0",
+      "5.1.0",
+      "5.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-alibaba",
-    "stable-version": "2.0.1",
+    "package-name": "apache-airflow-providers-singularity",
+    "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "1.1.0",
-      "1.1.1",
       "2.0.0",
-      "2.0.1"
+      "2.0.1",
+      "2.0.2",
+      "2.0.3",
+      "2.0.4",
+      "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-jenkins",
-    "stable-version": "3.0.0",
+    "package-name": "apache-airflow-providers-cncf-kubernetes",
+    "stable-version": "4.3.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
+      "1.0.2",
       "1.1.0",
+      "1.2.0",
       "2.0.0",
       "2.0.1",
       "2.0.2",
       "2.0.3",
-      "2.0.4",
-      "2.0.5",
-      "2.0.6",
-      "2.0.7",
       "2.1.0",
-      "3.0.0"
+      "2.2.0",
+      "3.0.0",
+      "3.0.1",
+      "3.0.2",
+      "3.1.0",
+      "3.1.1",
+      "3.1.2",
+      "4.0.0",
+      "4.0.1",
+      "4.0.2",
+      "4.1.0",
+      "4.2.0",
+      "4.3.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-ftp",
-    "stable-version": "3.1.0",
+    "package-name": "apache-airflow-providers-amazon",
+    "stable-version": "5.0.0",
     "all-versions": [
       "1.0.0",
-      "1.0.1",
       "1.1.0",
+      "1.2.0",
+      "1.3.0",
+      "1.4.0",
       "2.0.0",
+      "2.1.0",
+      "2.2.0",
+      "2.3.0",
+      "2.4.0",
+      "2.5.0",
+      "2.6.0",
+      "3.0.0",
+      "3.1.1",
+      "3.2.0",
+      "3.3.0",
+      "3.4.0",
+      "4.0.0",
+      "4.1.0",
+      "5.0.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-elasticsearch",
+    "stable-version": "4.2.0",
+    "all-versions": [
+      "1.0.0",
+      "1.0.1",
+      "1.0.2",
+      "1.0.3",
+      "1.0.4",
       "2.0.1",
+      "2.0.2",
+      "2.0.3",
       "2.1.0",
-      "2.1.1",
-      "2.1.2",
+      "2.2.0",
       "3.0.0",
-      "3.1.0"
+      "3.0.1",
+      "3.0.2",
+      "3.0.3",
+      "4.0.0",
+      "4.1.0",
+      "4.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-apache-kylin",
+    "package-name": "apache-airflow-providers-pagerduty",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "2.0.0",
       "2.0.1",
-      "2.0.2",
-      "2.0.3",
-      "2.0.4",
+      "2.1.0",
+      "2.1.1",
+      "2.1.2",
+      "2.1.3",
       "3.0.0"
     ]
   },
@@ -1211,13 +1158,30 @@
     ]
   },
   {
-    "package-name": "apache-airflow-providers-docker",
-    "stable-version": "3.1.0",
+    "package-name": "apache-airflow-providers-http",
+    "stable-version": "4.0.0",
+    "all-versions": [
+      "1.0.0",
+      "1.1.0",
+      "1.1.1",
+      "2.0.0",
+      "2.0.1",
+      "2.0.2",
+      "2.0.3",
+      "2.1.0",
+      "2.1.1",
+      "2.1.2",
+      "3.0.0",
+      "4.0.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-sftp",
+    "stable-version": "4.0.0",
     "all-versions": [
       "1.0.0",
-      "1.0.1",
-      "1.0.2",
       "1.1.0",
+      "1.1.1",
       "1.2.0",
       "2.0.0",
       "2.1.0",
@@ -1230,66 +1194,51 @@
       "2.5.1",
       "2.5.2",
       "2.6.0",
-      "2.7.0",
       "3.0.0",
-      "3.1.0"
+      "4.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-apache-hdfs",
-    "stable-version": "3.1.0",
+    "package-name": "apache-airflow-providers-redis",
+    "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "2.0.0",
-      "2.1.0",
-      "2.1.1",
-      "2.2.0",
-      "2.2.1",
-      "2.2.2",
-      "2.2.3",
-      "3.0.0",
-      "3.0.1",
-      "3.1.0"
+      "2.0.1",
+      "2.0.2",
+      "2.0.3",
+      "2.0.4",
+      "3.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-google",
-    "stable-version": "8.3.0",
+    "package-name": "apache-airflow-providers-mysql",
+    "stable-version": "3.2.0",
     "all-versions": [
-      "0.0.1",
-      "0.0.2",
       "1.0.0",
+      "1.0.1",
+      "1.0.2",
+      "1.1.0",
       "2.0.0",
       "2.1.0",
+      "2.1.1",
       "2.2.0",
+      "2.2.1",
+      "2.2.2",
+      "2.2.3",
       "3.0.0",
-      "4.0.0",
-      "5.0.0",
-      "5.1.0",
-      "6.0.0",
-      "6.1.0",
-      "6.2.0",
-      "6.3.0",
-      "6.4.0",
-      "6.5.0",
-      "6.6.0",
-      "6.7.0",
-      "6.8.0",
-      "7.0.0",
-      "8.0.0",
-      "8.1.0",
-      "8.2.0",
-      "8.3.0"
+      "3.1.0",
+      "3.2.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-dingding",
+    "package-name": "apache-airflow-providers-grpc",
     "stable-version": "3.0.0",
     "all-versions": [
       "1.0.0",
       "1.0.1",
-      "1.0.2",
+      "1.1.0",
       "2.0.0",
       "2.0.1",
       "2.0.2",
@@ -1298,6 +1247,35 @@
       "3.0.0"
     ]
   },
+  {
+    "package-name": "apache-airflow-providers-arangodb",
+    "stable-version": "2.0.0",
+    "all-versions": [
+      "1.0.0",
+      "2.0.0"
+    ]
+  },
+  {
+    "package-name": "helm-chart",
+    "stable-version": "1.6.0",
+    "all-versions": [
+      "1.0.0",
+      "1.1.0",
+      "1.2.0",
+      "1.3.0",
+      "1.4.0",
+      "1.5.0",
+      "1.6.0"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-common-sql",
+    "stable-version": "1.1.0",
+    "all-versions": [
+      "1.0.0",
+      "1.1.0"
+    ]
+  },
   {
     "package-name": "apache-airflow-providers-apache-spark",
     "stable-version": "3.0.0",
@@ -1318,38 +1296,62 @@
     ]
   },
   {
-    "package-name": "apache-airflow-providers-tabular",
-    "stable-version": "1.0.1",
+    "package-name": "apache-airflow-providers-jira",
+    "stable-version": "3.0.1",
     "all-versions": [
       "1.0.0",
-      "1.0.1"
+      "1.0.1",
+      "1.0.2",
+      "2.0.0",
+      "2.0.1",
+      "2.0.2",
+      "2.0.3",
+      "2.0.4",
+      "2.0.5",
+      "3.0.0",
+      "3.0.1"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-celery",
-    "stable-version": "3.0.0",
+    "package-name": "apache-airflow-providers-odbc",
+    "stable-version": "3.1.1",
     "all-versions": [
       "1.0.0",
       "1.0.1",
       "2.0.0",
+      "2.0.1",
+      "2.0.2",
+      "2.0.3",
+      "2.0.4",
+      "3.0.0",
+      "3.1.0",
+      "3.1.1"
+    ]
+  },
+  {
+    "package-name": "apache-airflow-providers-exasol",
+    "stable-version": "4.0.0",
+    "all-versions": [
+      "1.0.0",
+      "1.1.0",
+      "1.1.1",
+      "2.0.0",
+      "2.0.1",
       "2.1.0",
       "2.1.1",
       "2.1.2",
       "2.1.3",
-      "2.1.4",
-      "3.0.0"
+      "3.0.0",
+      "3.1.0",
+      "4.0.0"
     ]
   },
   {
-    "package-name": "apache-airflow-providers-github",
-    "stable-version": "2.1.0",
+    "package-name": "apache-airflow-providers-tabular",
+    "stable-version": "1.0.1",
     "all-versions": [
       "1.0.0",
-      "1.0.1",
-      "1.0.2",
-      "1.0.3",
-      "2.0.0",
-      "2.1.0"
+      "1.0.1"
     ]
   }
 ]
\ No newline at end of file
diff --git a/blog/airflow-1.10.10/index.html b/blog/airflow-1.10.10/index.html
index 826178caa3..e78e5f116b 100644
--- a/blog/airflow-1.10.10/index.html
+++ b/blog/airflow-1.10.10/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow-1.10.10/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2020-04-09T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Apache Airflow 1.10.10">
 <meta itemprop="description" content="We are happy to present Apache Airflow 1.10.10"><meta itemprop="datePublished" content="2020-04-09T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="1143"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="release," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/airflow-1.10.12/index.html b/blog/airflow-1.10.12/index.html
index a271d59028..680ee2c76c 100644
--- a/blog/airflow-1.10.12/index.html
+++ b/blog/airflow-1.10.12/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow-1.10.12/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2020-08-25T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Apache Airflow 1.10.12">
 <meta itemprop="description" content="We are happy to present Apache Airflow 1.10.12"><meta itemprop="datePublished" content="2020-08-25T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="911"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="release," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/airflow-1.10.8-1.10.9/index.html b/blog/airflow-1.10.8-1.10.9/index.html
index 3bee2d810f..d1ea67a81d 100644
--- a/blog/airflow-1.10.8-1.10.9/index.html
+++ b/blog/airflow-1.10.8-1.10.9/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow-1.10.8-1.10.9/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2020-02-23T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Apache Airflow 1.10.8 &amp; 1.10.9">
 <meta itemprop="description" content="We are happy to present the new 1.10.8 and 1.10.9 releases of Apache Airflow."><meta itemprop="datePublished" content="2020-02-23T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="437"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="release," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/airflow-2.2.0/index.html b/blog/airflow-2.2.0/index.html
index 8e2a1dda85..599b02e8a0 100644
--- a/blog/airflow-2.2.0/index.html
+++ b/blog/airflow-2.2.0/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow-2.2.0/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2021-10-11T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="What&#39;s new in Apache Airflow 2.2.0">
 <meta itemprop="description" content="We&#39;re proud to announce that Apache Airflow 2.2.0 has been released."><meta itemprop="datePublished" content="2021-10-11T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="658"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Release," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/airflow-2.3.0/index.html b/blog/airflow-2.3.0/index.html
index d24d753499..abed94ef8a 100644
--- a/blog/airflow-2.3.0/index.html
+++ b/blog/airflow-2.3.0/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow-2.3.0/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2022-04-30T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Apache Airflow 2.3.0 is here">
 <meta itemprop="description" content="We&#39;re proud to announce that Apache Airflow 2.3.0 has been released."><meta itemprop="datePublished" content="2022-04-30T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="708"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Release," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/airflow-survey-2020/index.html b/blog/airflow-survey-2020/index.html
index 1032b09db1..d709525a2a 100644
--- a/blog/airflow-survey-2020/index.html
+++ b/blog/airflow-survey-2020/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow-survey-2020/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2021-03-09T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Airflow Survey 2020">
 <meta itemprop="description" content="We observe steady growth in number of users as well as in an amount of active contributors. So listening and understanding our community is of high importance."><meta itemprop="datePublished" content="2021-03-09T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="2136"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="community,survey,users," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/airflow-survey-2022/index.html b/blog/airflow-survey-2022/index.html
index 7581eb9938..c063af421a 100644
--- a/blog/airflow-survey-2022/index.html
+++ b/blog/airflow-survey-2022/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow-survey-2022/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2022-06-17T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Airflow Survey 2022">
 <meta itemprop="description" content="2021 saw rapid adoption of Airflow 2, and continued growth of the community. This annual survey helps us understand how people are using Airflow, and where we can best focus our efforts going forward."><meta itemprop="datePublished" content="2022-06-17T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="3865"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="community,survey,users," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/airflow-survey/index.html b/blog/airflow-survey/index.html
index d88b027d41..389101adcb 100644
--- a/blog/airflow-survey/index.html
+++ b/blog/airflow-survey/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow-survey/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2019-12-11T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Airflow Survey 2019">
 <meta itemprop="description" content="Receiving and adjusting to our users’ feedback is a must. Let’s see who Airflow users are, how they play with it, and what they miss."><meta itemprop="datePublished" content="2019-12-11T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="1775"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="community,survey,users," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/airflow-two-point-oh-is-here/index.html b/blog/airflow-two-point-oh-is-here/index.html
index 40d3680c46..9d4c66b3b0 100644
--- a/blog/airflow-two-point-oh-is-here/index.html
+++ b/blog/airflow-two-point-oh-is-here/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow-two-point-oh-is-here/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2020-12-17T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Apache Airflow 2.0 is here!">
 <meta itemprop="description" content="We&#39;re proud to announce that Apache Airflow 2.0.0 has been released."><meta itemprop="datePublished" content="2020-12-17T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="1165"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Release," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/airflow_summit_2021/index.html b/blog/airflow_summit_2021/index.html
index 3b60e2e806..2d88e7c3c3 100644
--- a/blog/airflow_summit_2021/index.html
+++ b/blog/airflow_summit_2021/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow_summit_2021/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2021-03-21T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Airflow Summit 2021">
 <meta itemprop="description" content="We are thrilled about Airflow Summit 2021!"><meta itemprop="datePublished" content="2021-03-21T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="77"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Community,Airflow Summit," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/airflow_summit_2022/index.html b/blog/airflow_summit_2022/index.html
index dca704eac1..3a4b491633 100644
--- a/blog/airflow_summit_2022/index.html
+++ b/blog/airflow_summit_2022/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/airflow_summit_2022/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2022-05-16T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Airflow Summit 2022">
 <meta itemprop="description" content="Airflow Summit 2022 is here"><meta itemprop="datePublished" content="2022-05-16T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="129"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Community,Airflow Summit," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/announcing-new-website/index.html b/blog/announcing-new-website/index.html
index e20fac1974..e6766cdf9b 100644
--- a/blog/announcing-new-website/index.html
+++ b/blog/announcing-new-website/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/announcing-new-website/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2019-12-11T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="New Airflow website">
 <meta itemprop="description" content="We are thrilled about our new website!"><meta itemprop="datePublished" content="2019-12-11T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="282"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Community," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/apache-airflow-for-newcomers/index.html b/blog/apache-airflow-for-newcomers/index.html
index 0dbdb0dea7..0156915ab6 100644
--- a/blog/apache-airflow-for-newcomers/index.html
+++ b/blog/apache-airflow-for-newcomers/index.html
@@ -35,12 +35,12 @@ Authoring Workflow in Apache Airflow. Airflow makes it easy to author workflows
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/apache-airflow-for-newcomers/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2020-08-17T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Apache Airflow For Newcomers">
 <meta itemprop="description" content="Apache Airflow is a platform to programmatically author, schedule, and monitor workflows. A workflow is a sequence of tasks that processes a set of data. You can think of workflow as the path that describes how tasks go from being undone to done. Scheduling, on the other hand, is the process of planning, controlling, and optimizing when a particular task should be done.
 Authoring Workflow in Apache Airflow. Airflow makes it easy to author workflows using python scripts."><meta itemprop="datePublished" content="2020-08-17T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="1070"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Community," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/apache-con-europe-2019-thoughts-and-insights-by-airflow-committers/index.html b/blog/apache-con-europe-2019-thoughts-and-insights-by-airflow-committers/index.html
index 84b12bf4f8..d83ba4da26 100644
--- a/blog/apache-con-europe-2019-thoughts-and-insights-by-airflow-committers/index.html
+++ b/blog/apache-con-europe-2019-thoughts-and-insights-by-airflow-committers/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/apache-con-europe-2019-thoughts-and-insights-by-airflow-committers/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2019-11-22T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="ApacheCon Europe 2019 — Thoughts and Insights by Airflow Committers">
 <meta itemprop="description" content="Here come some thoughts by Airflow committers and contributors from the ApacheCon Europe 2019. Get to know the ASF community!"><meta itemprop="datePublished" content="2019-11-22T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="138"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Community," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/documenting-using-local-development-environments/index.html b/blog/documenting-using-local-development-environments/index.html
index b85519d1e4..0d0a302572 100644
--- a/blog/documenting-using-local-development-environments/index.html
+++ b/blog/documenting-using-local-development-environments/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/documenting-using-local-development-environments/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2019-11-22T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Documenting using local development environment">
 <meta itemprop="description" content="The story behind documenting local development environment of Apache Airflow"><meta itemprop="datePublished" content="2019-11-22T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="256"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Development," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/experience-in-google-season-of-docs-2019-with-apache-airflow/index.html b/blog/experience-in-google-season-of-docs-2019-with-apache-airflow/index.html
index 875725b581..098e898aa0 100644
--- a/blog/experience-in-google-season-of-docs-2019-with-apache-airflow/index.html
+++ b/blog/experience-in-google-season-of-docs-2019-with-apache-airflow/index.html
@@ -35,12 +35,12 @@ About Me I have been writing tech articles on medium as well as my blog for the
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/experience-in-google-season-of-docs-2019-with-apache-airflow/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2019-12-20T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Experience in Google Season of Docs 2019 with Apache Airflow">
 <meta itemprop="description" content="I came across Google Season of Docs (GSoD) almost by accident, thanks to my extensive HackerNews and Twitter addiction. I was familiar with the Google Summer of Code but not with this program. It turns out it was the inaugural phase. I read the details, and the process felt a lot like GSoC except that this was about documentation.
 About Me I have been writing tech articles on medium as well as my blog for the past 1."><meta itemprop="datePublished" content="2019-12-20T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="1521"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Documentation," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/experience-with-airflow-as-an-outreachy-intern/index.html b/blog/experience-with-airflow-as-an-outreachy-intern/index.html
index d7d23ae819..5c6a8803e2 100644
--- a/blog/experience-with-airflow-as-an-outreachy-intern/index.html
+++ b/blog/experience-with-airflow-as-an-outreachy-intern/index.html
@@ -35,12 +35,12 @@ Contribution Period The first thing I had to do was choose a project under an or
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/experience-with-airflow-as-an-outreachy-intern/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2020-08-30T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Journey with Airflow as an Outreachy Intern">
 <meta itemprop="description" content="Outreachy is a program which organises three months paid internships with FOSS projects for people who are typically underrepresented in those projects.
 Contribution Period The first thing I had to do was choose a project under an organisation. After going through all the projects I chose “Extending the REST API of Apache Airflow”, because I had a good idea of what REST API(s) are, so I thought it would be easier to get started with the contributions."><meta itemprop="datePublished" content="2020-08-30T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="528"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Community," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/implementing-stable-api-for-apache-airflow/index.html b/blog/implementing-stable-api-for-apache-airflow/index.html
index 9618b97b05..cf81c23ee3 100644
--- a/blog/implementing-stable-api-for-apache-airflow/index.html
+++ b/blog/implementing-stable-api-for-apache-airflow/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/implementing-stable-api-for-apache-airflow/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2020-07-19T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="Implementing Stable API for Apache Airflow">
 <meta itemprop="description" content="An Outreachy intern&#39;s progress report on contributing to Apache Airflow REST API."><meta itemprop="datePublished" content="2020-07-19T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="703"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="REST API," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/blog/its-a-breeze-to-develop-apache-airflow/index.html b/blog/its-a-breeze-to-develop-apache-airflow/index.html
index f1c4c6ea49..ed380d7ef1 100644
--- a/blog/its-a-breeze-to-develop-apache-airflow/index.html
+++ b/blog/its-a-breeze-to-develop-apache-airflow/index.html
@@ -34,11 +34,11 @@
 <meta property="og:type" content="article" />
 <meta property="og:url" content="/blog/its-a-breeze-to-develop-apache-airflow/" /><meta property="og:image" content="/images/feature-image.png"/><meta property="article:section" content="blog" />
 <meta property="article:published_time" content="2019-11-22T00:00:00+00:00" />
-<meta property="article:modified_time" content="2022-08-14T17:53:13+02:00" /><meta property="og:site_name" content="Apache Airflow" />
+<meta property="article:modified_time" content="2022-08-18T12:07:33+02:00" /><meta property="og:site_name" content="Apache Airflow" />
 
 <meta itemprop="name" content="It&#39;s a &#34;Breeze&#34; to develop Apache Airflow">
 <meta itemprop="description" content="A Principal Software Engineer&#39;s journey to developer productivity. Learn how Jarek and his team sped up and simplified Airflow development for the community."><meta itemprop="datePublished" content="2019-11-22T00:00:00+00:00" />
-<meta itemprop="dateModified" content="2022-08-14T17:53:13+02:00" />
+<meta itemprop="dateModified" content="2022-08-18T12:07:33+02:00" />
 <meta itemprop="wordCount" content="124"><meta itemprop="image" content="/images/feature-image.png"/>
 <meta itemprop="keywords" content="Development," /><meta name="twitter:card" content="summary_large_image"/>
 <meta name="twitter:image" content="/images/feature-image.png"/>
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/.buildinfo b/docs/apache-airflow-providers-common-sql/1.1.0/.buildinfo
new file mode 100644
index 0000000000..93914ae43f
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/.buildinfo
@@ -0,0 +1,4 @@
+# Sphinx build info version 1
+# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done.
+config: 7adb4ca4416c1d52541eb68f18e606a0
+tags: 645f666f9bcd5a90fca523b33c5a78b7
diff --git a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/hooks/index.html b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/hooks/index.html
similarity index 99%
copy from docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/hooks/index.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/hooks/index.html
index 165a490706..e1d8cdc985 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/hooks/index.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/hooks/index.html
@@ -284,7 +284,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -426,7 +426,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -847,5 +847,6 @@
         <script src="../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/hooks/sql/index.html b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/hooks/sql/index.html
similarity index 85%
copy from docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/hooks/sql/index.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/hooks/sql/index.html
index 0f46cbc3f3..831afcd48a 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/hooks/sql/index.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/hooks/sql/index.html
@@ -284,7 +284,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -426,7 +426,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -610,6 +610,42 @@
 </tr>
 </tbody>
 </table>
+</div>
+<div class="section" id="functions">
+<h3>Functions<a class="headerlink" href="#functions" title="Permalink to this heading">¶</a></h3>
+<table class="autosummary longtable docutils align-default">
+<colgroup>
+<col style="width: 10%" />
+<col style="width: 90%" />
+</colgroup>
+<tbody>
+<tr class="row-odd"><td><p><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.fetch_all_handler" title="airflow.providers.common.sql.hooks.sql.fetch_all_handler"><code class="xref py py-obj docutils literal notranslate"><span class="pre">fetch_all_handler</span></code></a>(cursor)</p></td>
+<td><p>Handler for DbApiHook.run() to return results</p></td>
+</tr>
+</tbody>
+</table>
+</div>
+<div class="section" id="attributes">
+<h3>Attributes<a class="headerlink" href="#attributes" title="Permalink to this heading">¶</a></h3>
+<table class="autosummary longtable docutils align-default">
+<colgroup>
+<col style="width: 10%" />
+<col style="width: 90%" />
+</colgroup>
+<tbody>
+<tr class="row-odd"><td><p><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.BaseForDbApiHook" title="airflow.providers.common.sql.hooks.sql.BaseForDbApiHook"><code class="xref py py-obj docutils literal notranslate"><span class="pre">BaseForDbApiHook</span></code></a></p></td>
+<td><p></p></td>
+</tr>
+</tbody>
+</table>
+<dl class="py function">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.fetch_all_handler">
+<span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.hooks.sql.</span></span><span class="sig-name descname"><span class="pre">fetch_all_handler</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">cursor</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#fetch_all_handler"><span class="viewcode-link [...]
+<dd><p>Handler for DbApiHook.run() to return results</p>
+<dl class="field-list simple">
+</dl>
+</dd></dl>
+
 <dl class="py class">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.ConnectorProtocol">
 <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.hooks.sql.</span></span><span class="sig-name descname"><span class="pre">ConnectorProtocol</span></span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#ConnectorProtocol"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlin [...]
@@ -617,7 +653,7 @@
 <p>A protocol where you can connect to a database.</p>
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.ConnectorProtocol.connect">
-<span class="sig-name descname"><span class="pre">connect</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">host</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">port</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">username</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">schem [...]
+<span class="sig-name descname"><span class="pre">connect</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">host</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">port</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">username</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">schema</span></span></em><span class="sig-paren">)</span><a class="reference internal" [...]
 <dd><p>Connect to a database.</p>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
@@ -639,10 +675,15 @@
 
 </dd></dl>
 
+<dl class="py data">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.BaseForDbApiHook">
+<span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.hooks.sql.</span></span><span class="sig-name descname"><span class="pre">BaseForDbApiHook</span></span><em class="property"><span class="w"> </span><span class="pre">:Type[airflow.hooks.base.BaseHook]</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#BaseForDbApiHook"><span class="viewcode-link"><span class="pre">[source]</span></s [...]
+<dd></dd></dl>
+
 <dl class="py class">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook">
 <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.hooks.sql.</span></span><span class="sig-name descname"><span class="pre">DbApiHook</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">schema</sp [...]
-<dd><p>Bases: <a class="reference external" href="/docs/apache-airflow/stable/_api/airflow/hooks/base/index.html#airflow.hooks.base.BaseHook" title="(in apache-airflow v2.4.0.dev0)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">airflow.hooks.base.BaseHook</span></code></a></p>
+<dd><p>Bases: <code class="xref py py-obj docutils literal notranslate"><span class="pre">airflow.hooks.dbapi.DbApiHook</span></code></p>
 <p>Abstract base class for sql hooks.</p>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
@@ -676,13 +717,13 @@ should be done before calling the <code class="docutils literal notranslate"><sp
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.get_conn">
-<span class="sig-name descname"><span class="pre">get_conn</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.get_conn"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.hooks.sql.DbApiHo [...]
+<span class="sig-name descname"><span class="pre">get_conn</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.get_conn"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.get_conn" title="Permalink to this definition">¶</a></dt>
 <dd><p>Returns a connection object</p>
 </dd></dl>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.get_uri">
-<span class="sig-name descname"><span class="pre">get_uri</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.get_uri"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.hooks.sql.DbApiHook [...]
+<span class="sig-name descname"><span class="pre">get_uri</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.get_uri"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.get_uri" title="Permalink to this definition">¶</a></dt>
 <dd><p>Extract the URI from the connection.</p>
 <dl class="field-list simple">
 <dt class="field-odd">Returns</dt>
@@ -696,7 +737,7 @@ should be done before calling the <code class="docutils literal notranslate"><sp
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.get_sqlalchemy_engine">
-<span class="sig-name descname"><span class="pre">get_sqlalchemy_engine</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">engine_kwargs</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_mod [...]
+<span class="sig-name descname"><span class="pre">get_sqlalchemy_engine</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">engine_kwargs</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.get_sqlalchemy_engine" [...]
 <dd><p>Get an sqlalchemy_engine object.</p>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
@@ -710,7 +751,7 @@ should be done before calling the <code class="docutils literal notranslate"><sp
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.get_pandas_df">
-<span class="sig-name descname"><span class="pre">get_pandas_df</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">parameters</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"> [...]
+<span class="sig-name descname"><span class="pre">get_pandas_df</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">parameters</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pr [...]
 <dd><p>Executes the sql and returns a pandas dataframe</p>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
@@ -726,7 +767,7 @@ sql statements to execute</p></li>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.get_pandas_df_by_chunks">
-<span class="sig-name descname"><span class="pre">get_pandas_df_by_chunks</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">parameters</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="s [...]
+<span class="sig-name descname"><span class="pre">get_pandas_df_by_chunks</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">parameters</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig- [...]
 <dd><p>Executes the sql and returns a generator</p>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
@@ -743,14 +784,14 @@ sql statements to execute</p></li>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.get_records">
-<span class="sig-name descname"><span class="pre">get_records</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">parameters</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)< [...]
+<span class="sig-name descname"><span class="pre">get_records</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">parameters</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre" [...]
 <dd><p>Executes the sql and returns a set of records.</p>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
 <dd class="field-odd"><ul class="simple">
-<li><p><strong>sql</strong> – the sql statement to be executed (str) or a list of
+<li><p><strong>sql</strong> (<em>Union</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>, </em><em>List</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em><em>]</em>) – the sql statement to be executed (str) or a list of
 sql statements to execute</p></li>
-<li><p><strong>parameters</strong> – The parameters to render the SQL query with.</p></li>
+<li><p><strong>parameters</strong> (<em>Optional</em><em>[</em><em>Union</em><em>[</em><em>Iterable</em><em>, </em><em>Mapping</em><em>]</em><em>]</em>) – The parameters to render the SQL query with.</p></li>
 </ul>
 </dd>
 </dl>
@@ -758,12 +799,12 @@ sql statements to execute</p></li>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.get_first">
-<span class="sig-name descname"><span class="pre">get_first</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">parameters</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</s [...]
+<span class="sig-name descname"><span class="pre">get_first</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">parameters</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/pro [...]
 <dd><p>Executes the sql and returns the first resulting row.</p>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
 <dd class="field-odd"><ul class="simple">
-<li><p><strong>sql</strong> – the sql statement to be executed (str) or a list of
+<li><p><strong>sql</strong> (<em>Union</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>, </em><em>List</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em><em>]</em>) – the sql statement to be executed (str) or a list of
 sql statements to execute</p></li>
 <li><p><strong>parameters</strong> – The parameters to render the SQL query with.</p></li>
 </ul>
@@ -771,38 +812,67 @@ sql statements to execute</p></li>
 </dl>
 </dd></dl>
 
+<dl class="py method">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.strip_sql_string">
+<em class="property"><span class="pre">static</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">strip_sql_string</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">sql</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.strip_sql_string"><span class="viewcode-link"><span class="pre">[sour [...]
+<dd><dl class="field-list simple">
+</dl>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.split_sql_string">
+<em class="property"><span class="pre">static</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">split_sql_string</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">sql</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.split_sql_string"><span class="viewcode-link"><span class="pre">[sour [...]
+<dd><p>Splits string into multiple SQL expressions</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters</dt>
+<dd class="field-odd"><p><strong>sql</strong> (<a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a>) – SQL string potentially consisting of multiple expressions</p>
+</dd>
+<dt class="field-even">Returns</dt>
+<dd class="field-even"><p>list of individual expressions</p>
+</dd>
+<dt class="field-odd">Return type</dt>
+<dd class="field-odd"><p>List[<a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)">str</a>]</p>
+</dd>
+</dl>
+</dd></dl>
+
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.run">
-<span class="sig-name descname"><span class="pre">run</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">autocommit</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">False</span></span></em>, <em class="sig-param"><span cla [...]
+<span class="sig-name descname"><span class="pre">run</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">autocommit</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">False</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">parameters</span></span><span class="o"><span class="pre [...]
 <dd><p>Runs a command or a list of commands. Pass a list of sql
 statements to the sql parameter to get them to execute
 sequentially</p>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
 <dd class="field-odd"><ul class="simple">
-<li><p><strong>sql</strong> – the sql statement to be executed (str) or a list of
+<li><p><strong>sql</strong> (<em>Union</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>, </em><em>Iterable</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em><em>]</em>) – the sql statement to be executed (str) or a list of
 sql statements to execute</p></li>
-<li><p><strong>autocommit</strong> – What to set the connection’s autocommit setting to
+<li><p><strong>autocommit</strong> (<a class="reference external" href="https://docs.python.org/3/library/functions.html#bool" title="(in Python v3.10)"><em>bool</em></a>) – What to set the connection’s autocommit setting to
 before executing the query.</p></li>
-<li><p><strong>parameters</strong> – The parameters to render the SQL query with.</p></li>
-<li><p><strong>handler</strong> – The result handler which is called with the result of each statement.</p></li>
+<li><p><strong>parameters</strong> (<em>Optional</em><em>[</em><em>Union</em><em>[</em><em>Iterable</em><em>, </em><em>Mapping</em><em>]</em><em>]</em>) – The parameters to render the SQL query with.</p></li>
+<li><p><strong>handler</strong> (<em>Optional</em><em>[</em><em>Callable</em><em>]</em>) – The result handler which is called with the result of each statement.</p></li>
+<li><p><strong>split_statements</strong> (<a class="reference external" href="https://docs.python.org/3/library/functions.html#bool" title="(in Python v3.10)"><em>bool</em></a>) – Whether to split a single SQL string into statements and run separately</p></li>
+<li><p><strong>return_last</strong> (<a class="reference external" href="https://docs.python.org/3/library/functions.html#bool" title="(in Python v3.10)"><em>bool</em></a>) – Whether to return result for only last statement or for all after split</p></li>
 </ul>
 </dd>
 <dt class="field-even">Returns</dt>
-<dd class="field-even"><p>query results if handler was provided.</p>
+<dd class="field-even"><p>return only result of the ALL SQL expressions if handler was provided.</p>
+</dd>
+<dt class="field-odd">Return type</dt>
+<dd class="field-odd"><p>Optional[Union[Any, List[Any]]]</p>
 </dd>
 </dl>
 </dd></dl>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.set_autocommit">
-<span class="sig-name descname"><span class="pre">set_autocommit</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">conn</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">autocommit</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sq [...]
+<span class="sig-name descname"><span class="pre">set_autocommit</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">conn</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">autocommit</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.set_autocommit"><span class="viewcode-link"><span class="pre">[s [...]
 <dd><p>Sets the autocommit flag on the connection</p>
 </dd></dl>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.get_autocommit">
-<span class="sig-name descname"><span class="pre">get_autocommit</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">conn</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.get_autocommit"><span class="viewcode-link"><span class="pre">[source] [...]
+<span class="sig-name descname"><span class="pre">get_autocommit</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">conn</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.get_autocommit"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.hooks [...]
 <dd><p>Get autocommit setting for the provided connection.
 Return True if conn.autocommit is set to True.
 Return False if conn.autocommit is not set or set to False or conn
@@ -822,13 +892,13 @@ does not support autocommit.</p>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.get_cursor">
-<span class="sig-name descname"><span class="pre">get_cursor</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.get_cursor"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.hooks.sql.DbA [...]
+<span class="sig-name descname"><span class="pre">get_cursor</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.get_cursor"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.get_cursor" title="Permalink to this definition">¶</a></dt>
 <dd><p>Returns a cursor</p>
 </dd></dl>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.insert_rows">
-<span class="sig-name descname"><span class="pre">insert_rows</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">rows</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">target_fields</span></span><span class="o"><span class="pre">=</span></span><span cla [...]
+<span class="sig-name descname"><span class="pre">insert_rows</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">rows</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">target_fields</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-para [...]
 <dd><p>A generic way to insert a set of tuples into a table,
 a new transaction is created every commit_every rows</p>
 <dl class="field-list simple">
@@ -847,7 +917,7 @@ transaction. Set to 0 to insert all rows in one transaction.</p></li>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.bulk_dump">
-<em class="property"><span class="pre">abstract</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">bulk_dump</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">tmp_file</span></span></em><span class="sig-paren">)</span><a class="reference intern [...]
+<em class="property"><span class="pre">abstract</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">bulk_dump</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">tmp_file</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.ht [...]
 <dd><p>Dumps a database table into a tab-delimited file</p>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
@@ -861,7 +931,7 @@ transaction. Set to 0 to insert all rows in one transaction.</p></li>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.bulk_load">
-<em class="property"><span class="pre">abstract</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">bulk_load</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">tmp_file</span></span></em><span class="sig-paren">)</span><a class="reference intern [...]
+<em class="property"><span class="pre">abstract</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">bulk_load</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">tmp_file</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.ht [...]
 <dd><p>Loads a tab-delimited file into a database table</p>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
@@ -875,7 +945,7 @@ transaction. Set to 0 to insert all rows in one transaction.</p></li>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.hooks.sql.DbApiHook.test_connection">
-<span class="sig-name descname"><span class="pre">test_connection</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.test_connection"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.hoo [...]
+<span class="sig-name descname"><span class="pre">test_connection</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/hooks/sql.html#DbApiHook.test_connection"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.test_connection" title="Permalink to this definition">¶</a></dt>
 <dd><p>Tests the connection using db-specific query</p>
 </dd></dl>
 
@@ -962,11 +1032,15 @@ transaction. Set to 0 to insert all rows in one transaction.</p></li>
             <ul>
 <li><a class="reference internal" href="#"><code class="xref py py-mod docutils literal notranslate"><span class="pre">airflow.providers.common.sql.hooks.sql</span></code></a><ul>
 <li><a class="reference internal" href="#module-contents">Module Contents</a><ul>
-<li><a class="reference internal" href="#classes">Classes</a><ul>
+<li><a class="reference internal" href="#classes">Classes</a></li>
+<li><a class="reference internal" href="#functions">Functions</a></li>
+<li><a class="reference internal" href="#attributes">Attributes</a><ul>
+<li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.fetch_all_handler">fetch_all_handler</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.ConnectorProtocol">ConnectorProtocol</a><ul>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.ConnectorProtocol.connect">connect</a></li>
 </ul>
 </li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.BaseForDbApiHook">BaseForDbApiHook</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook">DbApiHook</a><ul>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.conn_name_attr">conn_name_attr</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.default_conn_name">default_conn_name</a></li>
@@ -979,6 +1053,8 @@ transaction. Set to 0 to insert all rows in one transaction.</p></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.get_pandas_df_by_chunks">get_pandas_df_by_chunks</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.get_records">get_records</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.get_first">get_first</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.strip_sql_string">strip_sql_string</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.split_sql_string">split_sql_string</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.run">run</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.set_autocommit">set_autocommit</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.hooks.sql.DbApiHook.get_autocommit">get_autocommit</a></li>
@@ -1163,5 +1239,6 @@ transaction. Set to 0 to insert all rows in one transaction.</p></li>
         <script src="../../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/index.html b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/index.html
similarity index 99%
copy from docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/index.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/index.html
index 868dfbaf56..2853fe4328 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/index.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/index.html
@@ -284,7 +284,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -426,7 +426,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -856,5 +856,6 @@
         <script src="../../../../../_static/doctools.js"></script>
         <script src="../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/operators/index.html b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/operators/index.html
similarity index 99%
copy from docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/operators/index.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/operators/index.html
index c5674b0510..bdad218f76 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/operators/index.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/operators/index.html
@@ -284,7 +284,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -426,7 +426,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -847,5 +847,6 @@
         <script src="../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/operators/sql/index.html b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/operators/sql/index.html
similarity index 62%
copy from docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/operators/sql/index.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/operators/sql/index.html
index dceee992f7..9741f07fa5 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/operators/sql/index.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/operators/sql/index.html
@@ -284,7 +284,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -426,7 +426,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -602,12 +602,30 @@
 <col style="width: 90%" />
 </colgroup>
 <tbody>
-<tr class="row-odd"><td><p><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator" title="airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">SQLColumnCheckOperator</span></code></a></p></td>
+<tr class="row-odd"><td><p><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator" title="airflow.providers.common.sql.operators.sql.BaseSQLOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">BaseSQLOperator</span></code></a></p></td>
+<td><p>This is a base class for generic SQL Operator to get a DB Hook</p></td>
+</tr>
+<tr class="row-even"><td><p><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator" title="airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">SQLColumnCheckOperator</span></code></a></p></td>
 <td><p>Performs one or more of the templated checks in the column_checks dictionary.</p></td>
 </tr>
-<tr class="row-even"><td><p><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator" title="airflow.providers.common.sql.operators.sql.SQLTableCheckOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">SQLTableCheckOperator</span></code></a></p></td>
+<tr class="row-odd"><td><p><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator" title="airflow.providers.common.sql.operators.sql.SQLTableCheckOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">SQLTableCheckOperator</span></code></a></p></td>
 <td><p>Performs one or more of the checks provided in the checks dictionary.</p></td>
 </tr>
+<tr class="row-even"><td><p><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLCheckOperator" title="airflow.providers.common.sql.operators.sql.SQLCheckOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">SQLCheckOperator</span></code></a></p></td>
+<td><p>Performs checks against a db. The <code class="docutils literal notranslate"><span class="pre">SQLCheckOperator</span></code> expects</p></td>
+</tr>
+<tr class="row-odd"><td><p><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator" title="airflow.providers.common.sql.operators.sql.SQLValueCheckOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">SQLValueCheckOperator</span></code></a></p></td>
+<td><p>Performs a simple value check using sql code.</p></td>
+</tr>
+<tr class="row-even"><td><p><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator" title="airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">SQLIntervalCheckOperator</span></code></a></p></td>
+<td><p>Checks that the values of metrics given as SQL expressions are within</p></td>
+</tr>
+<tr class="row-odd"><td><p><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator" title="airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">SQLThresholdCheckOperator</span></code></a></p></td>
+<td><p>Performs a value check using sql code against a minimum threshold</p></td>
+</tr>
+<tr class="row-even"><td><p><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator" title="airflow.providers.common.sql.operators.sql.BranchSQLOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">BranchSQLOperator</span></code></a></p></td>
+<td><p>Allows a DAG to &quot;branch&quot; or follow a specified path based on the results of a SQL query.</p></td>
+</tr>
 </tbody>
 </table>
 </div>
@@ -633,10 +651,36 @@
 </dl>
 </dd></dl>
 
+<dl class="py class">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.BaseSQLOperator">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.operators.sql.</span></span><span class="sig-name descname"><span class="pre">BaseSQLOperator</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">conn_id</span></span><span class="o"><span class="pr [...]
+<dd><p>Bases: <code class="xref py py-obj docutils literal notranslate"><span class="pre">airflow.models.BaseOperator</span></code></p>
+<p>This is a base class for generic SQL Operator to get a DB Hook</p>
+<p>The provided method is .get_db_hook(). The default behavior will try to
+retrieve the DB hook based on connection type.
+You can custom the behavior by overriding the .get_db_hook() method.</p>
+<dl class="field-list simple">
+</dl>
+<dl class="py method">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.BaseSQLOperator.get_db_hook">
+<span class="sig-name descname"><span class="pre">get_db_hook</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#BaseSQLOperator.get_db_hook"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator.get_db_hook" title="Permalink to this definition"> [...]
+<dd><p>Get the database hook for the connection.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Returns</dt>
+<dd class="field-odd"><p>the database hook object.</p>
+</dd>
+<dt class="field-even">Return type</dt>
+<dd class="field-even"><p><a class="reference internal" href="../../hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook" title="airflow.providers.common.sql.hooks.sql.DbApiHook">DbApiHook</a></p>
+</dd>
+</dl>
+</dd></dl>
+
+</dd></dl>
+
 <dl class="py class">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator">
-<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.operators.sql.</span></span><span class="sig-name descname"><span class="pre">SQLColumnCheckOperator</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-para [...]
-<dd><p>Bases: <a class="reference external" href="/docs/apache-airflow/stable/_api/airflow/operators/sql/index.html#airflow.operators.sql.BaseSQLOperator" title="(in apache-airflow v2.4.0.dev0)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">airflow.operators.sql.BaseSQLOperator</span></code></a></p>
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.operators.sql.</span></span><span class="sig-name descname"><span class="pre">SQLColumnCheckOperator</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-para [...]
+<dd><p>Bases: <a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator" title="airflow.providers.common.sql.operators.sql.BaseSQLOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">BaseSQLOperator</span></code></a></p>
 <p>Performs one or more of the templated checks in the column_checks dictionary.
 Checks are performed on a per-column basis specified by the column_mapping.
 Each check can take one or more of the following options:
@@ -671,6 +715,15 @@ Each check can take one or more of the following options:
 </div>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
+<dd class="field-odd"><p><strong>partition_clause</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – a partial SQL statement that is added to a WHERE clause in the query built by
+the operator that creates partition_clauses for the checks to run on, e.g.</p>
+</dd>
+</dl>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="s2">&quot;date = &#39;1970-01-01&#39;&quot;</span>
+</pre></div>
+</div>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters</dt>
 <dd class="field-odd"><ul class="simple">
 <li><p><strong>conn_id</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – the connection ID used to connect to the database</p></li>
 <li><p><strong>database</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – name of database which overwrite the defined one in connection</p></li>
@@ -682,6 +735,11 @@ Each check can take one or more of the following options:
 <p>For more information on how to use this operator, take a look at the guide:
 <a class="reference internal" href="../../../../../../../operators.html#howto-operator-sqlcolumncheckoperator"><span class="std std-ref">Check SQL Table Columns</span></a></p>
 </div>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.template_fields">
+<span class="sig-name descname"><span class="pre">template_fields</span></span><em class="property"><span class="w"> </span><span class="pre">=</span> <span class="pre">['partition_clause']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLColumnCheckOperator.template_fields"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operato [...]
+<dd></dd></dl>
+
 <dl class="py attribute">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.column_checks">
 <span class="sig-name descname"><span class="pre">column_checks</span></span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLColumnCheckOperator.column_checks"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.column_checks" title="Permalink to this definition">¶</a></dt>
@@ -689,18 +747,20 @@ Each check can take one or more of the following options:
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.execute">
-<span class="sig-name descname"><span class="pre">execute</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">context</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/provide [...]
+<span class="sig-name descname"><span class="pre">execute</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">context</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLColumnCheckOperator.execute"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql [...]
 <dd><p>This is the main method to derive when creating an operator.
 Context is the same dictionary used as when rendering jinja templates.</p>
 <p>Refer to get_template_context for more context.</p>
+<dl class="field-list simple">
+</dl>
 </dd></dl>
 
 </dd></dl>
 
 <dl class="py class">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLTableCheckOperator">
-<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.operators.sql.</span></span><span class="sig-name descname"><span class="pre">SQLTableCheckOperator</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-param [...]
-<dd><p>Bases: <a class="reference external" href="/docs/apache-airflow/stable/_api/airflow/operators/sql/index.html#airflow.operators.sql.BaseSQLOperator" title="(in apache-airflow v2.4.0.dev0)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">airflow.operators.sql.BaseSQLOperator</span></code></a></p>
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.operators.sql.</span></span><span class="sig-name descname"><span class="pre">SQLTableCheckOperator</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-param [...]
+<dd><p>Bases: <a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator" title="airflow.providers.common.sql.operators.sql.BaseSQLOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">BaseSQLOperator</span></code></a></p>
 <p>Performs one or more of the checks provided in the checks dictionary.
 Checks should be written to return a boolean result.</p>
 <dl class="field-list simple">
@@ -719,6 +779,15 @@ Checks should be written to return a boolean result.</p>
 </div>
 <dl class="field-list simple">
 <dt class="field-odd">Parameters</dt>
+<dd class="field-odd"><p><strong>partition_clause</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – a partial SQL statement that is added to a WHERE clause in the query built by
+the operator that creates partition_clauses for the checks to run on, e.g.</p>
+</dd>
+</dl>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="s2">&quot;date = &#39;1970-01-01&#39;&quot;</span>
+</pre></div>
+</div>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters</dt>
 <dd class="field-odd"><ul class="simple">
 <li><p><strong>conn_id</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – the connection ID used to connect to the database</p></li>
 <li><p><strong>database</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – name of database which overwrite the defined one in connection</p></li>
@@ -730,22 +799,327 @@ Checks should be written to return a boolean result.</p>
 <p>For more information on how to use this operator, take a look at the guide:
 <a class="reference internal" href="../../../../../../../operators.html#howto-operator-sqltablecheckoperator"><span class="std std-ref">Check SQL Table Values</span></a></p>
 </div>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.template_fields">
+<span class="sig-name descname"><span class="pre">template_fields</span></span><em class="property"><span class="w"> </span><span class="pre">=</span> <span class="pre">['partition_clause']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLTableCheckOperator.template_fields"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operator [...]
+<dd></dd></dl>
+
 <dl class="py attribute">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.sql_check_template">
-<span class="sig-name descname"><span class="pre">sql_check_template</span></span><em class="property"><span class="w"> </span><span class="pre">=</span> <span class="pre">CASE</span> <span class="pre">WHEN</span> <span class="pre">check_statement</span> <span class="pre">THEN</span> <span class="pre">1</span> <span class="pre">ELSE</span> <span class="pre">0</span> <span class="pre">END</span> <span class="pre">AS</span> <span class="pre">check_name</span></em><a class="reference intern [...]
+<span class="sig-name descname"><span class="pre">sql_check_template</span></span><em class="property"><span class="w"> </span><span class="pre">=</span> <span class="pre">Multiline-String</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLTableCheckOperator.sql_check_template"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operat [...]
+<dd><blockquote>
+<div><details><summary>Show Value</summary><div class="highlight-text notranslate"><div class="highlight"><pre><span></span><span class="linenos">1</span>        SELECT &#39;_check_name&#39; AS check_name, MIN(_check_name) AS check_result
+<span class="linenos">2</span>        FROM(SELECT CASE WHEN check_statement THEN 1 ELSE 0 END AS _check_name FROM table)
+</pre></div>
+</div>
+</details></div></blockquote>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.execute">
+<span class="sig-name descname"><span class="pre">execute</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">context</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLTableCheckOperator.execute"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql. [...]
+<dd><p>This is the main method to derive when creating an operator.
+Context is the same dictionary used as when rendering jinja templates.</p>
+<p>Refer to get_template_context for more context.</p>
+<dl class="field-list simple">
+</dl>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLCheckOperator">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.operators.sql.</span></span><span class="sig-name descname"><span class="pre">SQLCheckOperator</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><span [...]
+<dd><p>Bases: <a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator" title="airflow.providers.common.sql.operators.sql.BaseSQLOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">BaseSQLOperator</span></code></a></p>
+<p>Performs checks against a db. The <code class="docutils literal notranslate"><span class="pre">SQLCheckOperator</span></code> expects
+a sql query that will return a single row. Each value on that
+first row is evaluated using python <code class="docutils literal notranslate"><span class="pre">bool</span></code> casting. If any of the
+values return <code class="docutils literal notranslate"><span class="pre">False</span></code> the check is failed and errors out.</p>
+<p>Note that Python bool casting evals the following as <code class="docutils literal notranslate"><span class="pre">False</span></code>:</p>
+<ul class="simple">
+<li><p><code class="docutils literal notranslate"><span class="pre">False</span></code></p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">0</span></code></p></li>
+<li><p>Empty string (<code class="docutils literal notranslate"><span class="pre">&quot;&quot;</span></code>)</p></li>
+<li><p>Empty list (<code class="docutils literal notranslate"><span class="pre">[]</span></code>)</p></li>
+<li><p>Empty dictionary or set (<code class="docutils literal notranslate"><span class="pre">{}</span></code>)</p></li>
+</ul>
+<p>Given a query like <code class="docutils literal notranslate"><span class="pre">SELECT</span> <span class="pre">COUNT(*)</span> <span class="pre">FROM</span> <span class="pre">foo</span></code>, it will fail only if
+the count <code class="docutils literal notranslate"><span class="pre">==</span> <span class="pre">0</span></code>. You can craft much more complex query that could,
+for instance, check that the table has the same number of rows as
+the source table upstream, or that the count of today’s partition is
+greater than yesterday’s partition, or that a set of metrics are less
+than 3 standard deviation for the 7 day average.</p>
+<p>This operator can be used as a data quality check in your pipeline, and
+depending on where you put it in your DAG, you have the choice to
+stop the critical path, preventing from
+publishing dubious data, or on the side and receive email alerts
+without stopping the progress of the DAG.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters</dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>sql</strong> (<a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a>) – the sql to be executed. (templated)</p></li>
+<li><p><strong>conn_id</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – the connection ID used to connect to the database.</p></li>
+<li><p><strong>database</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – name of database which overwrite the defined one in connection</p></li>
+</ul>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLCheckOperator.template_fields">
+<span class="sig-name descname"><span class="pre">template_fields</span></span><em class="property"><span class="w"> </span><span class="pre">:Sequence[str]</span> <span class="pre">=</span> <span class="pre">['sql']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLCheckOperator.template_fields"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.provide [...]
 <dd></dd></dl>
 
 <dl class="py attribute">
-<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.sql_min_template">
-<span class="sig-name descname"><span class="pre">sql_min_template</span></span><em class="property"><span class="w"> </span><span class="pre">=</span> <span class="pre">MIN(check_name)</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLTableCheckOperator.sql_min_template"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.s [...]
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLCheckOperator.template_ext">
+<span class="sig-name descname"><span class="pre">template_ext</span></span><em class="property"><span class="w"> </span><span class="pre">:Sequence[str]</span> <span class="pre">=</span> <span class="pre">['.hql',</span> <span class="pre">'.sql']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLCheckOperator.template_ext"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="header [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLCheckOperator.template_fields_renderers">
+<span class="sig-name descname"><span class="pre">template_fields_renderers</span></span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLCheckOperator.template_fields_renderers"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLCheckOperator.template_fields_renderers" title="Permalink to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLCheckOperator.ui_color">
+<span class="sig-name descname"><span class="pre">ui_color</span></span><em class="property"><span class="w"> </span><span class="pre">=</span> <span class="pre">#fff7e6</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLCheckOperator.ui_color"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLCheckOperator.ui_color" [...]
 <dd></dd></dl>
 
 <dl class="py method">
-<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.execute">
-<span class="sig-name descname"><span class="pre">execute</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">context</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/provide [...]
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLCheckOperator.execute">
+<span class="sig-name descname"><span class="pre">execute</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">context</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLCheckOperator.execute"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.opera [...]
+<dd><p>This is the main method to derive when creating an operator.
+Context is the same dictionary used as when rendering jinja templates.</p>
+<p>Refer to get_template_context for more context.</p>
+<dl class="field-list simple">
+</dl>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLValueCheckOperator">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.operators.sql.</span></span><span class="sig-name descname"><span class="pre">SQLValueCheckOperator</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"> [...]
+<dd><p>Bases: <a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator" title="airflow.providers.common.sql.operators.sql.BaseSQLOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">BaseSQLOperator</span></code></a></p>
+<p>Performs a simple value check using sql code.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters</dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>sql</strong> (<a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a>) – the sql to be executed. (templated)</p></li>
+<li><p><strong>conn_id</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – the connection ID used to connect to the database.</p></li>
+<li><p><strong>database</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – name of database which overwrite the defined one in connection</p></li>
+</ul>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.__mapper_args__">
+<span class="sig-name descname"><span class="pre">__mapper_args__</span></span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLValueCheckOperator.__mapper_args__"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.__mapper_args__" title="Permalink to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.template_fields">
+<span class="sig-name descname"><span class="pre">template_fields</span></span><em class="property"><span class="w"> </span><span class="pre">:Sequence[str]</span> <span class="pre">=</span> <span class="pre">['sql',</span> <span class="pre">'pass_value']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLValueCheckOperator.template_fields"><span class="viewcode-link"><span class="pre">[source]</span></span></a> [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.template_ext">
+<span class="sig-name descname"><span class="pre">template_ext</span></span><em class="property"><span class="w"> </span><span class="pre">:Sequence[str]</span> <span class="pre">=</span> <span class="pre">['.hql',</span> <span class="pre">'.sql']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLValueCheckOperator.template_ext"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="h [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.template_fields_renderers">
+<span class="sig-name descname"><span class="pre">template_fields_renderers</span></span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLValueCheckOperator.template_fields_renderers"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.template_fields_renderers" title="Permalink to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.ui_color">
+<span class="sig-name descname"><span class="pre">ui_color</span></span><em class="property"><span class="w"> </span><span class="pre">=</span> <span class="pre">#fff7e6</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLValueCheckOperator.ui_color"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator [...]
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.execute">
+<span class="sig-name descname"><span class="pre">execute</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">context</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLValueCheckOperator.execute"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql. [...]
 <dd><p>This is the main method to derive when creating an operator.
 Context is the same dictionary used as when rendering jinja templates.</p>
 <p>Refer to get_template_context for more context.</p>
+<dl class="field-list simple">
+</dl>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.operators.sql.</span></span><span class="sig-name descname"><span class="pre">SQLIntervalCheckOperator</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">table</span></span></em>, <em class="sig-pa [...]
+<dd><p>Bases: <a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator" title="airflow.providers.common.sql.operators.sql.BaseSQLOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">BaseSQLOperator</span></code></a></p>
+<p>Checks that the values of metrics given as SQL expressions are within
+a certain tolerance of the ones from days_back before.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters</dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>table</strong> (<a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a>) – the table name</p></li>
+<li><p><strong>conn_id</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – the connection ID used to connect to the database.</p></li>
+<li><p><strong>database</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – name of database which will overwrite the defined one in connection</p></li>
+<li><p><strong>days_back</strong> (<em>SupportsAbs</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/functions.html#int" title="(in Python v3.10)"><em>int</em></a><em>]</em>) – number of days between ds and the ds we want to check
+against. Defaults to 7 days</p></li>
+<li><p><strong>date_filter_column</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – The column name for the dates to filter on. Defaults to ‘ds’</p></li>
+<li><p><strong>ratio_formula</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – <p>which formula to use to compute the ratio between
+the two metrics. Assuming cur is the metric of today and ref is
+the metric to today - days_back.</p>
+<p>max_over_min: computes max(cur, ref) / min(cur, ref)
+relative_diff: computes abs(cur-ref) / ref</p>
+<p>Default: ‘max_over_min’</p>
+</p></li>
+<li><p><strong>ignore_zero</strong> (<a class="reference external" href="https://docs.python.org/3/library/functions.html#bool" title="(in Python v3.10)"><em>bool</em></a>) – whether we should ignore zero metrics</p></li>
+<li><p><strong>metrics_thresholds</strong> (<em>Dict</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>, </em><a class="reference external" href="https://docs.python.org/3/library/functions.html#int" title="(in Python v3.10)"><em>int</em></a><em>]</em>) – a dictionary of ratios indexed by metrics</p></li>
+</ul>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.__mapper_args__">
+<span class="sig-name descname"><span class="pre">__mapper_args__</span></span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLIntervalCheckOperator.__mapper_args__"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.__mapper_args__" title="Permalink to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.template_fields">
+<span class="sig-name descname"><span class="pre">template_fields</span></span><em class="property"><span class="w"> </span><span class="pre">:Sequence[str]</span> <span class="pre">=</span> <span class="pre">['sql1',</span> <span class="pre">'sql2']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLIntervalCheckOperator.template_fields"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.template_ext">
+<span class="sig-name descname"><span class="pre">template_ext</span></span><em class="property"><span class="w"> </span><span class="pre">:Sequence[str]</span> <span class="pre">=</span> <span class="pre">['.hql',</span> <span class="pre">'.sql']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLIntervalCheckOperator.template_ext"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.template_fields_renderers">
+<span class="sig-name descname"><span class="pre">template_fields_renderers</span></span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLIntervalCheckOperator.template_fields_renderers"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.template_fields_renderers" title="Permalink to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.ui_color">
+<span class="sig-name descname"><span class="pre">ui_color</span></span><em class="property"><span class="w"> </span><span class="pre">=</span> <span class="pre">#fff7e6</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLIntervalCheckOperator.ui_color"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOp [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.ratio_formulas">
+<span class="sig-name descname"><span class="pre">ratio_formulas</span></span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLIntervalCheckOperator.ratio_formulas"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.ratio_formulas" title="Permalink to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.execute">
+<span class="sig-name descname"><span class="pre">execute</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">context</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLIntervalCheckOperator.execute"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.s [...]
+<dd><p>This is the main method to derive when creating an operator.
+Context is the same dictionary used as when rendering jinja templates.</p>
+<p>Refer to get_template_context for more context.</p>
+<dl class="field-list simple">
+</dl>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.operators.sql.</span></span><span class="sig-name descname"><span class="pre">SQLThresholdCheckOperator</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-par [...]
+<dd><p>Bases: <a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator" title="airflow.providers.common.sql.operators.sql.BaseSQLOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">BaseSQLOperator</span></code></a></p>
+<p>Performs a value check using sql code against a minimum threshold
+and a maximum threshold. Thresholds can be in the form of a numeric
+value OR a sql statement that results a numeric.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters</dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>sql</strong> (<a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a>) – the sql to be executed. (templated)</p></li>
+<li><p><strong>conn_id</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – the connection ID used to connect to the database.</p></li>
+<li><p><strong>database</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – name of database which overwrite the defined one in connection</p></li>
+<li><p><strong>min_threshold</strong> (<em>Any</em>) – numerical value or min threshold sql to be executed (templated)</p></li>
+<li><p><strong>max_threshold</strong> (<em>Any</em>) – numerical value or max threshold sql to be executed (templated)</p></li>
+</ul>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.template_fields">
+<span class="sig-name descname"><span class="pre">template_fields</span></span><em class="property"><span class="w"> </span><span class="pre">:Sequence[str]</span> <span class="pre">=</span> <span class="pre">['sql',</span> <span class="pre">'min_threshold',</span> <span class="pre">'max_threshold']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLThresholdCheckOperator.template_fields"><span class="viewcode-l [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.template_ext">
+<span class="sig-name descname"><span class="pre">template_ext</span></span><em class="property"><span class="w"> </span><span class="pre">:Sequence[str]</span> <span class="pre">=</span> <span class="pre">['.hql',</span> <span class="pre">'.sql']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLThresholdCheckOperator.template_ext"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a clas [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.template_fields_renderers">
+<span class="sig-name descname"><span class="pre">template_fields_renderers</span></span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLThresholdCheckOperator.template_fields_renderers"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.template_fields_renderers" title="Permalink to this definition">¶< [...]
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.execute">
+<span class="sig-name descname"><span class="pre">execute</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">context</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLThresholdCheckOperator.execute"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common. [...]
+<dd><p>This is the main method to derive when creating an operator.
+Context is the same dictionary used as when rendering jinja templates.</p>
+<p>Refer to get_template_context for more context.</p>
+<dl class="field-list simple">
+</dl>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.push">
+<span class="sig-name descname"><span class="pre">push</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">meta_data</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#SQLThresholdCheckOperator.push"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql. [...]
+<dd><p>Optional: Send data check info and metadata to an external database.
+Default functionality will log metadata.</p>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.BranchSQLOperator">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">airflow.providers.common.sql.operators.sql.</span></span><span class="sig-name descname"><span class="pre">BranchSQLOperator</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">sql</span></span></em>, <em class="sig-param"><spa [...]
+<dd><p>Bases: <a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator" title="airflow.providers.common.sql.operators.sql.BaseSQLOperator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">BaseSQLOperator</span></code></a>, <code class="xref py py-obj docutils literal notranslate"><span class="pre">airflow.models.SkipMixin</span></code></p>
+<p>Allows a DAG to “branch” or follow a specified path based on the results of a SQL query.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters</dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>sql</strong> (<a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a>) – The SQL code to be executed, should return true or false (templated)
+Template reference are recognized by str ending in ‘.sql’.
+Expected SQL query to return Boolean (True/False), integer (0 = False, Otherwise = 1)
+or string (true/y/yes/1/on/false/n/no/0/off).</p></li>
+<li><p><strong>follow_task_ids_if_true</strong> (<em>List</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – task id or task ids to follow if query returns true</p></li>
+<li><p><strong>follow_task_ids_if_false</strong> (<em>List</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – task id or task ids to follow if query returns false</p></li>
+<li><p><strong>conn_id</strong> (<a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a>) – the connection ID used to connect to the database.</p></li>
+<li><p><strong>database</strong> (<em>Optional</em><em>[</em><a class="reference external" href="https://docs.python.org/3/library/stdtypes.html#str" title="(in Python v3.10)"><em>str</em></a><em>]</em>) – name of database which overwrite the defined one in connection</p></li>
+<li><p><strong>parameters</strong> (<em>Optional</em><em>[</em><em>Union</em><em>[</em><em>Iterable</em><em>, </em><em>Mapping</em><em>]</em><em>]</em>) – (optional) the parameters to render the SQL query with.</p></li>
+</ul>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.BranchSQLOperator.template_fields">
+<span class="sig-name descname"><span class="pre">template_fields</span></span><em class="property"><span class="w"> </span><span class="pre">:Sequence[str]</span> <span class="pre">=</span> <span class="pre">['sql']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#BranchSQLOperator.template_fields"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.provid [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.BranchSQLOperator.template_ext">
+<span class="sig-name descname"><span class="pre">template_ext</span></span><em class="property"><span class="w"> </span><span class="pre">:Sequence[str]</span> <span class="pre">=</span> <span class="pre">['.sql']</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#BranchSQLOperator.template_ext"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.c [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.BranchSQLOperator.template_fields_renderers">
+<span class="sig-name descname"><span class="pre">template_fields_renderers</span></span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#BranchSQLOperator.template_fields_renderers"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator.template_fields_renderers" title="Permalink to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.BranchSQLOperator.ui_color">
+<span class="sig-name descname"><span class="pre">ui_color</span></span><em class="property"><span class="w"> </span><span class="pre">=</span> <span class="pre">#a22034</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#BranchSQLOperator.ui_color"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator.ui_colo [...]
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.BranchSQLOperator.ui_fgcolor">
+<span class="sig-name descname"><span class="pre">ui_fgcolor</span></span><em class="property"><span class="w"> </span><span class="pre">=</span> <span class="pre">#F7F7F7</span></em><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#BranchSQLOperator.ui_fgcolor"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator.ui_ [...]
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="airflow.providers.common.sql.operators.sql.BranchSQLOperator.execute">
+<span class="sig-name descname"><span class="pre">execute</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">context</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/operators/sql.html#BranchSQLOperator.execute"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.oper [...]
+<dd><p>This is the main method to derive when creating an operator.
+Context is the same dictionary used as when rendering jinja templates.</p>
+<p>Refer to get_template_context for more context.</p>
+<dl class="field-list simple">
+</dl>
 </dd></dl>
 
 </dd></dl>
@@ -834,17 +1208,66 @@ Context is the same dictionary used as when rendering jinja templates.</p>
 <li><a class="reference internal" href="#classes">Classes</a></li>
 <li><a class="reference internal" href="#functions">Functions</a><ul>
 <li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.parse_boolean">parse_boolean</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator">BaseSQLOperator</a><ul>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BaseSQLOperator.get_db_hook">get_db_hook</a></li>
+</ul>
+</li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator">SQLColumnCheckOperator</a><ul>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.template_fields">template_fields</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.column_checks">column_checks</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.execute">execute</a></li>
 </ul>
 </li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator">SQLTableCheckOperator</a><ul>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.template_fields">template_fields</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.sql_check_template">sql_check_template</a></li>
-<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.sql_min_template">sql_min_template</a></li>
 <li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.execute">execute</a></li>
 </ul>
 </li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLCheckOperator">SQLCheckOperator</a><ul>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLCheckOperator.template_fields">template_fields</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLCheckOperator.template_ext">template_ext</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLCheckOperator.template_fields_renderers">template_fields_renderers</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLCheckOperator.ui_color">ui_color</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLCheckOperator.execute">execute</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator">SQLValueCheckOperator</a><ul>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.__mapper_args__">__mapper_args__</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.template_fields">template_fields</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.template_ext">template_ext</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.template_fields_renderers">template_fields_renderers</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.ui_color">ui_color</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.execute">execute</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator">SQLIntervalCheckOperator</a><ul>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.__mapper_args__">__mapper_args__</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.template_fields">template_fields</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.template_ext">template_ext</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.template_fields_renderers">template_fields_renderers</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.ui_color">ui_color</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.ratio_formulas">ratio_formulas</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.execute">execute</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator">SQLThresholdCheckOperator</a><ul>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.template_fields">template_fields</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.template_ext">template_ext</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.template_fields_renderers">template_fields_renderers</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.execute">execute</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.push">push</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator">BranchSQLOperator</a><ul>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator.template_fields">template_fields</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator.template_ext">template_ext</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator.template_fields_renderers">template_fields_renderers</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator.ui_color">ui_color</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator.ui_fgcolor">ui_fgcolor</a></li>
+<li><a class="reference internal" href="#airflow.providers.common.sql.operators.sql.BranchSQLOperator.execute">execute</a></li>
+</ul>
+</li>
 </ul>
 </li>
 </ul>
@@ -1019,5 +1442,6 @@ Context is the same dictionary used as when rendering jinja templates.</p>
         <script src="../../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/sensors/index.html b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/sensors/index.html
similarity index 99%
copy from docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/sensors/index.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/sensors/index.html
index bf41d13a2f..21fe47a520 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/sensors/index.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/sensors/index.html
@@ -284,7 +284,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -426,7 +426,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -847,5 +847,6 @@
         <script src="../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/sensors/sql/index.html b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/sensors/sql/index.html
similarity index 99%
copy from docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/sensors/sql/index.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/sensors/sql/index.html
index 9236b666f2..4a95181e84 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_api/airflow/providers/common/sql/sensors/sql/index.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_api/airflow/providers/common/sql/sensors/sql/index.html
@@ -284,7 +284,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -426,7 +426,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -652,7 +652,7 @@ Should match the desired hook constructor params.</p></li>
 
 <dl class="py method">
 <dt class="sig sig-object py" id="airflow.providers.common.sql.sensors.sql.SqlSensor.poke">
-<span class="sig-name descname"><span class="pre">poke</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">self</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">context</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/sensors/sql.html#SqlSensor.poke"><span class="viewcode-link"><span class="pre">[source]</span></span>< [...]
+<span class="sig-name descname"><span class="pre">poke</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">context</span></span></em><span class="sig-paren">)</span><a class="reference internal" href="../../../../../../../_modules/airflow/providers/common/sql/sensors/sql.html#SqlSensor.poke"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#airflow.providers.common.sql.sensors.sql.SqlSenso [...]
 <dd><p>Function that the sensors defined while deriving this class should
 override.</p>
 <dl class="field-list simple">
@@ -924,5 +924,6 @@ override.</p>
         <script src="../../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_api/tests/system/providers/common/sql/example_sql_column_table_check/index.html b/docs/apache-airflow-providers-common-sql/1.1.0/_api/tests/system/providers/common/sql/example_sql_column_table_check/index.html
similarity index 99%
copy from docs/apache-airflow-providers-common-sql/stable/_api/tests/system/providers/common/sql/example_sql_column_table_check/index.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_api/tests/system/providers/common/sql/example_sql_column_table_check/index.html
index fee7e26805..37d8573cce 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_api/tests/system/providers/common/sql/example_sql_column_table_check/index.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_api/tests/system/providers/common/sql/example_sql_column_table_check/index.html
@@ -284,7 +284,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -426,7 +426,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -868,5 +868,6 @@
         <script src="../../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_api/tests/system/providers/common/sql/index.html b/docs/apache-airflow-providers-common-sql/1.1.0/_api/tests/system/providers/common/sql/index.html
similarity index 99%
copy from docs/apache-airflow-providers-common-sql/stable/_api/tests/system/providers/common/sql/index.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_api/tests/system/providers/common/sql/index.html
index ec1a6dba19..7eec32d865 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_api/tests/system/providers/common/sql/index.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_api/tests/system/providers/common/sql/index.html
@@ -284,7 +284,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -426,7 +426,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -845,5 +845,6 @@
         <script src="../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_modules/airflow/providers/common/sql/hooks/sql.html b/docs/apache-airflow-providers-common-sql/1.1.0/_modules/airflow/providers/common/sql/hooks/sql.html
similarity index 91%
copy from docs/apache-airflow-providers-common-sql/stable/_modules/airflow/providers/common/sql/hooks/sql.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_modules/airflow/providers/common/sql/hooks/sql.html
index 2ed8d0a354..07d436b57b 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_modules/airflow/providers/common/sql/hooks/sql.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_modules/airflow/providers/common/sql/hooks/sql.html
@@ -282,7 +282,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -424,7 +424,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -606,8 +606,10 @@
 <span class="kn">import</span> <span class="nn">warnings</span>
 <span class="kn">from</span> <span class="nn">contextlib</span> <span class="kn">import</span> <span class="n">closing</span>
 <span class="kn">from</span> <span class="nn">datetime</span> <span class="kn">import</span> <span class="n">datetime</span>
-<span class="kn">from</span> <span class="nn">typing</span> <span class="kn">import</span> <span class="n">Any</span><span class="p">,</span> <span class="n">Optional</span>
+<span class="kn">from</span> <span class="nn">typing</span> <span class="kn">import</span> <span class="n">Any</span><span class="p">,</span> <span class="n">Callable</span><span class="p">,</span> <span class="n">Iterable</span><span class="p">,</span> <span class="n">List</span><span class="p">,</span> <span class="n">Mapping</span><span class="p">,</span> <span class="n">Optional</span><span class="p">,</span> <span class="n">Tuple</span><span class="p">,</span> <span class="n">Type</ [...]
 
+<span class="kn">import</span> <span class="nn">sqlparse</span>
+<span class="kn">from</span> <span class="nn">packaging.version</span> <span class="kn">import</span> <span class="n">Version</span>
 <span class="kn">from</span> <span class="nn">sqlalchemy</span> <span class="kn">import</span> <span class="n">create_engine</span>
 <span class="kn">from</span> <span class="nn">typing_extensions</span> <span class="kn">import</span> <span class="n">Protocol</span>
 
@@ -615,6 +617,15 @@
 <span class="kn">from</span> <span class="nn">airflow.hooks.base</span> <span class="kn">import</span> <span class="n">BaseHook</span>
 <span class="kn">from</span> <span class="nn">airflow.providers_manager</span> <span class="kn">import</span> <span class="n">ProvidersManager</span>
 <span class="kn">from</span> <span class="nn">airflow.utils.module_loading</span> <span class="kn">import</span> <span class="n">import_string</span>
+<span class="kn">from</span> <span class="nn">airflow.version</span> <span class="kn">import</span> <span class="n">version</span>
+
+
+<div class="viewcode-block" id="fetch_all_handler"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.fetch_all_handler">[docs]</a><span class="k">def</span> <span class="nf">fetch_all_handler</span><span class="p">(</span><span class="n">cursor</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="n">Optional</span><span class="p">[</span><span class="n">List</span><span class= [...]
+    <span class="sd">&quot;&quot;&quot;Handler for DbApiHook.run() to return results&quot;&quot;&quot;</span>
+    <span class="k">if</span> <span class="n">cursor</span><span class="o">.</span><span class="n">description</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
+        <span class="k">return</span> <span class="n">cursor</span><span class="o">.</span><span class="n">fetchall</span><span class="p">()</span>
+    <span class="k">else</span><span class="p">:</span>
+        <span class="k">return</span> <span class="kc">None</span></div>
 
 
 <span class="k">def</span> <span class="nf">_backported_get_hook</span><span class="p">(</span><span class="n">connection</span><span class="p">,</span> <span class="o">*</span><span class="p">,</span> <span class="n">hook_params</span><span class="o">=</span><span class="kc">None</span><span class="p">):</span>
@@ -653,7 +664,21 @@
 <span class="sd">        &quot;&quot;&quot;</span></div></div>
 
 
-<div class="viewcode-block" id="DbApiHook"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook">[docs]</a><span class="k">class</span> <span class="nc">DbApiHook</span><span class="p">(</span><span class="n">BaseHook</span><span class="p">):</span>
+<span class="c1"># In case we are running it on Airflow 2.4+, we should use BaseHook, but on Airflow 2.3 and below</span>
+<span class="c1"># We want the DbApiHook to derive from the original DbApiHook from airflow, because otherwise</span>
+<span class="c1"># SqlSensor and BaseSqlOperator from &quot;airflow.operators&quot; and &quot;airflow.sensors&quot; will refuse to</span>
+<span class="c1"># accept the new Hooks as not derived from the original DbApiHook</span>
+<span class="k">if</span> <span class="n">Version</span><span class="p">(</span><span class="n">version</span><span class="p">)</span> <span class="o">&lt;</span> <span class="n">Version</span><span class="p">(</span><span class="s1">&#39;2.4&#39;</span><span class="p">):</span>
+    <span class="k">try</span><span class="p">:</span>
+        <span class="kn">from</span> <span class="nn">airflow.hooks.dbapi</span> <span class="kn">import</span> <span class="n">DbApiHook</span> <span class="k">as</span> <span class="n">BaseForDbApiHook</span>
+    <span class="k">except</span> <span class="ne">ImportError</span><span class="p">:</span>
+        <span class="c1"># just in case we have a problem with circular import</span>
+<div class="viewcode-block" id="BaseForDbApiHook"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.BaseForDbApiHook">[docs]</a>        <span class="n">BaseForDbApiHook</span><span class="p">:</span> <span class="n">Type</span><span class="p">[</span><span class="n">BaseHook</span><span class="p">]</span> <span class="o">=</span> <span class="n">BaseHook</span>  <span class="c1"># type: ignore[no [...]
+<span class="k">else</span><span class="p">:</span>
+    <span class="n">BaseForDbApiHook</span><span class="p">:</span> <span class="n">Type</span><span class="p">[</span><span class="n">BaseHook</span><span class="p">]</span> <span class="o">=</span> <span class="n">BaseHook</span>  <span class="c1"># type: ignore[no-redef]</span>
+
+
+<div class="viewcode-block" id="DbApiHook"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook">[docs]</a><span class="k">class</span> <span class="nc">DbApiHook</span><span class="p">(</span><span class="n">BaseForDbApiHook</span><span class="p">):</span>
     <span class="sd">&quot;&quot;&quot;</span>
 <span class="sd">    Abstract base class for sql hooks.</span>
 
@@ -758,7 +783,12 @@
         <span class="k">with</span> <span class="n">closing</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">get_conn</span><span class="p">())</span> <span class="k">as</span> <span class="n">conn</span><span class="p">:</span>
             <span class="k">yield from</span> <span class="n">psql</span><span class="o">.</span><span class="n">read_sql</span><span class="p">(</span><span class="n">sql</span><span class="p">,</span> <span class="n">con</span><span class="o">=</span><span class="n">conn</span><span class="p">,</span> <span class="n">params</span><span class="o">=</span><span class="n">parameters</span><span class="p">,</span> <span class="n">chunksize</span><span class="o">=</span><span class="n">chun [...]
 
-<div class="viewcode-block" id="DbApiHook.get_records"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook.get_records">[docs]</a>    <span class="k">def</span> <span class="nf">get_records</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">sql</span><span class="p">,</span> <span class="n">parameters</span><span class="o">=</span><span clas [...]
+<div class="viewcode-block" id="DbApiHook.get_records"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook.get_records">[docs]</a>    <span class="k">def</span> <span class="nf">get_records</span><span class="p">(</span>
+        <span class="bp">self</span><span class="p">,</span>
+        <span class="n">sql</span><span class="p">:</span> <span class="n">Union</span><span class="p">[</span><span class="nb">str</span><span class="p">,</span> <span class="n">List</span><span class="p">[</span><span class="nb">str</span><span class="p">]],</span>
+        <span class="n">parameters</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="n">Union</span><span class="p">[</span><span class="n">Iterable</span><span class="p">,</span> <span class="n">Mapping</span><span class="p">]]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="o">**</span><span class="n">kwargs</span><span class="p">:</span> <span class="nb">dict</span><span class="p">,</span>
+    <span class="p">):</span>
         <span class="sd">&quot;&quot;&quot;</span>
 <span class="sd">        Executes the sql and returns a set of records.</span>
 
@@ -774,7 +804,7 @@
                     <span class="n">cur</span><span class="o">.</span><span class="n">execute</span><span class="p">(</span><span class="n">sql</span><span class="p">)</span>
                 <span class="k">return</span> <span class="n">cur</span><span class="o">.</span><span class="n">fetchall</span><span class="p">()</span></div>
 
-<div class="viewcode-block" id="DbApiHook.get_first"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook.get_first">[docs]</a>    <span class="k">def</span> <span class="nf">get_first</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">sql</span><span class="p">,</span> <span class="n">parameters</span><span class="o">=</span><span class="kc" [...]
+<div class="viewcode-block" id="DbApiHook.get_first"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook.get_first">[docs]</a>    <span class="k">def</span> <span class="nf">get_first</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">sql</span><span class="p">:</span> <span class="n">Union</span><span class="p">[</span><span class="nb">str< [...]
         <span class="sd">&quot;&quot;&quot;</span>
 <span class="sd">        Executes the sql and returns the first resulting row.</span>
 
@@ -790,7 +820,33 @@
                     <span class="n">cur</span><span class="o">.</span><span class="n">execute</span><span class="p">(</span><span class="n">sql</span><span class="p">)</span>
                 <span class="k">return</span> <span class="n">cur</span><span class="o">.</span><span class="n">fetchone</span><span class="p">()</span></div>
 
-<div class="viewcode-block" id="DbApiHook.run"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook.run">[docs]</a>    <span class="k">def</span> <span class="nf">run</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">sql</span><span class="p">,</span> <span class="n">autocommit</span><span class="o">=</span><span class="kc">False</span><span [...]
+    <span class="nd">@staticmethod</span>
+<div class="viewcode-block" id="DbApiHook.strip_sql_string"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook.strip_sql_string">[docs]</a>    <span class="k">def</span> <span class="nf">strip_sql_string</span><span class="p">(</span><span class="n">sql</span><span class="p">:</span> <span class="nb">str</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</sp [...]
+        <span class="k">return</span> <span class="n">sql</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span><span class="o">.</span><span class="n">rstrip</span><span class="p">(</span><span class="s1">&#39;;&#39;</span><span class="p">)</span></div>
+
+    <span class="nd">@staticmethod</span>
+<div class="viewcode-block" id="DbApiHook.split_sql_string"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook.split_sql_string">[docs]</a>    <span class="k">def</span> <span class="nf">split_sql_string</span><span class="p">(</span><span class="n">sql</span><span class="p">:</span> <span class="nb">str</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="n">List</sp [...]
+        <span class="sd">&quot;&quot;&quot;</span>
+<span class="sd">        Splits string into multiple SQL expressions</span>
+
+<span class="sd">        :param sql: SQL string potentially consisting of multiple expressions</span>
+<span class="sd">        :return: list of individual expressions</span>
+<span class="sd">        &quot;&quot;&quot;</span>
+        <span class="n">splits</span> <span class="o">=</span> <span class="n">sqlparse</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="n">sqlparse</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">sql</span><span class="p">,</span> <span class="n">strip_comments</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+        <span class="n">statements</span><span class="p">:</span> <span class="n">List</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span>
+            <span class="nb">filter</span><span class="p">(</span><span class="kc">None</span><span class="p">,</span> <span class="p">[</span><span class="n">s</span><span class="o">.</span><span class="n">rstrip</span><span class="p">(</span><span class="s1">&#39;;&#39;</span><span class="p">)</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> <span class="k">if</span> <span class="n">s</span><span class="o">.</span><span class="n">endswith</span><span  [...]
+        <span class="p">)</span>
+        <span class="k">return</span> <span class="n">statements</span></div>
+
+<div class="viewcode-block" id="DbApiHook.run"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/hooks/sql/index.html#airflow.providers.common.sql.hooks.sql.DbApiHook.run">[docs]</a>    <span class="k">def</span> <span class="nf">run</span><span class="p">(</span>
+        <span class="bp">self</span><span class="p">,</span>
+        <span class="n">sql</span><span class="p">:</span> <span class="n">Union</span><span class="p">[</span><span class="nb">str</span><span class="p">,</span> <span class="n">Iterable</span><span class="p">[</span><span class="nb">str</span><span class="p">]],</span>
+        <span class="n">autocommit</span><span class="p">:</span> <span class="nb">bool</span> <span class="o">=</span> <span class="kc">False</span><span class="p">,</span>
+        <span class="n">parameters</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="n">Union</span><span class="p">[</span><span class="n">Iterable</span><span class="p">,</span> <span class="n">Mapping</span><span class="p">]]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="n">handler</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="n">Callable</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="n">split_statements</span><span class="p">:</span> <span class="nb">bool</span> <span class="o">=</span> <span class="kc">False</span><span class="p">,</span>
+        <span class="n">return_last</span><span class="p">:</span> <span class="nb">bool</span> <span class="o">=</span> <span class="kc">True</span><span class="p">,</span>
+    <span class="p">)</span> <span class="o">-&gt;</span> <span class="n">Optional</span><span class="p">[</span><span class="n">Union</span><span class="p">[</span><span class="n">Any</span><span class="p">,</span> <span class="n">List</span><span class="p">[</span><span class="n">Any</span><span class="p">]]]:</span>
         <span class="sd">&quot;&quot;&quot;</span>
 <span class="sd">        Runs a command or a list of commands. Pass a list of sql</span>
 <span class="sd">        statements to the sql parameter to get them to execute</span>
@@ -802,14 +858,19 @@
 <span class="sd">            before executing the query.</span>
 <span class="sd">        :param parameters: The parameters to render the SQL query with.</span>
 <span class="sd">        :param handler: The result handler which is called with the result of each statement.</span>
-<span class="sd">        :return: query results if handler was provided.</span>
+<span class="sd">        :param split_statements: Whether to split a single SQL string into statements and run separately</span>
+<span class="sd">        :param return_last: Whether to return result for only last statement or for all after split</span>
+<span class="sd">        :return: return only result of the ALL SQL expressions if handler was provided.</span>
 <span class="sd">        &quot;&quot;&quot;</span>
-        <span class="n">scalar</span> <span class="o">=</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">sql</span><span class="p">,</span> <span class="nb">str</span><span class="p">)</span>
-        <span class="k">if</span> <span class="n">scalar</span><span class="p">:</span>
-            <span class="n">sql</span> <span class="o">=</span> <span class="p">[</span><span class="n">sql</span><span class="p">]</span>
+        <span class="n">scalar_return_last</span> <span class="o">=</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">sql</span><span class="p">,</span> <span class="nb">str</span><span class="p">)</span> <span class="ow">and</span> <span class="n">return_last</span>
+        <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">sql</span><span class="p">,</span> <span class="nb">str</span><span class="p">):</span>
+            <span class="k">if</span> <span class="n">split_statements</span><span class="p">:</span>
+                <span class="n">sql</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">split_sql_string</span><span class="p">(</span><span class="n">sql</span><span class="p">)</span>
+            <span class="k">else</span><span class="p">:</span>
+                <span class="n">sql</span> <span class="o">=</span> <span class="p">[</span><span class="bp">self</span><span class="o">.</span><span class="n">strip_sql_string</span><span class="p">(</span><span class="n">sql</span><span class="p">)]</span>
 
         <span class="k">if</span> <span class="n">sql</span><span class="p">:</span>
-            <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">debug</span><span class="p">(</span><span class="s2">&quot;Executing </span><span class="si">%d</span><span class="s2"> statements&quot;</span><span class="p">,</span> <span class="nb">len</span><span class="p">(</span><span class="n">sql</span><span class="p">))</span>
+            <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">debug</span><span class="p">(</span><span class="s2">&quot;Executing following statements against DB: </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="nb">list</span><span class="p">(</span><span class="n">sql</span><span class="p">))</span>
         <span class="k">else</span><span class="p">:</span>
             <span class="k">raise</span> <span class="ne">ValueError</span><span class="p">(</span><span class="s2">&quot;List of SQL statements is empty&quot;</span><span class="p">)</span>
 
@@ -821,22 +882,21 @@
                 <span class="n">results</span> <span class="o">=</span> <span class="p">[]</span>
                 <span class="k">for</span> <span class="n">sql_statement</span> <span class="ow">in</span> <span class="n">sql</span><span class="p">:</span>
                     <span class="bp">self</span><span class="o">.</span><span class="n">_run_command</span><span class="p">(</span><span class="n">cur</span><span class="p">,</span> <span class="n">sql_statement</span><span class="p">,</span> <span class="n">parameters</span><span class="p">)</span>
+
                     <span class="k">if</span> <span class="n">handler</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
                         <span class="n">result</span> <span class="o">=</span> <span class="n">handler</span><span class="p">(</span><span class="n">cur</span><span class="p">)</span>
                         <span class="n">results</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">result</span><span class="p">)</span>
 
-            <span class="c1"># If autocommit was set to False for db that supports autocommit,</span>
-            <span class="c1"># or if db does not supports autocommit, we do a manual commit.</span>
+            <span class="c1"># If autocommit was set to False or db does not support autocommit, we do a manual commit.</span>
             <span class="k">if</span> <span class="ow">not</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_autocommit</span><span class="p">(</span><span class="n">conn</span><span class="p">):</span>
                 <span class="n">conn</span><span class="o">.</span><span class="n">commit</span><span class="p">()</span>
 
         <span class="k">if</span> <span class="n">handler</span> <span class="ow">is</span> <span class="kc">None</span><span class="p">:</span>
             <span class="k">return</span> <span class="kc">None</span>
-
-        <span class="k">if</span> <span class="n">scalar</span><span class="p">:</span>
-            <span class="k">return</span> <span class="n">results</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
-
-        <span class="k">return</span> <span class="n">results</span></div>
+        <span class="k">elif</span> <span class="n">scalar_return_last</span><span class="p">:</span>
+            <span class="k">return</span> <span class="n">results</span><span class="p">[</span><span class="o">-</span><span class="mi">1</span><span class="p">]</span>
+        <span class="k">else</span><span class="p">:</span>
+            <span class="k">return</span> <span class="n">results</span></div>
 
     <span class="k">def</span> <span class="nf">_run_command</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">cur</span><span class="p">,</span> <span class="n">sql_statement</span><span class="p">,</span> <span class="n">parameters</span><span class="p">):</span>
         <span class="sd">&quot;&quot;&quot;Runs a statement using an already open cursor.&quot;&quot;&quot;</span>
@@ -1207,5 +1267,6 @@
         <script src="../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_modules/airflow/providers/common/sql/operators/sql.html b/docs/apache-airflow-providers-common-sql/1.1.0/_modules/airflow/providers/common/sql/operators/sql.html
similarity index 56%
copy from docs/apache-airflow-providers-common-sql/stable/_modules/airflow/providers/common/sql/operators/sql.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_modules/airflow/providers/common/sql/operators/sql.html
index d0664a6b99..99382f2e6f 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_modules/airflow/providers/common/sql/operators/sql.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_modules/airflow/providers/common/sql/operators/sql.html
@@ -282,7 +282,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -424,7 +424,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -604,10 +604,19 @@
 <span class="c1"># KIND, either express or implied.  See the License for the</span>
 <span class="c1"># specific language governing permissions and limitations</span>
 <span class="c1"># under the License.</span>
-<span class="kn">from</span> <span class="nn">typing</span> <span class="kn">import</span> <span class="n">Any</span><span class="p">,</span> <span class="n">Dict</span><span class="p">,</span> <span class="n">Optional</span><span class="p">,</span> <span class="n">Union</span>
+<span class="kn">from</span> <span class="nn">typing</span> <span class="kn">import</span> <span class="n">TYPE_CHECKING</span><span class="p">,</span> <span class="n">Any</span><span class="p">,</span> <span class="n">Dict</span><span class="p">,</span> <span class="n">Iterable</span><span class="p">,</span> <span class="n">List</span><span class="p">,</span> <span class="n">Mapping</span><span class="p">,</span> <span class="n">Optional</span><span class="p">,</span> <span class="n">Se [...]
 
+<span class="kn">from</span> <span class="nn">packaging.version</span> <span class="kn">import</span> <span class="n">Version</span>
+
+<span class="kn">from</span> <span class="nn">airflow.compat.functools</span> <span class="kn">import</span> <span class="n">cached_property</span>
 <span class="kn">from</span> <span class="nn">airflow.exceptions</span> <span class="kn">import</span> <span class="n">AirflowException</span>
-<span class="kn">from</span> <span class="nn">airflow.operators.sql</span> <span class="kn">import</span> <span class="n">BaseSQLOperator</span>
+<span class="kn">from</span> <span class="nn">airflow.hooks.base</span> <span class="kn">import</span> <span class="n">BaseHook</span>
+<span class="kn">from</span> <span class="nn">airflow.models</span> <span class="kn">import</span> <span class="n">BaseOperator</span><span class="p">,</span> <span class="n">SkipMixin</span>
+<span class="kn">from</span> <span class="nn">airflow.providers.common.sql.hooks.sql</span> <span class="kn">import</span> <span class="n">DbApiHook</span><span class="p">,</span> <span class="n">_backported_get_hook</span>
+<span class="kn">from</span> <span class="nn">airflow.version</span> <span class="kn">import</span> <span class="n">version</span>
+
+<span class="k">if</span> <span class="n">TYPE_CHECKING</span><span class="p">:</span>
+    <span class="kn">from</span> <span class="nn">airflow.utils.context</span> <span class="kn">import</span> <span class="n">Context</span>
 
 
 <div class="viewcode-block" id="parse_boolean"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.parse_boolean">[docs]</a><span class="k">def</span> <span class="nf">parse_boolean</span><span class="p">(</span><span class="n">val</span><span class="p">:</span> <span class="nb">str</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="n">Union</span><span class="p">[</sp [...]
@@ -623,7 +632,13 @@
     <span class="k">raise</span> <span class="ne">ValueError</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="n">val</span><span class="si">!r}</span><span class="s2"> is not a boolean-like string value&quot;</span><span class="p">)</span></div>
 
 
-<span class="k">def</span> <span class="nf">_get_failed_tests</span><span class="p">(</span><span class="n">checks</span><span class="p">):</span>
+<span class="k">def</span> <span class="nf">_get_failed_checks</span><span class="p">(</span><span class="n">checks</span><span class="p">,</span> <span class="n">col</span><span class="o">=</span><span class="kc">None</span><span class="p">):</span>
+    <span class="k">if</span> <span class="n">col</span><span class="p">:</span>
+        <span class="k">return</span> <span class="p">[</span>
+            <span class="sa">f</span><span class="s2">&quot;Column: </span><span class="si">{</span><span class="n">col</span><span class="si">}</span><span class="se">\n</span><span class="s2">Check: </span><span class="si">{</span><span class="n">check</span><span class="si">}</span><span class="s2">,</span><span class="se">\n</span><span class="s2">Check Values: </span><span class="si">{</span><span class="n">check_values</span><span class="si">}</span><span class="se">\n</span><span  [...]
+            <span class="k">for</span> <span class="n">check</span><span class="p">,</span> <span class="n">check_values</span> <span class="ow">in</span> <span class="n">checks</span><span class="o">.</span><span class="n">items</span><span class="p">()</span>
+            <span class="k">if</span> <span class="ow">not</span> <span class="n">check_values</span><span class="p">[</span><span class="s2">&quot;success&quot;</span><span class="p">]</span>
+        <span class="p">]</span>
     <span class="k">return</span> <span class="p">[</span>
         <span class="sa">f</span><span class="s2">&quot;</span><span class="se">\t</span><span class="s2">Check: </span><span class="si">{</span><span class="n">check</span><span class="si">}</span><span class="s2">,</span><span class="se">\n\t</span><span class="s2">Check Values: </span><span class="si">{</span><span class="n">check_values</span><span class="si">}</span><span class="se">\n</span><span class="s2">&quot;</span>
         <span class="k">for</span> <span class="n">check</span><span class="p">,</span> <span class="n">check_values</span> <span class="ow">in</span> <span class="n">checks</span><span class="o">.</span><span class="n">items</span><span class="p">()</span>
@@ -631,6 +646,61 @@
     <span class="p">]</span>
 
 
+<div class="viewcode-block" id="BaseSQLOperator"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.BaseSQLOperator">[docs]</a><span class="k">class</span> <span class="nc">BaseSQLOperator</span><span class="p">(</span><span class="n">BaseOperator</span><span class="p">):</span>
+    <span class="sd">&quot;&quot;&quot;</span>
+<span class="sd">    This is a base class for generic SQL Operator to get a DB Hook</span>
+
+<span class="sd">    The provided method is .get_db_hook(). The default behavior will try to</span>
+<span class="sd">    retrieve the DB hook based on connection type.</span>
+<span class="sd">    You can custom the behavior by overriding the .get_db_hook() method.</span>
+<span class="sd">    &quot;&quot;&quot;</span>
+
+    <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span>
+        <span class="bp">self</span><span class="p">,</span>
+        <span class="o">*</span><span class="p">,</span>
+        <span class="n">conn_id</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="n">database</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="n">hook_params</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="n">Dict</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="o">**</span><span class="n">kwargs</span><span class="p">,</span>
+    <span class="p">):</span>
+        <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="fm">__init__</span><span class="p">(</span><span class="o">**</span><span class="n">kwargs</span><span class="p">)</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">conn_id</span> <span class="o">=</span> <span class="n">conn_id</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">database</span> <span class="o">=</span> <span class="n">database</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">hook_params</span> <span class="o">=</span> <span class="p">{}</span> <span class="k">if</span> <span class="n">hook_params</span> <span class="ow">is</span> <span class="kc">None</span> <span class="k">else</span> <span class="n">hook_params</span>
+
+    <span class="nd">@cached_property</span>
+    <span class="k">def</span> <span class="nf">_hook</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
+        <span class="sd">&quot;&quot;&quot;Get DB Hook based on connection type&quot;&quot;&quot;</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">debug</span><span class="p">(</span><span class="s2">&quot;Get connection for </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">conn_id</span><span class="p">)</span>
+        <span class="n">conn</span> <span class="o">=</span> <span class="n">BaseHook</span><span class="o">.</span><span class="n">get_connection</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">conn_id</span><span class="p">)</span>
+        <span class="k">if</span> <span class="n">Version</span><span class="p">(</span><span class="n">version</span><span class="p">)</span> <span class="o">&gt;=</span> <span class="n">Version</span><span class="p">(</span><span class="s1">&#39;2.3&#39;</span><span class="p">):</span>
+            <span class="c1"># &quot;hook_params&quot; were introduced to into &quot;get_hook()&quot; only in Airflow 2.3.</span>
+            <span class="n">hook</span> <span class="o">=</span> <span class="n">conn</span><span class="o">.</span><span class="n">get_hook</span><span class="p">(</span><span class="n">hook_params</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">hook_params</span><span class="p">)</span>  <span class="c1"># ignore airflow compat check</span>
+        <span class="k">else</span><span class="p">:</span>
+            <span class="c1"># For supporting Airflow versions &lt; 2.3, we backport &quot;get_hook()&quot; method. This should be removed</span>
+            <span class="c1"># when &quot;apache-airflow-providers-common-sql&quot; will depend on Airflow &gt;= 2.3.</span>
+            <span class="n">hook</span> <span class="o">=</span> <span class="n">_backported_get_hook</span><span class="p">(</span><span class="n">conn</span><span class="p">,</span> <span class="n">hook_params</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">hook_params</span><span class="p">)</span>
+        <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">hook</span><span class="p">,</span> <span class="n">DbApiHook</span><span class="p">):</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span>
+                <span class="sa">f</span><span class="s1">&#39;The connection type is not supported by </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="vm">__class__</span><span class="o">.</span><span class="vm">__name__</span><span class="si">}</span><span class="s1">. &#39;</span>
+                <span class="sa">f</span><span class="s1">&#39;The associated hook should be a subclass of `DbApiHook`. Got </span><span class="si">{</span><span class="n">hook</span><span class="o">.</span><span class="vm">__class__</span><span class="o">.</span><span class="vm">__name__</span><span class="si">}</span><span class="s1">&#39;</span>
+            <span class="p">)</span>
+
+        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">database</span><span class="p">:</span>
+            <span class="n">hook</span><span class="o">.</span><span class="n">schema</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">database</span>
+
+        <span class="k">return</span> <span class="n">hook</span>
+
+<div class="viewcode-block" id="BaseSQLOperator.get_db_hook"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.BaseSQLOperator.get_db_hook">[docs]</a>    <span class="k">def</span> <span class="nf">get_db_hook</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="n">DbApiHook</span><span class="p">:</span>
+        <span class="sd">&quot;&quot;&quot;</span>
+<span class="sd">        Get the database hook for the connection.</span>
+
+<span class="sd">        :return: the database hook object.</span>
+<span class="sd">        :rtype: DbApiHook</span>
+<span class="sd">        &quot;&quot;&quot;</span>
+        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">_hook</span></div></div>
+
+
 <div class="viewcode-block" id="SQLColumnCheckOperator"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator">[docs]</a><span class="k">class</span> <span class="nc">SQLColumnCheckOperator</span><span class="p">(</span><span class="n">BaseSQLOperator</span><span class="p">):</span>
     <span class="sd">&quot;&quot;&quot;</span>
 <span class="sd">    Performs one or more of the templated checks in the column_checks dictionary.</span>
@@ -662,6 +732,13 @@
 <span class="sd">            }</span>
 <span class="sd">        }</span>
 
+<span class="sd">    :param partition_clause: a partial SQL statement that is added to a WHERE clause in the query built by</span>
+<span class="sd">        the operator that creates partition_clauses for the checks to run on, e.g.</span>
+
+<span class="sd">    .. code-block:: python</span>
+
+<span class="sd">        &quot;date = &#39;1970-01-01&#39;&quot;</span>
+
 <span class="sd">    :param conn_id: the connection ID used to connect to the database</span>
 <span class="sd">    :param database: name of database which overwrite the defined one in connection</span>
 
@@ -670,6 +747,8 @@
 <span class="sd">        :ref:`howto/operator:SQLColumnCheckOperator`</span>
 <span class="sd">    &quot;&quot;&quot;</span>
 
+<div class="viewcode-block" id="SQLColumnCheckOperator.template_fields"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.template_fields">[docs]</a>    <span class="n">template_fields</span> <span class="o">=</span> <span class="p">(</span><span class="s2">&quot;partition_clause&quot;</span><span class="p">,)</span></div>
+
 <div class="viewcode-block" id="SQLColumnCheckOperator.column_checks"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.column_checks">[docs]</a>    <span class="n">column_checks</span> <span class="o">=</span> <span class="p">{</span>
         <span class="s2">&quot;null_check&quot;</span><span class="p">:</span> <span class="s2">&quot;SUM(CASE WHEN column IS NULL THEN 1 ELSE 0 END) AS column_null_check&quot;</span><span class="p">,</span>
         <span class="s2">&quot;distinct_check&quot;</span><span class="p">:</span> <span class="s2">&quot;COUNT(DISTINCT(column)) AS column_distinct_check&quot;</span><span class="p">,</span>
@@ -683,6 +762,7 @@
         <span class="o">*</span><span class="p">,</span>
         <span class="n">table</span><span class="p">:</span> <span class="nb">str</span><span class="p">,</span>
         <span class="n">column_mapping</span><span class="p">:</span> <span class="n">Dict</span><span class="p">[</span><span class="nb">str</span><span class="p">,</span> <span class="n">Dict</span><span class="p">[</span><span class="nb">str</span><span class="p">,</span> <span class="n">Any</span><span class="p">]],</span>
+        <span class="n">partition_clause</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
         <span class="n">conn_id</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
         <span class="n">database</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
         <span class="o">**</span><span class="n">kwargs</span><span class="p">,</span>
@@ -694,17 +774,18 @@
 
         <span class="bp">self</span><span class="o">.</span><span class="n">table</span> <span class="o">=</span> <span class="n">table</span>
         <span class="bp">self</span><span class="o">.</span><span class="n">column_mapping</span> <span class="o">=</span> <span class="n">column_mapping</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">partition_clause</span> <span class="o">=</span> <span class="n">partition_clause</span>
         <span class="c1"># OpenLineage needs a valid SQL query with the input/output table(s) to parse</span>
         <span class="bp">self</span><span class="o">.</span><span class="n">sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SELECT * FROM </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="si">}</span><span class="s2">;&quot;</span>
 
-<div class="viewcode-block" id="SQLColumnCheckOperator.execute"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.execute">[docs]</a>    <span class="k">def</span> <span class="nf">execute</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">context</span><span class="o">=</span><span class="kc">None</span><span class="p [...]
+<div class="viewcode-block" id="SQLColumnCheckOperator.execute"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator.execute">[docs]</a>    <span class="k">def</span> <span class="nf">execute</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">context</span><span class="p">:</span> <span class="s1">&#39;Context&#39;</span> [...]
         <span class="n">hook</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_db_hook</span><span class="p">()</span>
         <span class="n">failed_tests</span> <span class="o">=</span> <span class="p">[]</span>
         <span class="k">for</span> <span class="n">column</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">column_mapping</span><span class="p">:</span>
             <span class="n">checks</span> <span class="o">=</span> <span class="p">[</span><span class="o">*</span><span class="bp">self</span><span class="o">.</span><span class="n">column_mapping</span><span class="p">[</span><span class="n">column</span><span class="p">]]</span>
             <span class="n">checks_sql</span> <span class="o">=</span> <span class="s2">&quot;,&quot;</span><span class="o">.</span><span class="n">join</span><span class="p">([</span><span class="bp">self</span><span class="o">.</span><span class="n">column_checks</span><span class="p">[</span><span class="n">check</span><span class="p">]</span><span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">&quot;column&quot;</span><span class="p">,</span> [...]
-
-            <span class="bp">self</span><span class="o">.</span><span class="n">sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SELECT </span><span class="si">{</span><span class="n">checks_sql</span><span class="si">}</span><span class="s2"> FROM </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="si">}</span><span class="s2">;&quot;</span>
+            <span class="n">partition_clause_statement</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;WHERE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">partition_clause</span><span class="si">}</span><span class="s2">&quot;</span> <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">partition_clause</span> <span class="k">else</span> <span class="s2">&quot;&qu [...]
+            <span class="bp">self</span><span class="o">.</span><span class="n">sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SELECT </span><span class="si">{</span><span class="n">checks_sql</span><span class="si">}</span><span class="s2"> FROM </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="si">}</span><span class="s2"> </span><span class="si">{</span><span class="n">parti [...]
             <span class="n">records</span> <span class="o">=</span> <span class="n">hook</span><span class="o">.</span><span class="n">get_first</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">)</span>
 
             <span class="k">if</span> <span class="ow">not</span> <span class="n">records</span><span class="p">:</span>
@@ -720,10 +801,10 @@
                     <span class="bp">self</span><span class="o">.</span><span class="n">column_mapping</span><span class="p">[</span><span class="n">column</span><span class="p">][</span><span class="n">checks</span><span class="p">[</span><span class="n">idx</span><span class="p">]],</span> <span class="n">result</span><span class="p">,</span> <span class="n">tolerance</span>
                 <span class="p">)</span>
 
-            <span class="n">failed_tests</span><span class="o">.</span><span class="n">extend</span><span class="p">(</span><span class="n">_get_failed_tests</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">column_mapping</span><span class="p">[</span><span class="n">column</span><span class="p">]))</span>
+            <span class="n">failed_tests</span><span class="o">.</span><span class="n">extend</span><span class="p">(</span><span class="n">_get_failed_checks</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">column_mapping</span><span class="p">[</span><span class="n">column</span><span class="p">],</span> <span class="n">column</span><span class="p">))</span>
         <span class="k">if</span> <span class="n">failed_tests</span><span class="p">:</span>
             <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span>
-                <span class="sa">f</span><span class="s2">&quot;Test failed.</span><span class="se">\n</span><span class="s2">Query:</span><span class="se">\n</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="si">}</span><span class="se">\n</span><span class="s2">Results:</span><span class="se">\n</span><span class="si">{</span><span class="n">records</span><span class="si">!s}</span><span class="se">\n</span><span c [...]
+                <span class="sa">f</span><span class="s2">&quot;Test failed.</span><span class="se">\n</span><span class="s2">Results:</span><span class="se">\n</span><span class="si">{</span><span class="n">records</span><span class="si">!s}</span><span class="se">\n</span><span class="s2">&quot;</span>
                 <span class="s2">&quot;The following tests have failed:&quot;</span>
                 <span class="sa">f</span><span class="s2">&quot;</span><span class="se">\n</span><span class="si">{</span><span class="s1">&#39;&#39;</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">failed_tests</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
             <span class="p">)</span>
@@ -838,6 +919,14 @@
 <span class="sd">            &quot;column_sum_check&quot;: {&quot;check_statement&quot;: &quot;col_a + col_b &lt; col_c&quot;},</span>
 <span class="sd">        }</span>
 
+
+<span class="sd">    :param partition_clause: a partial SQL statement that is added to a WHERE clause in the query built by</span>
+<span class="sd">        the operator that creates partition_clauses for the checks to run on, e.g.</span>
+
+<span class="sd">    .. code-block:: python</span>
+
+<span class="sd">        &quot;date = &#39;1970-01-01&#39;&quot;</span>
+
 <span class="sd">    :param conn_id: the connection ID used to connect to the database</span>
 <span class="sd">    :param database: name of database which overwrite the defined one in connection</span>
 
@@ -846,14 +935,19 @@
 <span class="sd">        :ref:`howto/operator:SQLTableCheckOperator`</span>
 <span class="sd">    &quot;&quot;&quot;</span>
 
-<div class="viewcode-block" id="SQLTableCheckOperator.sql_check_template"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.sql_check_template">[docs]</a>    <span class="n">sql_check_template</span> <span class="o">=</span> <span class="s2">&quot;CASE WHEN check_statement THEN 1 ELSE 0 END AS check_name&quot;</span></div>
-<div class="viewcode-block" id="SQLTableCheckOperator.sql_min_template"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.sql_min_template">[docs]</a>    <span class="n">sql_min_template</span> <span class="o">=</span> <span class="s2">&quot;MIN(check_name)&quot;</span></div>
+<div class="viewcode-block" id="SQLTableCheckOperator.template_fields"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.template_fields">[docs]</a>    <span class="n">template_fields</span> <span class="o">=</span> <span class="p">(</span><span class="s2">&quot;partition_clause&quot;</span><span class="p">,)</span></div>
+
+<div class="viewcode-block" id="SQLTableCheckOperator.sql_check_template"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.sql_check_template">[docs]</a>    <span class="n">sql_check_template</span> <span class="o">=</span> <span class="s2">&quot;&quot;&quot;</span>
+<span class="s2">        SELECT &#39;_check_name&#39; AS check_name, MIN(_check_name) AS check_result</span>
+<span class="s2">        FROM(SELECT CASE WHEN check_statement THEN 1 ELSE 0 END AS _check_name FROM table)</span>
+<span class="s2">    &quot;&quot;&quot;</span></div>
 
     <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span>
         <span class="bp">self</span><span class="p">,</span>
         <span class="o">*</span><span class="p">,</span>
         <span class="n">table</span><span class="p">:</span> <span class="nb">str</span><span class="p">,</span>
         <span class="n">checks</span><span class="p">:</span> <span class="n">Dict</span><span class="p">[</span><span class="nb">str</span><span class="p">,</span> <span class="n">Dict</span><span class="p">[</span><span class="nb">str</span><span class="p">,</span> <span class="n">Any</span><span class="p">]],</span>
+        <span class="n">partition_clause</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
         <span class="n">conn_id</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
         <span class="n">database</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
         <span class="o">**</span><span class="n">kwargs</span><span class="p">,</span>
@@ -862,38 +956,38 @@
 
         <span class="bp">self</span><span class="o">.</span><span class="n">table</span> <span class="o">=</span> <span class="n">table</span>
         <span class="bp">self</span><span class="o">.</span><span class="n">checks</span> <span class="o">=</span> <span class="n">checks</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">partition_clause</span> <span class="o">=</span> <span class="n">partition_clause</span>
         <span class="c1"># OpenLineage needs a valid SQL query with the input/output table(s) to parse</span>
         <span class="bp">self</span><span class="o">.</span><span class="n">sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SELECT * FROM </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="si">}</span><span class="s2">;&quot;</span>
 
-<div class="viewcode-block" id="SQLTableCheckOperator.execute"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.execute">[docs]</a>    <span class="k">def</span> <span class="nf">execute</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">context</span><span class="o">=</span><span class="kc">None</span><span class="p"> [...]
+<div class="viewcode-block" id="SQLTableCheckOperator.execute"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLTableCheckOperator.execute">[docs]</a>    <span class="k">def</span> <span class="nf">execute</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">context</span><span class="p">:</span> <span class="s1">&#39;Context&#39;</span><s [...]
         <span class="n">hook</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_db_hook</span><span class="p">()</span>
-
-        <span class="n">check_names</span> <span class="o">=</span> <span class="p">[</span><span class="o">*</span><span class="bp">self</span><span class="o">.</span><span class="n">checks</span><span class="p">]</span>
-        <span class="n">check_mins_sql</span> <span class="o">=</span> <span class="s2">&quot;,&quot;</span><span class="o">.</span><span class="n">join</span><span class="p">(</span>
-            <span class="bp">self</span><span class="o">.</span><span class="n">sql_min_template</span><span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">&quot;check_name&quot;</span><span class="p">,</span> <span class="n">check_name</span><span class="p">)</span> <span class="k">for</span> <span class="n">check_name</span> <span class="ow">in</span> <span class="n">check_names</span>
-        <span class="p">)</span>
-        <span class="n">checks_sql</span> <span class="o">=</span> <span class="s2">&quot;,&quot;</span><span class="o">.</span><span class="n">join</span><span class="p">(</span>
+        <span class="n">checks_sql</span> <span class="o">=</span> <span class="s2">&quot; UNION ALL &quot;</span><span class="o">.</span><span class="n">join</span><span class="p">(</span>
             <span class="p">[</span>
-                <span class="bp">self</span><span class="o">.</span><span class="n">sql_check_template</span><span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">&quot;check_statement&quot;</span><span class="p">,</span> <span class="n">value</span><span class="p">[</span><span class="s2">&quot;check_statement&quot;</span><span class="p">])</span><span class="o">.</span><span class="n">replace</span><span class="p">(</span>
-                    <span class="s2">&quot;check_name&quot;</span><span class="p">,</span> <span class="n">check_name</span>
-                <span class="p">)</span>
+                <span class="bp">self</span><span class="o">.</span><span class="n">sql_check_template</span><span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">&quot;check_statement&quot;</span><span class="p">,</span> <span class="n">value</span><span class="p">[</span><span class="s2">&quot;check_statement&quot;</span><span class="p">])</span>
+                <span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">&quot;_check_name&quot;</span><span class="p">,</span> <span class="n">check_name</span><span class="p">)</span>
+                <span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">&quot;table&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="p">)</span>
                 <span class="k">for</span> <span class="n">check_name</span><span class="p">,</span> <span class="n">value</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">checks</span><span class="o">.</span><span class="n">items</span><span class="p">()</span>
             <span class="p">]</span>
         <span class="p">)</span>
+        <span class="n">partition_clause_statement</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;WHERE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">partition_clause</span><span class="si">}</span><span class="s2">&quot;</span> <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">partition_clause</span> <span class="k">else</span> <span class="s2">&quot;&quot;</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SELECT check_name, check_result FROM (</span><span class="si">{</span><span class="n">checks_sql</span><span class="si">}</span><span class="s2">) &quot;</span>
+        <span class="sa">f</span><span class="s2">&quot;AS check_table </span><span class="si">{</span><span class="n">partition_clause_statement</span><span class="si">}</span><span class="s2">;&quot;</span>
 
-        <span class="bp">self</span><span class="o">.</span><span class="n">sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SELECT </span><span class="si">{</span><span class="n">check_mins_sql</span><span class="si">}</span><span class="s2"> FROM (SELECT </span><span class="si">{</span><span class="n">checks_sql</span><span class="si">}</span><span class="s2"> FROM </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><sp [...]
-        <span class="n">records</span> <span class="o">=</span> <span class="n">hook</span><span class="o">.</span><span class="n">get_first</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">)</span>
+        <span class="n">records</span> <span class="o">=</span> <span class="n">hook</span><span class="o">.</span><span class="n">get_pandas_df</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">)</span>
 
-        <span class="k">if</span> <span class="ow">not</span> <span class="n">records</span><span class="p">:</span>
+        <span class="k">if</span> <span class="n">records</span><span class="o">.</span><span class="n">empty</span><span class="p">:</span>
             <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;The following query returned zero rows: </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">)</span>
 
-        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Record: </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="n">records</span><span class="p">)</span>
+        <span class="n">records</span><span class="o">.</span><span class="n">columns</span> <span class="o">=</span> <span class="n">records</span><span class="o">.</span><span class="n">columns</span><span class="o">.</span><span class="n">str</span><span class="o">.</span><span class="n">lower</span><span class="p">()</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Record:</span><span class="se">\n</span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="n">records</span><span class="p">)</span>
 
-        <span class="k">for</span> <span class="n">check</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">checks</span><span class="o">.</span><span class="n">keys</span><span class="p">():</span>
-            <span class="k">for</span> <span class="n">result</span> <span class="ow">in</span> <span class="n">records</span><span class="p">:</span>
-                <span class="bp">self</span><span class="o">.</span><span class="n">checks</span><span class="p">[</span><span class="n">check</span><span class="p">][</span><span class="s2">&quot;success&quot;</span><span class="p">]</span> <span class="o">=</span> <span class="n">parse_boolean</span><span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="n">result</span><span class="p">))</span>
+        <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">records</span><span class="o">.</span><span class="n">iterrows</span><span class="p">():</span>
+            <span class="n">check</span> <span class="o">=</span> <span class="n">row</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;check_name&quot;</span><span class="p">)</span>
+            <span class="n">result</span> <span class="o">=</span> <span class="n">row</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;check_result&quot;</span><span class="p">)</span>
+            <span class="bp">self</span><span class="o">.</span><span class="n">checks</span><span class="p">[</span><span class="n">check</span><span class="p">][</span><span class="s2">&quot;success&quot;</span><span class="p">]</span> <span class="o">=</span> <span class="n">parse_boolean</span><span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="n">result</span><span class="p">))</span>
 
-        <span class="n">failed_tests</span> <span class="o">=</span> <span class="n">_get_failed_tests</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">checks</span><span class="p">)</span>
+        <span class="n">failed_tests</span> <span class="o">=</span> <span class="n">_get_failed_checks</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">checks</span><span class="p">)</span>
         <span class="k">if</span> <span class="n">failed_tests</span><span class="p">:</span>
             <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span>
                 <span class="sa">f</span><span class="s2">&quot;Test failed.</span><span class="se">\n</span><span class="s2">Query:</span><span class="se">\n</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="si">}</span><span class="se">\n</span><span class="s2">Results:</span><span class="se">\n</span><span class="si">{</span><span class="n">records</span><span class="si">!s}</span><span class="se">\n</span><span c [...]
@@ -902,6 +996,484 @@
             <span class="p">)</span>
 
         <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;All tests have passed&quot;</span><span class="p">)</span></div></div>
+
+
+<div class="viewcode-block" id="SQLCheckOperator"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLCheckOperator">[docs]</a><span class="k">class</span> <span class="nc">SQLCheckOperator</span><span class="p">(</span><span class="n">BaseSQLOperator</span><span class="p">):</span>
+    <span class="sd">&quot;&quot;&quot;</span>
+<span class="sd">    Performs checks against a db. The ``SQLCheckOperator`` expects</span>
+<span class="sd">    a sql query that will return a single row. Each value on that</span>
+<span class="sd">    first row is evaluated using python ``bool`` casting. If any of the</span>
+<span class="sd">    values return ``False`` the check is failed and errors out.</span>
+
+<span class="sd">    Note that Python bool casting evals the following as ``False``:</span>
+
+<span class="sd">    * ``False``</span>
+<span class="sd">    * ``0``</span>
+<span class="sd">    * Empty string (``&quot;&quot;``)</span>
+<span class="sd">    * Empty list (``[]``)</span>
+<span class="sd">    * Empty dictionary or set (``{}``)</span>
+
+<span class="sd">    Given a query like ``SELECT COUNT(*) FROM foo``, it will fail only if</span>
+<span class="sd">    the count ``== 0``. You can craft much more complex query that could,</span>
+<span class="sd">    for instance, check that the table has the same number of rows as</span>
+<span class="sd">    the source table upstream, or that the count of today&#39;s partition is</span>
+<span class="sd">    greater than yesterday&#39;s partition, or that a set of metrics are less</span>
+<span class="sd">    than 3 standard deviation for the 7 day average.</span>
+
+<span class="sd">    This operator can be used as a data quality check in your pipeline, and</span>
+<span class="sd">    depending on where you put it in your DAG, you have the choice to</span>
+<span class="sd">    stop the critical path, preventing from</span>
+<span class="sd">    publishing dubious data, or on the side and receive email alerts</span>
+<span class="sd">    without stopping the progress of the DAG.</span>
+
+<span class="sd">    :param sql: the sql to be executed. (templated)</span>
+<span class="sd">    :param conn_id: the connection ID used to connect to the database.</span>
+<span class="sd">    :param database: name of database which overwrite the defined one in connection</span>
+<span class="sd">    &quot;&quot;&quot;</span>
+
+<div class="viewcode-block" id="SQLCheckOperator.template_fields"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLCheckOperator.template_fields">[docs]</a>    <span class="n">template_fields</span><span class="p">:</span> <span class="n">Sequence</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="p">(</span><span cl [...]
+<div class="viewcode-block" id="SQLCheckOperator.template_ext"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLCheckOperator.template_ext">[docs]</a>    <span class="n">template_ext</span><span class="p">:</span> <span class="n">Sequence</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="p">(</span>
+        <span class="s2">&quot;.hql&quot;</span><span class="p">,</span>
+        <span class="s2">&quot;.sql&quot;</span><span class="p">,</span></div>
+    <span class="p">)</span>
+<div class="viewcode-block" id="SQLCheckOperator.template_fields_renderers"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLCheckOperator.template_fields_renderers">[docs]</a>    <span class="n">template_fields_renderers</span> <span class="o">=</span> <span class="p">{</span><span class="s2">&quot;sql&quot;</span><span class="p">:</span> <span class="s2">&quot;sql&quot;</span><span  [...]
+<div class="viewcode-block" id="SQLCheckOperator.ui_color"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLCheckOperator.ui_color">[docs]</a>    <span class="n">ui_color</span> <span class="o">=</span> <span class="s2">&quot;#fff7e6&quot;</span></div>
+
+    <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span>
+        <span class="bp">self</span><span class="p">,</span> <span class="o">*</span><span class="p">,</span> <span class="n">sql</span><span class="p">:</span> <span class="nb">str</span><span class="p">,</span> <span class="n">conn_id</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span> <span class="n">database</span><span cl [...]
+    <span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
+        <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="fm">__init__</span><span class="p">(</span><span class="n">conn_id</span><span class="o">=</span><span class="n">conn_id</span><span class="p">,</span> <span class="n">database</span><span class="o">=</span><span class="n">database</span><span class="p">,</span> <span class="o">**</span><span class="n">kwargs</span><span class="p">)</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">sql</span> <span class="o">=</span> <span class="n">sql</span>
+
+<div class="viewcode-block" id="SQLCheckOperator.execute"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLCheckOperator.execute">[docs]</a>    <span class="k">def</span> <span class="nf">execute</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">context</span><span class="p">:</span> <span class="s1">&#39;Context&#39;</span><span class= [...]
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Executing SQL check: </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">)</span>
+        <span class="n">records</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_db_hook</span><span class="p">()</span><span class="o">.</span><span class="n">get_first</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">)</span>
+
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Record: </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="n">records</span><span class="p">)</span>
+        <span class="k">if</span> <span class="ow">not</span> <span class="n">records</span><span class="p">:</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span><span class="s2">&quot;The query returned None&quot;</span><span class="p">)</span>
+        <span class="k">elif</span> <span class="ow">not</span> <span class="nb">all</span><span class="p">(</span><span class="nb">bool</span><span class="p">(</span><span class="n">r</span><span class="p">)</span> <span class="k">for</span> <span class="n">r</span> <span class="ow">in</span> <span class="n">records</span><span class="p">):</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Test failed.</span><span class="se">\n</span><span class="s2">Query:</span><span class="se">\n</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="si">}</span><span class="se">\n</span><span class="s2">Results:</span><span class="se">\n</span><span class="si">{</span><s [...]
+
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Success.&quot;</span><span class="p">)</span></div></div>
+
+
+<div class="viewcode-block" id="SQLValueCheckOperator"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator">[docs]</a><span class="k">class</span> <span class="nc">SQLValueCheckOperator</span><span class="p">(</span><span class="n">BaseSQLOperator</span><span class="p">):</span>
+    <span class="sd">&quot;&quot;&quot;</span>
+<span class="sd">    Performs a simple value check using sql code.</span>
+
+<span class="sd">    :param sql: the sql to be executed. (templated)</span>
+<span class="sd">    :param conn_id: the connection ID used to connect to the database.</span>
+<span class="sd">    :param database: name of database which overwrite the defined one in connection</span>
+<span class="sd">    &quot;&quot;&quot;</span>
+
+<div class="viewcode-block" id="SQLValueCheckOperator.__mapper_args__"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.__mapper_args__">[docs]</a>    <span class="n">__mapper_args__</span> <span class="o">=</span> <span class="p">{</span><span class="s2">&quot;polymorphic_identity&quot;</span><span class="p">:</span> <span class="s2">&quot;SQLValueCheckOperator&quo [...]
+<div class="viewcode-block" id="SQLValueCheckOperator.template_fields"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.template_fields">[docs]</a>    <span class="n">template_fields</span><span class="p">:</span> <span class="n">Sequence</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="p">(</span>
+        <span class="s2">&quot;sql&quot;</span><span class="p">,</span>
+        <span class="s2">&quot;pass_value&quot;</span><span class="p">,</span></div>
+    <span class="p">)</span>
+<div class="viewcode-block" id="SQLValueCheckOperator.template_ext"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.template_ext">[docs]</a>    <span class="n">template_ext</span><span class="p">:</span> <span class="n">Sequence</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="p">(</span>
+        <span class="s2">&quot;.hql&quot;</span><span class="p">,</span>
+        <span class="s2">&quot;.sql&quot;</span><span class="p">,</span></div>
+    <span class="p">)</span>
+<div class="viewcode-block" id="SQLValueCheckOperator.template_fields_renderers"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.template_fields_renderers">[docs]</a>    <span class="n">template_fields_renderers</span> <span class="o">=</span> <span class="p">{</span><span class="s2">&quot;sql&quot;</span><span class="p">:</span> <span class="s2">&quot;sql&quot;</s [...]
+<div class="viewcode-block" id="SQLValueCheckOperator.ui_color"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.ui_color">[docs]</a>    <span class="n">ui_color</span> <span class="o">=</span> <span class="s2">&quot;#fff7e6&quot;</span></div>
+
+    <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span>
+        <span class="bp">self</span><span class="p">,</span>
+        <span class="o">*</span><span class="p">,</span>
+        <span class="n">sql</span><span class="p">:</span> <span class="nb">str</span><span class="p">,</span>
+        <span class="n">pass_value</span><span class="p">:</span> <span class="n">Any</span><span class="p">,</span>
+        <span class="n">tolerance</span><span class="p">:</span> <span class="n">Any</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="n">conn_id</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="n">database</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="o">**</span><span class="n">kwargs</span><span class="p">,</span>
+    <span class="p">):</span>
+        <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="fm">__init__</span><span class="p">(</span><span class="n">conn_id</span><span class="o">=</span><span class="n">conn_id</span><span class="p">,</span> <span class="n">database</span><span class="o">=</span><span class="n">database</span><span class="p">,</span> <span class="o">**</span><span class="n">kwargs</span><span class="p">)</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">sql</span> <span class="o">=</span> <span class="n">sql</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">pass_value</span> <span class="o">=</span> <span class="nb">str</span><span class="p">(</span><span class="n">pass_value</span><span class="p">)</span>
+        <span class="n">tol</span> <span class="o">=</span> <span class="n">_convert_to_float_if_possible</span><span class="p">(</span><span class="n">tolerance</span><span class="p">)</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">tol</span> <span class="o">=</span> <span class="n">tol</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">tol</span><span class="p">,</span> <span class="nb">float</span><span class="p">)</span> <span class="k">else</span> <span class="kc">None</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">has_tolerance</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">tol</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span>
+
+<div class="viewcode-block" id="SQLValueCheckOperator.execute"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLValueCheckOperator.execute">[docs]</a>    <span class="k">def</span> <span class="nf">execute</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">context</span><span class="p">:</span> <span class="s1">&#39;Context&#39;</span><s [...]
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Executing SQL check: </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">)</span>
+        <span class="n">records</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_db_hook</span><span class="p">()</span><span class="o">.</span><span class="n">get_first</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">)</span>
+
+        <span class="k">if</span> <span class="ow">not</span> <span class="n">records</span><span class="p">:</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span><span class="s2">&quot;The query returned None&quot;</span><span class="p">)</span>
+
+        <span class="n">pass_value_conv</span> <span class="o">=</span> <span class="n">_convert_to_float_if_possible</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">pass_value</span><span class="p">)</span>
+        <span class="n">is_numeric_value_check</span> <span class="o">=</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">pass_value_conv</span><span class="p">,</span> <span class="nb">float</span><span class="p">)</span>
+
+        <span class="n">tolerance_pct_str</span> <span class="o">=</span> <span class="nb">str</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">tol</span> <span class="o">*</span> <span class="mi">100</span><span class="p">)</span> <span class="o">+</span> <span class="s2">&quot;%&quot;</span> <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">tol</span> <span class="ow">is</span> <span class="ow" [...]
+        <span class="n">error_msg</span> <span class="o">=</span> <span class="p">(</span>
+            <span class="s2">&quot;Test failed.</span><span class="se">\n</span><span class="s2">Pass value:</span><span class="si">{pass_value_conv}</span><span class="se">\n</span><span class="s2">&quot;</span>
+            <span class="s2">&quot;Tolerance:</span><span class="si">{tolerance_pct_str}</span><span class="se">\n</span><span class="s2">&quot;</span>
+            <span class="s2">&quot;Query:</span><span class="se">\n</span><span class="si">{sql}</span><span class="se">\n</span><span class="s2">Results:</span><span class="se">\n</span><span class="si">{records!s}</span><span class="s2">&quot;</span>
+        <span class="p">)</span><span class="o">.</span><span class="n">format</span><span class="p">(</span>
+            <span class="n">pass_value_conv</span><span class="o">=</span><span class="n">pass_value_conv</span><span class="p">,</span>
+            <span class="n">tolerance_pct_str</span><span class="o">=</span><span class="n">tolerance_pct_str</span><span class="p">,</span>
+            <span class="n">sql</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">,</span>
+            <span class="n">records</span><span class="o">=</span><span class="n">records</span><span class="p">,</span>
+        <span class="p">)</span>
+
+        <span class="k">if</span> <span class="ow">not</span> <span class="n">is_numeric_value_check</span><span class="p">:</span>
+            <span class="n">tests</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_get_string_matches</span><span class="p">(</span><span class="n">records</span><span class="p">,</span> <span class="n">pass_value_conv</span><span class="p">)</span>
+        <span class="k">elif</span> <span class="n">is_numeric_value_check</span><span class="p">:</span>
+            <span class="k">try</span><span class="p">:</span>
+                <span class="n">numeric_records</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_to_float</span><span class="p">(</span><span class="n">records</span><span class="p">)</span>
+            <span class="k">except</span> <span class="p">(</span><span class="ne">ValueError</span><span class="p">,</span> <span class="ne">TypeError</span><span class="p">):</span>
+                <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Converting a result to float failed.</span><span class="se">\n</span><span class="si">{</span><span class="n">error_msg</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">)</span>
+            <span class="n">tests</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_get_numeric_matches</span><span class="p">(</span><span class="n">numeric_records</span><span class="p">,</span> <span class="n">pass_value_conv</span><span class="p">)</span>
+        <span class="k">else</span><span class="p">:</span>
+            <span class="n">tests</span> <span class="o">=</span> <span class="p">[]</span>
+
+        <span class="k">if</span> <span class="ow">not</span> <span class="nb">all</span><span class="p">(</span><span class="n">tests</span><span class="p">):</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span><span class="n">error_msg</span><span class="p">)</span></div>
+
+    <span class="k">def</span> <span class="nf">_to_float</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">records</span><span class="p">):</span>
+        <span class="k">return</span> <span class="p">[</span><span class="nb">float</span><span class="p">(</span><span class="n">record</span><span class="p">)</span> <span class="k">for</span> <span class="n">record</span> <span class="ow">in</span> <span class="n">records</span><span class="p">]</span>
+
+    <span class="k">def</span> <span class="nf">_get_string_matches</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">records</span><span class="p">,</span> <span class="n">pass_value_conv</span><span class="p">):</span>
+        <span class="k">return</span> <span class="p">[</span><span class="nb">str</span><span class="p">(</span><span class="n">record</span><span class="p">)</span> <span class="o">==</span> <span class="n">pass_value_conv</span> <span class="k">for</span> <span class="n">record</span> <span class="ow">in</span> <span class="n">records</span><span class="p">]</span>
+
+    <span class="k">def</span> <span class="nf">_get_numeric_matches</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">numeric_records</span><span class="p">,</span> <span class="n">numeric_pass_value_conv</span><span class="p">):</span>
+        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">has_tolerance</span><span class="p">:</span>
+            <span class="k">return</span> <span class="p">[</span>
+                <span class="n">numeric_pass_value_conv</span> <span class="o">*</span> <span class="p">(</span><span class="mi">1</span> <span class="o">-</span> <span class="bp">self</span><span class="o">.</span><span class="n">tol</span><span class="p">)</span> <span class="o">&lt;=</span> <span class="n">record</span> <span class="o">&lt;=</span> <span class="n">numeric_pass_value_conv</span> <span class="o">*</span> <span class="p">(</span><span class="mi">1</span> <span class="o"> [...]
+                <span class="k">for</span> <span class="n">record</span> <span class="ow">in</span> <span class="n">numeric_records</span>
+            <span class="p">]</span>
+
+        <span class="k">return</span> <span class="p">[</span><span class="n">record</span> <span class="o">==</span> <span class="n">numeric_pass_value_conv</span> <span class="k">for</span> <span class="n">record</span> <span class="ow">in</span> <span class="n">numeric_records</span><span class="p">]</span></div>
+
+
+<div class="viewcode-block" id="SQLIntervalCheckOperator"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator">[docs]</a><span class="k">class</span> <span class="nc">SQLIntervalCheckOperator</span><span class="p">(</span><span class="n">BaseSQLOperator</span><span class="p">):</span>
+    <span class="sd">&quot;&quot;&quot;</span>
+<span class="sd">    Checks that the values of metrics given as SQL expressions are within</span>
+<span class="sd">    a certain tolerance of the ones from days_back before.</span>
+
+<span class="sd">    :param table: the table name</span>
+<span class="sd">    :param conn_id: the connection ID used to connect to the database.</span>
+<span class="sd">    :param database: name of database which will overwrite the defined one in connection</span>
+<span class="sd">    :param days_back: number of days between ds and the ds we want to check</span>
+<span class="sd">        against. Defaults to 7 days</span>
+<span class="sd">    :param date_filter_column: The column name for the dates to filter on. Defaults to &#39;ds&#39;</span>
+<span class="sd">    :param ratio_formula: which formula to use to compute the ratio between</span>
+<span class="sd">        the two metrics. Assuming cur is the metric of today and ref is</span>
+<span class="sd">        the metric to today - days_back.</span>
+
+<span class="sd">        max_over_min: computes max(cur, ref) / min(cur, ref)</span>
+<span class="sd">        relative_diff: computes abs(cur-ref) / ref</span>
+
+<span class="sd">        Default: &#39;max_over_min&#39;</span>
+<span class="sd">    :param ignore_zero: whether we should ignore zero metrics</span>
+<span class="sd">    :param metrics_thresholds: a dictionary of ratios indexed by metrics</span>
+<span class="sd">    &quot;&quot;&quot;</span>
+
+<div class="viewcode-block" id="SQLIntervalCheckOperator.__mapper_args__"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.__mapper_args__">[docs]</a>    <span class="n">__mapper_args__</span> <span class="o">=</span> <span class="p">{</span><span class="s2">&quot;polymorphic_identity&quot;</span><span class="p">:</span> <span class="s2">&quot;SQLIntervalCheckOpe [...]
+<div class="viewcode-block" id="SQLIntervalCheckOperator.template_fields"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.template_fields">[docs]</a>    <span class="n">template_fields</span><span class="p">:</span> <span class="n">Sequence</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="p"> [...]
+<div class="viewcode-block" id="SQLIntervalCheckOperator.template_ext"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.template_ext">[docs]</a>    <span class="n">template_ext</span><span class="p">:</span> <span class="n">Sequence</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="p">(</span>
+        <span class="s2">&quot;.hql&quot;</span><span class="p">,</span>
+        <span class="s2">&quot;.sql&quot;</span><span class="p">,</span></div>
+    <span class="p">)</span>
+<div class="viewcode-block" id="SQLIntervalCheckOperator.template_fields_renderers"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.template_fields_renderers">[docs]</a>    <span class="n">template_fields_renderers</span> <span class="o">=</span> <span class="p">{</span><span class="s2">&quot;sql1&quot;</span><span class="p">:</span> <span class="s2">&quot;sql&q [...]
+<div class="viewcode-block" id="SQLIntervalCheckOperator.ui_color"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.ui_color">[docs]</a>    <span class="n">ui_color</span> <span class="o">=</span> <span class="s2">&quot;#fff7e6&quot;</span></div>
+
+<div class="viewcode-block" id="SQLIntervalCheckOperator.ratio_formulas"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.ratio_formulas">[docs]</a>    <span class="n">ratio_formulas</span> <span class="o">=</span> <span class="p">{</span>
+        <span class="s2">&quot;max_over_min&quot;</span><span class="p">:</span> <span class="k">lambda</span> <span class="n">cur</span><span class="p">,</span> <span class="n">ref</span><span class="p">:</span> <span class="nb">float</span><span class="p">(</span><span class="nb">max</span><span class="p">(</span><span class="n">cur</span><span class="p">,</span> <span class="n">ref</span><span class="p">))</span> <span class="o">/</span> <span class="nb">min</span><span class="p">(</s [...]
+        <span class="s2">&quot;relative_diff&quot;</span><span class="p">:</span> <span class="k">lambda</span> <span class="n">cur</span><span class="p">,</span> <span class="n">ref</span><span class="p">:</span> <span class="nb">float</span><span class="p">(</span><span class="nb">abs</span><span class="p">(</span><span class="n">cur</span> <span class="o">-</span> <span class="n">ref</span><span class="p">))</span> <span class="o">/</span> <span class="n">ref</span><span class="p">,</ [...]
+    <span class="p">}</span>
+
+    <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span>
+        <span class="bp">self</span><span class="p">,</span>
+        <span class="o">*</span><span class="p">,</span>
+        <span class="n">table</span><span class="p">:</span> <span class="nb">str</span><span class="p">,</span>
+        <span class="n">metrics_thresholds</span><span class="p">:</span> <span class="n">Dict</span><span class="p">[</span><span class="nb">str</span><span class="p">,</span> <span class="nb">int</span><span class="p">],</span>
+        <span class="n">date_filter_column</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="s2">&quot;ds&quot;</span><span class="p">,</span>
+        <span class="n">days_back</span><span class="p">:</span> <span class="n">SupportsAbs</span><span class="p">[</span><span class="nb">int</span><span class="p">]</span> <span class="o">=</span> <span class="o">-</span><span class="mi">7</span><span class="p">,</span>
+        <span class="n">ratio_formula</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="s2">&quot;max_over_min&quot;</span><span class="p">,</span>
+        <span class="n">ignore_zero</span><span class="p">:</span> <span class="nb">bool</span> <span class="o">=</span> <span class="kc">True</span><span class="p">,</span>
+        <span class="n">conn_id</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="n">database</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="o">**</span><span class="n">kwargs</span><span class="p">,</span>
+    <span class="p">):</span>
+        <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="fm">__init__</span><span class="p">(</span><span class="n">conn_id</span><span class="o">=</span><span class="n">conn_id</span><span class="p">,</span> <span class="n">database</span><span class="o">=</span><span class="n">database</span><span class="p">,</span> <span class="o">**</span><span class="n">kwargs</span><span class="p">)</span>
+        <span class="k">if</span> <span class="n">ratio_formula</span> <span class="ow">not</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">ratio_formulas</span><span class="p">:</span>
+            <span class="n">msg_template</span> <span class="o">=</span> <span class="s2">&quot;Invalid diff_method: </span><span class="si">{diff_method}</span><span class="s2">. Supported diff methods are: </span><span class="si">{diff_methods}</span><span class="s2">&quot;</span>
+
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span>
+                <span class="n">msg_template</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">diff_method</span><span class="o">=</span><span class="n">ratio_formula</span><span class="p">,</span> <span class="n">diff_methods</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">ratio_formulas</span><span class="p">)</span>
+            <span class="p">)</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">ratio_formula</span> <span class="o">=</span> <span class="n">ratio_formula</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">ignore_zero</span> <span class="o">=</span> <span class="n">ignore_zero</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">table</span> <span class="o">=</span> <span class="n">table</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">metrics_thresholds</span> <span class="o">=</span> <span class="n">metrics_thresholds</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">metrics_sorted</span> <span class="o">=</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">metrics_thresholds</span><span class="o">.</span><span class="n">keys</span><span class="p">())</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">date_filter_column</span> <span class="o">=</span> <span class="n">date_filter_column</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">days_back</span> <span class="o">=</span> <span class="o">-</span><span class="nb">abs</span><span class="p">(</span><span class="n">days_back</span><span class="p">)</span>
+        <span class="n">sqlexp</span> <span class="o">=</span> <span class="s2">&quot;, &quot;</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">metrics_sorted</span><span class="p">)</span>
+        <span class="n">sqlt</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SELECT </span><span class="si">{</span><span class="n">sqlexp</span><span class="si">}</span><span class="s2"> FROM </span><span class="si">{</span><span class="n">table</span><span class="si">}</span><span class="s2"> WHERE </span><span class="si">{</span><span class="n">date_filter_column</span><span class="si">}</span><span class="s2">=&quot;</span>
+
+        <span class="bp">self</span><span class="o">.</span><span class="n">sql1</span> <span class="o">=</span> <span class="n">sqlt</span> <span class="o">+</span> <span class="s2">&quot;&#39;{{ ds }}&#39;&quot;</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">sql2</span> <span class="o">=</span> <span class="n">sqlt</span> <span class="o">+</span> <span class="s2">&quot;&#39;{{ macros.ds_add(ds, &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">days_back</span><span class="p">)</span> <span class="o">+</span> <span class="s2">&quot;) }}&#39;&quot;</span>
+
+<div class="viewcode-block" id="SQLIntervalCheckOperator.execute"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator.execute">[docs]</a>    <span class="k">def</span> <span class="nf">execute</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">context</span><span class="p">:</span> <span class="s1">&#39;Context&#39;</s [...]
+        <span class="n">hook</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_db_hook</span><span class="p">()</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Using ratio formula: </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">ratio_formula</span><span class="p">)</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Executing SQL check: </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql2</span><span class="p">)</span>
+        <span class="n">row2</span> <span class="o">=</span> <span class="n">hook</span><span class="o">.</span><span class="n">get_first</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">sql2</span><span class="p">)</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Executing SQL check: </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql1</span><span class="p">)</span>
+        <span class="n">row1</span> <span class="o">=</span> <span class="n">hook</span><span class="o">.</span><span class="n">get_first</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">sql1</span><span class="p">)</span>
+
+        <span class="k">if</span> <span class="ow">not</span> <span class="n">row2</span><span class="p">:</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;The query </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql2</span><span class="si">}</span><span class="s2"> returned None&quot;</span><span class="p">)</span>
+        <span class="k">if</span> <span class="ow">not</span> <span class="n">row1</span><span class="p">:</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;The query </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql1</span><span class="si">}</span><span class="s2"> returned None&quot;</span><span class="p">)</span>
+
+        <span class="n">current</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">(</span><span class="nb">zip</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">metrics_sorted</span><span class="p">,</span> <span class="n">row1</span><span class="p">))</span>
+        <span class="n">reference</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">(</span><span class="nb">zip</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">metrics_sorted</span><span class="p">,</span> <span class="n">row2</span><span class="p">))</span>
+
+        <span class="n">ratios</span><span class="p">:</span> <span class="n">Dict</span><span class="p">[</span><span class="nb">str</span><span class="p">,</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">int</span><span class="p">]]</span> <span class="o">=</span> <span class="p">{}</span>
+        <span class="n">test_results</span> <span class="o">=</span> <span class="p">{}</span>
+
+        <span class="k">for</span> <span class="n">metric</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">metrics_sorted</span><span class="p">:</span>
+            <span class="n">cur</span> <span class="o">=</span> <span class="n">current</span><span class="p">[</span><span class="n">metric</span><span class="p">]</span>
+            <span class="n">ref</span> <span class="o">=</span> <span class="n">reference</span><span class="p">[</span><span class="n">metric</span><span class="p">]</span>
+            <span class="n">threshold</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">metrics_thresholds</span><span class="p">[</span><span class="n">metric</span><span class="p">]</span>
+            <span class="k">if</span> <span class="n">cur</span> <span class="o">==</span> <span class="mi">0</span> <span class="ow">or</span> <span class="n">ref</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
+                <span class="n">ratios</span><span class="p">[</span><span class="n">metric</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span>
+                <span class="n">test_results</span><span class="p">[</span><span class="n">metric</span><span class="p">]</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">ignore_zero</span>
+            <span class="k">else</span><span class="p">:</span>
+                <span class="n">ratio_metric</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">ratio_formulas</span><span class="p">[</span><span class="bp">self</span><span class="o">.</span><span class="n">ratio_formula</span><span class="p">](</span><span class="n">current</span><span class="p">[</span><span class="n">metric</span><span class="p">],</span> <span class="n">reference</span><span class="p">[</span><span class="n">metric</ [...]
+                <span class="n">ratios</span><span class="p">[</span><span class="n">metric</span><span class="p">]</span> <span class="o">=</span> <span class="n">ratio_metric</span>
+                <span class="k">if</span> <span class="n">ratio_metric</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
+                    <span class="n">test_results</span><span class="p">[</span><span class="n">metric</span><span class="p">]</span> <span class="o">=</span> <span class="n">ratio_metric</span> <span class="o">&lt;</span> <span class="n">threshold</span>
+                <span class="k">else</span><span class="p">:</span>
+                    <span class="n">test_results</span><span class="p">[</span><span class="n">metric</span><span class="p">]</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">ignore_zero</span>
+
+            <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span>
+                <span class="p">(</span>
+                    <span class="s2">&quot;Current metric for </span><span class="si">%s</span><span class="s2">: </span><span class="si">%s</span><span class="se">\n</span><span class="s2">&quot;</span>
+                    <span class="s2">&quot;Past metric for </span><span class="si">%s</span><span class="s2">: </span><span class="si">%s</span><span class="se">\n</span><span class="s2">&quot;</span>
+                    <span class="s2">&quot;Ratio for </span><span class="si">%s</span><span class="s2">: </span><span class="si">%s</span><span class="se">\n</span><span class="s2">&quot;</span>
+                    <span class="s2">&quot;Threshold: </span><span class="si">%s</span><span class="se">\n</span><span class="s2">&quot;</span>
+                <span class="p">),</span>
+                <span class="n">metric</span><span class="p">,</span>
+                <span class="n">cur</span><span class="p">,</span>
+                <span class="n">metric</span><span class="p">,</span>
+                <span class="n">ref</span><span class="p">,</span>
+                <span class="n">metric</span><span class="p">,</span>
+                <span class="n">ratios</span><span class="p">[</span><span class="n">metric</span><span class="p">],</span>
+                <span class="n">threshold</span><span class="p">,</span>
+            <span class="p">)</span>
+
+        <span class="k">if</span> <span class="ow">not</span> <span class="nb">all</span><span class="p">(</span><span class="n">test_results</span><span class="o">.</span><span class="n">values</span><span class="p">()):</span>
+            <span class="n">failed_tests</span> <span class="o">=</span> <span class="p">[</span><span class="n">it</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="k">for</span> <span class="n">it</span> <span class="ow">in</span> <span class="n">test_results</span><span class="o">.</span><span class="n">items</span><span class="p">()</span> <span class="k">if</span> <span class="ow">not</span> <span class="n">it</span><span class="p">[</span> [...]
+            <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">warning</span><span class="p">(</span>
+                <span class="s2">&quot;The following </span><span class="si">%s</span><span class="s2"> tests out of </span><span class="si">%s</span><span class="s2"> failed:&quot;</span><span class="p">,</span>
+                <span class="nb">len</span><span class="p">(</span><span class="n">failed_tests</span><span class="p">),</span>
+                <span class="nb">len</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">metrics_sorted</span><span class="p">),</span>
+            <span class="p">)</span>
+            <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">failed_tests</span><span class="p">:</span>
+                <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">warning</span><span class="p">(</span>
+                    <span class="s2">&quot;&#39;</span><span class="si">%s</span><span class="s2">&#39; check failed. </span><span class="si">%s</span><span class="s2"> is above </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span>
+                    <span class="n">k</span><span class="p">,</span>
+                    <span class="n">ratios</span><span class="p">[</span><span class="n">k</span><span class="p">],</span>
+                    <span class="bp">self</span><span class="o">.</span><span class="n">metrics_thresholds</span><span class="p">[</span><span class="n">k</span><span class="p">],</span>
+                <span class="p">)</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;The following tests have failed:</span><span class="se">\n</span><span class="s2"> </span><span class="si">{</span><span class="s1">&#39;, &#39;</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="nb">sorted</span><span class="p">(</span><span class="n">failed_tests</span><span class="p">))</span> [...]
+
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;All tests have passed&quot;</span><span class="p">)</span></div></div>
+
+
+<div class="viewcode-block" id="SQLThresholdCheckOperator"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator">[docs]</a><span class="k">class</span> <span class="nc">SQLThresholdCheckOperator</span><span class="p">(</span><span class="n">BaseSQLOperator</span><span class="p">):</span>
+    <span class="sd">&quot;&quot;&quot;</span>
+<span class="sd">    Performs a value check using sql code against a minimum threshold</span>
+<span class="sd">    and a maximum threshold. Thresholds can be in the form of a numeric</span>
+<span class="sd">    value OR a sql statement that results a numeric.</span>
+
+<span class="sd">    :param sql: the sql to be executed. (templated)</span>
+<span class="sd">    :param conn_id: the connection ID used to connect to the database.</span>
+<span class="sd">    :param database: name of database which overwrite the defined one in connection</span>
+<span class="sd">    :param min_threshold: numerical value or min threshold sql to be executed (templated)</span>
+<span class="sd">    :param max_threshold: numerical value or max threshold sql to be executed (templated)</span>
+<span class="sd">    &quot;&quot;&quot;</span>
+
+<div class="viewcode-block" id="SQLThresholdCheckOperator.template_fields"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.template_fields">[docs]</a>    <span class="n">template_fields</span><span class="p">:</span> <span class="n">Sequence</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="p [...]
+<div class="viewcode-block" id="SQLThresholdCheckOperator.template_ext"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.template_ext">[docs]</a>    <span class="n">template_ext</span><span class="p">:</span> <span class="n">Sequence</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="p">(</span>
+        <span class="s2">&quot;.hql&quot;</span><span class="p">,</span>
+        <span class="s2">&quot;.sql&quot;</span><span class="p">,</span></div>
+    <span class="p">)</span>
+<div class="viewcode-block" id="SQLThresholdCheckOperator.template_fields_renderers"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.template_fields_renderers">[docs]</a>    <span class="n">template_fields_renderers</span> <span class="o">=</span> <span class="p">{</span><span class="s2">&quot;sql&quot;</span><span class="p">:</span> <span class="s2">&quot;sql& [...]
+
+    <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span>
+        <span class="bp">self</span><span class="p">,</span>
+        <span class="o">*</span><span class="p">,</span>
+        <span class="n">sql</span><span class="p">:</span> <span class="nb">str</span><span class="p">,</span>
+        <span class="n">min_threshold</span><span class="p">:</span> <span class="n">Any</span><span class="p">,</span>
+        <span class="n">max_threshold</span><span class="p">:</span> <span class="n">Any</span><span class="p">,</span>
+        <span class="n">conn_id</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="n">database</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="o">**</span><span class="n">kwargs</span><span class="p">,</span>
+    <span class="p">):</span>
+        <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="fm">__init__</span><span class="p">(</span><span class="n">conn_id</span><span class="o">=</span><span class="n">conn_id</span><span class="p">,</span> <span class="n">database</span><span class="o">=</span><span class="n">database</span><span class="p">,</span> <span class="o">**</span><span class="n">kwargs</span><span class="p">)</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">sql</span> <span class="o">=</span> <span class="n">sql</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">min_threshold</span> <span class="o">=</span> <span class="n">_convert_to_float_if_possible</span><span class="p">(</span><span class="n">min_threshold</span><span class="p">)</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">max_threshold</span> <span class="o">=</span> <span class="n">_convert_to_float_if_possible</span><span class="p">(</span><span class="n">max_threshold</span><span class="p">)</span>
+
+<div class="viewcode-block" id="SQLThresholdCheckOperator.execute"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.execute">[docs]</a>    <span class="k">def</span> <span class="nf">execute</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">context</span><span class="p">:</span> <span class="s1">&#39;Context&#39;< [...]
+        <span class="n">hook</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_db_hook</span><span class="p">()</span>
+        <span class="n">result</span> <span class="o">=</span> <span class="n">hook</span><span class="o">.</span><span class="n">get_first</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span>
+
+        <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">min_threshold</span><span class="p">,</span> <span class="nb">float</span><span class="p">):</span>
+            <span class="n">lower_bound</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">min_threshold</span>
+        <span class="k">else</span><span class="p">:</span>
+            <span class="n">lower_bound</span> <span class="o">=</span> <span class="n">hook</span><span class="o">.</span><span class="n">get_first</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">min_threshold</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span>
+
+        <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">max_threshold</span><span class="p">,</span> <span class="nb">float</span><span class="p">):</span>
+            <span class="n">upper_bound</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">max_threshold</span>
+        <span class="k">else</span><span class="p">:</span>
+            <span class="n">upper_bound</span> <span class="o">=</span> <span class="n">hook</span><span class="o">.</span><span class="n">get_first</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">max_threshold</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span>
+
+        <span class="n">meta_data</span> <span class="o">=</span> <span class="p">{</span>
+            <span class="s2">&quot;result&quot;</span><span class="p">:</span> <span class="n">result</span><span class="p">,</span>
+            <span class="s2">&quot;task_id&quot;</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">task_id</span><span class="p">,</span>
+            <span class="s2">&quot;min_threshold&quot;</span><span class="p">:</span> <span class="n">lower_bound</span><span class="p">,</span>
+            <span class="s2">&quot;max_threshold&quot;</span><span class="p">:</span> <span class="n">upper_bound</span><span class="p">,</span>
+            <span class="s2">&quot;within_threshold&quot;</span><span class="p">:</span> <span class="n">lower_bound</span> <span class="o">&lt;=</span> <span class="n">result</span> <span class="o">&lt;=</span> <span class="n">upper_bound</span><span class="p">,</span>
+        <span class="p">}</span>
+
+        <span class="bp">self</span><span class="o">.</span><span class="n">push</span><span class="p">(</span><span class="n">meta_data</span><span class="p">)</span>
+        <span class="k">if</span> <span class="ow">not</span> <span class="n">meta_data</span><span class="p">[</span><span class="s2">&quot;within_threshold&quot;</span><span class="p">]:</span>
+            <span class="n">result</span> <span class="o">=</span> <span class="p">(</span>
+                <span class="nb">round</span><span class="p">(</span><span class="n">meta_data</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;result&quot;</span><span class="p">),</span> <span class="mi">2</span><span class="p">)</span>  <span class="c1"># type: ignore[arg-type]</span>
+                <span class="k">if</span> <span class="n">meta_data</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;result&quot;</span><span class="p">)</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span>
+                <span class="k">else</span> <span class="s2">&quot;&lt;None&gt;&quot;</span>
+            <span class="p">)</span>
+            <span class="n">error_msg</span> <span class="o">=</span> <span class="p">(</span>
+                <span class="sa">f</span><span class="s1">&#39;Threshold Check: &quot;</span><span class="si">{</span><span class="n">meta_data</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;task_id&quot;</span><span class="p">)</span><span class="si">}</span><span class="s1">&quot; failed.</span><span class="se">\n</span><span class="s1">&#39;</span>
+                <span class="sa">f</span><span class="s1">&#39;DAG: </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">dag_id</span><span class="si">}</span><span class="se">\n</span><span class="s1">Task_id: </span><span class="si">{</span><span class="n">meta_data</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;task_id&quot;</span><span class="p">)</span><span class="si">}</span><spa [...]
+                <span class="sa">f</span><span class="s1">&#39;Check description: </span><span class="si">{</span><span class="n">meta_data</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;description&quot;</span><span class="p">)</span><span class="si">}</span><span class="se">\n</span><span class="s1">&#39;</span>
+                <span class="sa">f</span><span class="s2">&quot;SQL: </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="si">}</span><span class="se">\n</span><span class="s2">&quot;</span>
+                <span class="sa">f</span><span class="s1">&#39;Result: </span><span class="si">{</span><span class="n">result</span><span class="si">}</span><span class="s1"> is not within thresholds &#39;</span>
+                <span class="sa">f</span><span class="s1">&#39;</span><span class="si">{</span><span class="n">meta_data</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;min_threshold&quot;</span><span class="p">)</span><span class="si">}</span><span class="s1"> and </span><span class="si">{</span><span class="n">meta_data</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;max_thresh [...]
+            <span class="p">)</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span><span class="n">error_msg</span><span class="p">)</span>
+
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Test </span><span class="si">%s</span><span class="s2"> Successful.&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">task_id</span><span class="p">)</span></div>
+
+<div class="viewcode-block" id="SQLThresholdCheckOperator.push"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator.push">[docs]</a>    <span class="k">def</span> <span class="nf">push</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">meta_data</span><span class="p">):</span>
+        <span class="sd">&quot;&quot;&quot;</span>
+<span class="sd">        Optional: Send data check info and metadata to an external database.</span>
+<span class="sd">        Default functionality will log metadata.</span>
+<span class="sd">        &quot;&quot;&quot;</span>
+        <span class="n">info</span> <span class="o">=</span> <span class="s2">&quot;</span><span class="se">\n</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;&quot;&quot;</span><span class="si">{</span><span class="n">key</span><span class="si">}</span><span class="s2">: </span><span class="si">{</span><span class="n">item</span><span class="si">}</span><span class="s2">&quot;& [...]
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Log from </span><span class="si">%s</span><span class="s2">:</span><span class="se">\n</span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">dag_id</span><span class="p">,</span> <span class="n">info</span>< [...]
+
+
+<div class="viewcode-block" id="BranchSQLOperator"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.BranchSQLOperator">[docs]</a><span class="k">class</span> <span class="nc">BranchSQLOperator</span><span class="p">(</span><span class="n">BaseSQLOperator</span><span class="p">,</span> <span class="n">SkipMixin</span><span class="p">):</span>
+    <span class="sd">&quot;&quot;&quot;</span>
+<span class="sd">    Allows a DAG to &quot;branch&quot; or follow a specified path based on the results of a SQL query.</span>
+
+<span class="sd">    :param sql: The SQL code to be executed, should return true or false (templated)</span>
+<span class="sd">       Template reference are recognized by str ending in &#39;.sql&#39;.</span>
+<span class="sd">       Expected SQL query to return Boolean (True/False), integer (0 = False, Otherwise = 1)</span>
+<span class="sd">       or string (true/y/yes/1/on/false/n/no/0/off).</span>
+<span class="sd">    :param follow_task_ids_if_true: task id or task ids to follow if query returns true</span>
+<span class="sd">    :param follow_task_ids_if_false: task id or task ids to follow if query returns false</span>
+<span class="sd">    :param conn_id: the connection ID used to connect to the database.</span>
+<span class="sd">    :param database: name of database which overwrite the defined one in connection</span>
+<span class="sd">    :param parameters: (optional) the parameters to render the SQL query with.</span>
+<span class="sd">    &quot;&quot;&quot;</span>
+
+<div class="viewcode-block" id="BranchSQLOperator.template_fields"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.BranchSQLOperator.template_fields">[docs]</a>    <span class="n">template_fields</span><span class="p">:</span> <span class="n">Sequence</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="p">(</span><span  [...]
+<div class="viewcode-block" id="BranchSQLOperator.template_ext"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.BranchSQLOperator.template_ext">[docs]</a>    <span class="n">template_ext</span><span class="p">:</span> <span class="n">Sequence</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="p">(</span><span class="s2 [...]
+<div class="viewcode-block" id="BranchSQLOperator.template_fields_renderers"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.BranchSQLOperator.template_fields_renderers">[docs]</a>    <span class="n">template_fields_renderers</span> <span class="o">=</span> <span class="p">{</span><span class="s2">&quot;sql&quot;</span><span class="p">:</span> <span class="s2">&quot;sql&quot;</span><spa [...]
+<div class="viewcode-block" id="BranchSQLOperator.ui_color"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.BranchSQLOperator.ui_color">[docs]</a>    <span class="n">ui_color</span> <span class="o">=</span> <span class="s2">&quot;#a22034&quot;</span></div>
+<div class="viewcode-block" id="BranchSQLOperator.ui_fgcolor"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.BranchSQLOperator.ui_fgcolor">[docs]</a>    <span class="n">ui_fgcolor</span> <span class="o">=</span> <span class="s2">&quot;#F7F7F7&quot;</span></div>
+
+    <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span>
+        <span class="bp">self</span><span class="p">,</span>
+        <span class="o">*</span><span class="p">,</span>
+        <span class="n">sql</span><span class="p">:</span> <span class="nb">str</span><span class="p">,</span>
+        <span class="n">follow_task_ids_if_true</span><span class="p">:</span> <span class="n">List</span><span class="p">[</span><span class="nb">str</span><span class="p">],</span>
+        <span class="n">follow_task_ids_if_false</span><span class="p">:</span> <span class="n">List</span><span class="p">[</span><span class="nb">str</span><span class="p">],</span>
+        <span class="n">conn_id</span><span class="p">:</span> <span class="nb">str</span> <span class="o">=</span> <span class="s2">&quot;default_conn_id&quot;</span><span class="p">,</span>
+        <span class="n">database</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="nb">str</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="n">parameters</span><span class="p">:</span> <span class="n">Optional</span><span class="p">[</span><span class="n">Union</span><span class="p">[</span><span class="n">Iterable</span><span class="p">,</span> <span class="n">Mapping</span><span class="p">]]</span> <span class="o">=</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="o">**</span><span class="n">kwargs</span><span class="p">,</span>
+    <span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
+        <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="fm">__init__</span><span class="p">(</span><span class="n">conn_id</span><span class="o">=</span><span class="n">conn_id</span><span class="p">,</span> <span class="n">database</span><span class="o">=</span><span class="n">database</span><span class="p">,</span> <span class="o">**</span><span class="n">kwargs</span><span class="p">)</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">sql</span> <span class="o">=</span> <span class="n">sql</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">parameters</span> <span class="o">=</span> <span class="n">parameters</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">follow_task_ids_if_true</span> <span class="o">=</span> <span class="n">follow_task_ids_if_true</span>
+        <span class="bp">self</span><span class="o">.</span><span class="n">follow_task_ids_if_false</span> <span class="o">=</span> <span class="n">follow_task_ids_if_false</span>
+
+<div class="viewcode-block" id="BranchSQLOperator.execute"><a class="viewcode-back" href="../../../../../../_api/airflow/providers/common/sql/operators/sql/index.html#airflow.providers.common.sql.operators.sql.BranchSQLOperator.execute">[docs]</a>    <span class="k">def</span> <span class="nf">execute</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">context</span><span class="p">:</span> <span class="s1">&#39;Context&#39;</span><span clas [...]
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span>
+            <span class="s2">&quot;Executing: </span><span class="si">%s</span><span class="s2"> (with parameters </span><span class="si">%s</span><span class="s2">) with connection: </span><span class="si">%s</span><span class="s2">&quot;</span><span class="p">,</span>
+            <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">,</span>
+            <span class="bp">self</span><span class="o">.</span><span class="n">parameters</span><span class="p">,</span>
+            <span class="bp">self</span><span class="o">.</span><span class="n">conn_id</span><span class="p">,</span>
+        <span class="p">)</span>
+        <span class="n">record</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_db_hook</span><span class="p">()</span><span class="o">.</span><span class="n">get_first</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">parameters</span><span class="p">)</span>
+        <span class="k">if</span> <span class="ow">not</span> <span class="n">record</span><span class="p">:</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span>
+                <span class="s2">&quot;No rows returned from sql query. Operator expected True or False return value.&quot;</span>
+            <span class="p">)</span>
+
+        <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">record</span><span class="p">,</span> <span class="nb">list</span><span class="p">):</span>
+            <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">record</span><span class="p">[</span><span class="mi">0</span><span class="p">],</span> <span class="nb">list</span><span class="p">):</span>
+                <span class="n">query_result</span> <span class="o">=</span> <span class="n">record</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="mi">0</span><span class="p">]</span>
+            <span class="k">else</span><span class="p">:</span>
+                <span class="n">query_result</span> <span class="o">=</span> <span class="n">record</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
+        <span class="k">elif</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">record</span><span class="p">,</span> <span class="nb">tuple</span><span class="p">):</span>
+            <span class="n">query_result</span> <span class="o">=</span> <span class="n">record</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
+        <span class="k">else</span><span class="p">:</span>
+            <span class="n">query_result</span> <span class="o">=</span> <span class="n">record</span>
+
+        <span class="bp">self</span><span class="o">.</span><span class="n">log</span><span class="o">.</span><span class="n">info</span><span class="p">(</span><span class="s2">&quot;Query returns </span><span class="si">%s</span><span class="s2">, type &#39;</span><span class="si">%s</span><span class="s2">&#39;&quot;</span><span class="p">,</span> <span class="n">query_result</span><span class="p">,</span> <span class="nb">type</span><span class="p">(</span><span class="n">query_resul [...]
+
+        <span class="n">follow_branch</span> <span class="o">=</span> <span class="kc">None</span>
+        <span class="k">try</span><span class="p">:</span>
+            <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">query_result</span><span class="p">,</span> <span class="nb">bool</span><span class="p">):</span>
+                <span class="k">if</span> <span class="n">query_result</span><span class="p">:</span>
+                    <span class="n">follow_branch</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">follow_task_ids_if_true</span>
+            <span class="k">elif</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">query_result</span><span class="p">,</span> <span class="nb">str</span><span class="p">):</span>
+                <span class="c1"># return result is not Boolean, try to convert from String to Boolean</span>
+                <span class="k">if</span> <span class="n">parse_boolean</span><span class="p">(</span><span class="n">query_result</span><span class="p">):</span>
+                    <span class="n">follow_branch</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">follow_task_ids_if_true</span>
+            <span class="k">elif</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">query_result</span><span class="p">,</span> <span class="nb">int</span><span class="p">):</span>
+                <span class="k">if</span> <span class="nb">bool</span><span class="p">(</span><span class="n">query_result</span><span class="p">):</span>
+                    <span class="n">follow_branch</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">follow_task_ids_if_true</span>
+            <span class="k">else</span><span class="p">:</span>
+                <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span>
+                    <span class="sa">f</span><span class="s2">&quot;Unexpected query return result &#39;</span><span class="si">{</span><span class="n">query_result</span><span class="si">}</span><span class="s2">&#39; type &#39;</span><span class="si">{</span><span class="nb">type</span><span class="p">(</span><span class="n">query_result</span><span class="p">)</span><span class="si">}</span><span class="s2">&#39;&quot;</span>
+                <span class="p">)</span>
+
+            <span class="k">if</span> <span class="n">follow_branch</span> <span class="ow">is</span> <span class="kc">None</span><span class="p">:</span>
+                <span class="n">follow_branch</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">follow_task_ids_if_false</span>
+        <span class="k">except</span> <span class="ne">ValueError</span><span class="p">:</span>
+            <span class="k">raise</span> <span class="n">AirflowException</span><span class="p">(</span>
+                <span class="sa">f</span><span class="s2">&quot;Unexpected query return result &#39;</span><span class="si">{</span><span class="n">query_result</span><span class="si">}</span><span class="s2">&#39; type &#39;</span><span class="si">{</span><span class="nb">type</span><span class="p">(</span><span class="n">query_result</span><span class="p">)</span><span class="si">}</span><span class="s2">&#39;&quot;</span>
+            <span class="p">)</span>
+
+        <span class="bp">self</span><span class="o">.</span><span class="n">skip_all_except</span><span class="p">(</span><span class="n">context</span><span class="p">[</span><span class="s2">&quot;ti&quot;</span><span class="p">],</span> <span class="n">follow_branch</span><span class="p">)</span></div></div>
+
+
+<span class="k">def</span> <span class="nf">_convert_to_float_if_possible</span><span class="p">(</span><span class="n">s</span><span class="p">):</span>
+    <span class="sd">&quot;&quot;&quot;</span>
+<span class="sd">    A small helper function to convert a string to a numeric value</span>
+<span class="sd">    if appropriate</span>
+
+<span class="sd">    :param s: the string to be converted</span>
+<span class="sd">    &quot;&quot;&quot;</span>
+    <span class="k">try</span><span class="p">:</span>
+        <span class="n">ret</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
+    <span class="k">except</span> <span class="p">(</span><span class="ne">ValueError</span><span class="p">,</span> <span class="ne">TypeError</span><span class="p">):</span>
+        <span class="n">ret</span> <span class="o">=</span> <span class="n">s</span>
+    <span class="k">return</span> <span class="n">ret</span>
 </pre></div>
 
     <div class="pager" role="navigation" aria-label="related navigation"><button class="btn-hollow btn-blue bodytext__medium--cerulean-blue" disabled>Previous</button><button class="btn-hollow btn-blue bodytext__medium--cerulean-blue" disabled>Next</button>
@@ -1120,5 +1692,6 @@
         <script src="../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_modules/airflow/providers/common/sql/sensors/sql.html b/docs/apache-airflow-providers-common-sql/1.1.0/_modules/airflow/providers/common/sql/sensors/sql.html
similarity index 99%
copy from docs/apache-airflow-providers-common-sql/stable/_modules/airflow/providers/common/sql/sensors/sql.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_modules/airflow/providers/common/sql/sensors/sql.html
index df6f39eb43..6ce44ab62d 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_modules/airflow/providers/common/sql/sensors/sql.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_modules/airflow/providers/common/sql/sensors/sql.html
@@ -282,7 +282,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -424,7 +424,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -923,5 +923,6 @@
         <script src="../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_modules/index.html b/docs/apache-airflow-providers-common-sql/1.1.0/_modules/index.html
similarity index 99%
copy from docs/apache-airflow-providers-common-sql/stable/_modules/index.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_modules/index.html
index 7757f29f81..b8f0d214d7 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_modules/index.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_modules/index.html
@@ -282,7 +282,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -424,7 +424,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -807,5 +807,6 @@
         <script src="../_static/doctools.js"></script>
         <script src="../_static/clipboard.min.js"></script>
         <script src="../_static/copybutton.js"></script>
+        <script src="../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_modules/tests/system/providers/common/sql/example_sql_column_table_check.html b/docs/apache-airflow-providers-common-sql/1.1.0/_modules/tests/system/providers/common/sql/example_sql_column_table_check.html
similarity index 99%
copy from docs/apache-airflow-providers-common-sql/stable/_modules/tests/system/providers/common/sql/example_sql_column_table_check.html
copy to docs/apache-airflow-providers-common-sql/1.1.0/_modules/tests/system/providers/common/sql/example_sql_column_table_check.html
index d5c53839c6..b4c8611658 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_modules/tests/system/providers/common/sql/example_sql_column_table_check.html
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_modules/tests/system/providers/common/sql/example_sql_column_table_check.html
@@ -282,7 +282,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -424,7 +424,7 @@
 <div id="docs-version-selector" class="docs-version-selector sidebar__version-selector">
     <a class="dropdown-toggle" href="#" id="versionDropdown" role="button" data-toggle="dropdown" aria-haspopup="true"
        aria-expanded="false">
-        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.0.0</span>
+        <span class="bodytext__medium--greyish-brown">Version: </span><span class="version">1.1.0</span>
     </a>
     <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
 
@@ -624,7 +624,7 @@
     <span class="n">description</span><span class="o">=</span><span class="s2">&quot;Example DAG for SQLColumnCheckOperator and SQLTableCheckOperator.&quot;</span><span class="p">,</span>
     <span class="n">default_args</span><span class="o">=</span><span class="n">connection_args</span><span class="p">,</span>
     <span class="n">start_date</span><span class="o">=</span><span class="n">datetime</span><span class="p">(</span><span class="mi">2021</span><span class="p">,</span> <span class="mi">1</span><span class="p">,</span> <span class="mi">1</span><span class="p">),</span>
-    <span class="n">schedule_interval</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
+    <span class="n">schedule</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
     <span class="n">catchup</span><span class="o">=</span><span class="kc">False</span><span class="p">,</span>
 <span class="p">)</span> <span class="k">as</span> <span class="n">dag</span><span class="p">:</span>
     <span class="sd">&quot;&quot;&quot;</span>
@@ -888,5 +888,6 @@
         <script src="../../../../../../_static/doctools.js"></script>
         <script src="../../../../../../_static/clipboard.min.js"></script>
         <script src="../../../../../../_static/copybutton.js"></script>
+        <script src="../../../../../../_static/js/globaltoc.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/hooks/index.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/hooks/index.rst.txt
new file mode 100644
index 0000000000..3cd244260a
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/hooks/index.rst.txt
@@ -0,0 +1,15 @@
+:py:mod:`airflow.providers.common.sql.hooks`
+============================================
+
+.. py:module:: airflow.providers.common.sql.hooks
+
+
+Submodules
+----------
+.. toctree::
+   :titlesonly:
+   :maxdepth: 1
+
+   sql/index.rst
+
+
diff --git a/docs/apache-airflow-providers-common-sql/stable/_sources/_api/airflow/providers/common/sql/hooks/sql/index.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/hooks/sql/index.rst.txt
similarity index 71%
copy from docs/apache-airflow-providers-common-sql/stable/_sources/_api/airflow/providers/common/sql/hooks/sql/index.rst.txt
copy to docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/hooks/sql/index.rst.txt
index b168155418..af67408cb6 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_sources/_api/airflow/providers/common/sql/hooks/sql/index.rst.txt
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/hooks/sql/index.rst.txt
@@ -17,6 +17,27 @@ Classes
 
 
 
+Functions
+~~~~~~~~~
+
+.. autoapisummary::
+
+   airflow.providers.common.sql.hooks.sql.fetch_all_handler
+
+
+
+Attributes
+~~~~~~~~~~
+
+.. autoapisummary::
+
+   airflow.providers.common.sql.hooks.sql.BaseForDbApiHook
+
+
+.. py:function:: fetch_all_handler(cursor)
+
+   Handler for DbApiHook.run() to return results
+
 
 .. py:class:: ConnectorProtocol
 
@@ -24,7 +45,7 @@ Classes
 
    A protocol where you can connect to a database.
 
-   .. py:method:: connect(self, host, port, username, schema)
+   .. py:method:: connect(host, port, username, schema)
 
       Connect to a database.
 
@@ -36,9 +57,14 @@ Classes
 
 
 
+.. py:data:: BaseForDbApiHook
+   :annotation: :Type[airflow.hooks.base.BaseHook]
+
+   
+
 .. py:class:: DbApiHook(*args, schema = None, log_sql = True, **kwargs)
 
-   Bases: :py:obj:`airflow.hooks.base.BaseHook`
+   Bases: :py:obj:`airflow.hooks.dbapi.DbApiHook`
 
    Abstract base class for sql hooks.
 
@@ -67,19 +93,19 @@ Classes
 
       
 
-   .. py:method:: get_conn(self)
+   .. py:method:: get_conn()
 
       Returns a connection object
 
 
-   .. py:method:: get_uri(self)
+   .. py:method:: get_uri()
 
       Extract the URI from the connection.
 
       :return: the extracted uri.
 
 
-   .. py:method:: get_sqlalchemy_engine(self, engine_kwargs=None)
+   .. py:method:: get_sqlalchemy_engine(engine_kwargs=None)
 
       Get an sqlalchemy_engine object.
 
@@ -87,7 +113,7 @@ Classes
       :return: the created engine.
 
 
-   .. py:method:: get_pandas_df(self, sql, parameters=None, **kwargs)
+   .. py:method:: get_pandas_df(sql, parameters=None, **kwargs)
 
       Executes the sql and returns a pandas dataframe
 
@@ -97,7 +123,7 @@ Classes
       :param kwargs: (optional) passed into pandas.io.sql.read_sql method
 
 
-   .. py:method:: get_pandas_df_by_chunks(self, sql, parameters=None, *, chunksize, **kwargs)
+   .. py:method:: get_pandas_df_by_chunks(sql, parameters=None, *, chunksize, **kwargs)
 
       Executes the sql and returns a generator
 
@@ -108,7 +134,7 @@ Classes
       :param kwargs: (optional) passed into pandas.io.sql.read_sql method
 
 
-   .. py:method:: get_records(self, sql, parameters=None)
+   .. py:method:: get_records(sql, parameters = None, **kwargs)
 
       Executes the sql and returns a set of records.
 
@@ -117,7 +143,7 @@ Classes
       :param parameters: The parameters to render the SQL query with.
 
 
-   .. py:method:: get_first(self, sql, parameters=None)
+   .. py:method:: get_first(sql, parameters=None)
 
       Executes the sql and returns the first resulting row.
 
@@ -126,7 +152,20 @@ Classes
       :param parameters: The parameters to render the SQL query with.
 
 
-   .. py:method:: run(self, sql, autocommit=False, parameters=None, handler=None)
+   .. py:method:: strip_sql_string(sql)
+      :staticmethod:
+
+
+   .. py:method:: split_sql_string(sql)
+      :staticmethod:
+
+      Splits string into multiple SQL expressions
+
+      :param sql: SQL string potentially consisting of multiple expressions
+      :return: list of individual expressions
+
+
+   .. py:method:: run(sql, autocommit = False, parameters = None, handler = None, split_statements = False, return_last = True)
 
       Runs a command or a list of commands. Pass a list of sql
       statements to the sql parameter to get them to execute
@@ -138,15 +177,17 @@ Classes
           before executing the query.
       :param parameters: The parameters to render the SQL query with.
       :param handler: The result handler which is called with the result of each statement.
-      :return: query results if handler was provided.
+      :param split_statements: Whether to split a single SQL string into statements and run separately
+      :param return_last: Whether to return result for only last statement or for all after split
+      :return: return only result of the ALL SQL expressions if handler was provided.
 
 
-   .. py:method:: set_autocommit(self, conn, autocommit)
+   .. py:method:: set_autocommit(conn, autocommit)
 
       Sets the autocommit flag on the connection
 
 
-   .. py:method:: get_autocommit(self, conn)
+   .. py:method:: get_autocommit(conn)
 
       Get autocommit setting for the provided connection.
       Return True if conn.autocommit is set to True.
@@ -158,12 +199,12 @@ Classes
       :rtype: bool
 
 
-   .. py:method:: get_cursor(self)
+   .. py:method:: get_cursor()
 
       Returns a cursor
 
 
-   .. py:method:: insert_rows(self, table, rows, target_fields=None, commit_every=1000, replace=False, **kwargs)
+   .. py:method:: insert_rows(table, rows, target_fields=None, commit_every=1000, replace=False, **kwargs)
 
       A generic way to insert a set of tuples into a table,
       a new transaction is created every commit_every rows
@@ -176,7 +217,7 @@ Classes
       :param replace: Whether to replace instead of insert
 
 
-   .. py:method:: bulk_dump(self, table, tmp_file)
+   .. py:method:: bulk_dump(table, tmp_file)
       :abstractmethod:
 
       Dumps a database table into a tab-delimited file
@@ -185,7 +226,7 @@ Classes
       :param tmp_file: The path of the target file
 
 
-   .. py:method:: bulk_load(self, table, tmp_file)
+   .. py:method:: bulk_load(table, tmp_file)
       :abstractmethod:
 
       Loads a tab-delimited file into a database table
@@ -194,7 +235,7 @@ Classes
       :param tmp_file: The path of the file to load into the table
 
 
-   .. py:method:: test_connection(self)
+   .. py:method:: test_connection()
 
       Tests the connection using db-specific query
 
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/index.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/index.rst.txt
new file mode 100644
index 0000000000..7dc3e87761
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/index.rst.txt
@@ -0,0 +1,17 @@
+:py:mod:`airflow.providers.common.sql`
+======================================
+
+.. py:module:: airflow.providers.common.sql
+
+
+Subpackages
+-----------
+.. toctree::
+   :titlesonly:
+   :maxdepth: 3
+
+   hooks/index.rst
+   operators/index.rst
+   sensors/index.rst
+
+
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/operators/index.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/operators/index.rst.txt
new file mode 100644
index 0000000000..036b9e201d
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/operators/index.rst.txt
@@ -0,0 +1,15 @@
+:py:mod:`airflow.providers.common.sql.operators`
+================================================
+
+.. py:module:: airflow.providers.common.sql.operators
+
+
+Submodules
+----------
+.. toctree::
+   :titlesonly:
+   :maxdepth: 1
+
+   sql/index.rst
+
+
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/operators/sql/index.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/operators/sql/index.rst.txt
new file mode 100644
index 0000000000..b03ba93acc
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/operators/sql/index.rst.txt
@@ -0,0 +1,457 @@
+:py:mod:`airflow.providers.common.sql.operators.sql`
+====================================================
+
+.. py:module:: airflow.providers.common.sql.operators.sql
+
+
+Module Contents
+---------------
+
+Classes
+~~~~~~~
+
+.. autoapisummary::
+
+   airflow.providers.common.sql.operators.sql.BaseSQLOperator
+   airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator
+   airflow.providers.common.sql.operators.sql.SQLTableCheckOperator
+   airflow.providers.common.sql.operators.sql.SQLCheckOperator
+   airflow.providers.common.sql.operators.sql.SQLValueCheckOperator
+   airflow.providers.common.sql.operators.sql.SQLIntervalCheckOperator
+   airflow.providers.common.sql.operators.sql.SQLThresholdCheckOperator
+   airflow.providers.common.sql.operators.sql.BranchSQLOperator
+
+
+
+Functions
+~~~~~~~~~
+
+.. autoapisummary::
+
+   airflow.providers.common.sql.operators.sql.parse_boolean
+
+
+
+.. py:function:: parse_boolean(val)
+
+   Try to parse a string into boolean.
+
+   Raises ValueError if the input is not a valid true- or false-like string value.
+
+
+.. py:class:: BaseSQLOperator(*, conn_id = None, database = None, hook_params = None, **kwargs)
+
+   Bases: :py:obj:`airflow.models.BaseOperator`
+
+   This is a base class for generic SQL Operator to get a DB Hook
+
+   The provided method is .get_db_hook(). The default behavior will try to
+   retrieve the DB hook based on connection type.
+   You can custom the behavior by overriding the .get_db_hook() method.
+
+   .. py:method:: get_db_hook()
+
+      Get the database hook for the connection.
+
+      :return: the database hook object.
+      :rtype: DbApiHook
+
+
+
+.. py:class:: SQLColumnCheckOperator(*, table, column_mapping, partition_clause = None, conn_id = None, database = None, **kwargs)
+
+   Bases: :py:obj:`BaseSQLOperator`
+
+   Performs one or more of the templated checks in the column_checks dictionary.
+   Checks are performed on a per-column basis specified by the column_mapping.
+   Each check can take one or more of the following options:
+   - equal_to: an exact value to equal, cannot be used with other comparison options
+   - greater_than: value that result should be strictly greater than
+   - less_than: value that results should be strictly less than
+   - geq_to: value that results should be greater than or equal to
+   - leq_to: value that results should be less than or equal to
+   - tolerance: the percentage that the result may be off from the expected value
+
+   :param table: the table to run checks on
+   :param column_mapping: the dictionary of columns and their associated checks, e.g.
+
+   .. code-block:: python
+
+       {
+           "col_name": {
+               "null_check": {
+                   "equal_to": 0,
+               },
+               "min": {
+                   "greater_than": 5,
+                   "leq_to": 10,
+                   "tolerance": 0.2,
+               },
+               "max": {"less_than": 1000, "geq_to": 10, "tolerance": 0.01},
+           }
+       }
+
+   :param partition_clause: a partial SQL statement that is added to a WHERE clause in the query built by
+       the operator that creates partition_clauses for the checks to run on, e.g.
+
+   .. code-block:: python
+
+       "date = '1970-01-01'"
+
+   :param conn_id: the connection ID used to connect to the database
+   :param database: name of database which overwrite the defined one in connection
+
+   .. seealso::
+       For more information on how to use this operator, take a look at the guide:
+       :ref:`howto/operator:SQLColumnCheckOperator`
+
+   .. py:attribute:: template_fields
+      :annotation: = ['partition_clause']
+
+      
+
+   .. py:attribute:: column_checks
+      
+
+      
+
+   .. py:method:: execute(context)
+
+      This is the main method to derive when creating an operator.
+      Context is the same dictionary used as when rendering jinja templates.
+
+      Refer to get_template_context for more context.
+
+
+
+.. py:class:: SQLTableCheckOperator(*, table, checks, partition_clause = None, conn_id = None, database = None, **kwargs)
+
+   Bases: :py:obj:`BaseSQLOperator`
+
+   Performs one or more of the checks provided in the checks dictionary.
+   Checks should be written to return a boolean result.
+
+   :param table: the table to run checks on
+   :param checks: the dictionary of checks, e.g.:
+
+   .. code-block:: python
+
+       {
+           "row_count_check": {"check_statement": "COUNT(*) = 1000"},
+           "column_sum_check": {"check_statement": "col_a + col_b < col_c"},
+       }
+
+
+   :param partition_clause: a partial SQL statement that is added to a WHERE clause in the query built by
+       the operator that creates partition_clauses for the checks to run on, e.g.
+
+   .. code-block:: python
+
+       "date = '1970-01-01'"
+
+   :param conn_id: the connection ID used to connect to the database
+   :param database: name of database which overwrite the defined one in connection
+
+   .. seealso::
+       For more information on how to use this operator, take a look at the guide:
+       :ref:`howto/operator:SQLTableCheckOperator`
+
+   .. py:attribute:: template_fields
+      :annotation: = ['partition_clause']
+
+      
+
+   .. py:attribute:: sql_check_template
+      :annotation: = Multiline-String
+
+       .. raw:: html
+
+           <details><summary>Show Value</summary>
+
+       .. code-block:: text
+           :linenos:
+
+           
+                   SELECT '_check_name' AS check_name, MIN(_check_name) AS check_result
+                   FROM(SELECT CASE WHEN check_statement THEN 1 ELSE 0 END AS _check_name FROM table)
+               
+
+       .. raw:: html
+
+           </details>
+
+      
+
+   .. py:method:: execute(context)
+
+      This is the main method to derive when creating an operator.
+      Context is the same dictionary used as when rendering jinja templates.
+
+      Refer to get_template_context for more context.
+
+
+
+.. py:class:: SQLCheckOperator(*, sql, conn_id = None, database = None, **kwargs)
+
+   Bases: :py:obj:`BaseSQLOperator`
+
+   Performs checks against a db. The ``SQLCheckOperator`` expects
+   a sql query that will return a single row. Each value on that
+   first row is evaluated using python ``bool`` casting. If any of the
+   values return ``False`` the check is failed and errors out.
+
+   Note that Python bool casting evals the following as ``False``:
+
+   * ``False``
+   * ``0``
+   * Empty string (``""``)
+   * Empty list (``[]``)
+   * Empty dictionary or set (``{}``)
+
+   Given a query like ``SELECT COUNT(*) FROM foo``, it will fail only if
+   the count ``== 0``. You can craft much more complex query that could,
+   for instance, check that the table has the same number of rows as
+   the source table upstream, or that the count of today's partition is
+   greater than yesterday's partition, or that a set of metrics are less
+   than 3 standard deviation for the 7 day average.
+
+   This operator can be used as a data quality check in your pipeline, and
+   depending on where you put it in your DAG, you have the choice to
+   stop the critical path, preventing from
+   publishing dubious data, or on the side and receive email alerts
+   without stopping the progress of the DAG.
+
+   :param sql: the sql to be executed. (templated)
+   :param conn_id: the connection ID used to connect to the database.
+   :param database: name of database which overwrite the defined one in connection
+
+   .. py:attribute:: template_fields
+      :annotation: :Sequence[str] = ['sql']
+
+      
+
+   .. py:attribute:: template_ext
+      :annotation: :Sequence[str] = ['.hql', '.sql']
+
+      
+
+   .. py:attribute:: template_fields_renderers
+      
+
+      
+
+   .. py:attribute:: ui_color
+      :annotation: = #fff7e6
+
+      
+
+   .. py:method:: execute(context)
+
+      This is the main method to derive when creating an operator.
+      Context is the same dictionary used as when rendering jinja templates.
+
+      Refer to get_template_context for more context.
+
+
+
+.. py:class:: SQLValueCheckOperator(*, sql, pass_value, tolerance = None, conn_id = None, database = None, **kwargs)
+
+   Bases: :py:obj:`BaseSQLOperator`
+
+   Performs a simple value check using sql code.
+
+   :param sql: the sql to be executed. (templated)
+   :param conn_id: the connection ID used to connect to the database.
+   :param database: name of database which overwrite the defined one in connection
+
+   .. py:attribute:: __mapper_args__
+      
+
+      
+
+   .. py:attribute:: template_fields
+      :annotation: :Sequence[str] = ['sql', 'pass_value']
+
+      
+
+   .. py:attribute:: template_ext
+      :annotation: :Sequence[str] = ['.hql', '.sql']
+
+      
+
+   .. py:attribute:: template_fields_renderers
+      
+
+      
+
+   .. py:attribute:: ui_color
+      :annotation: = #fff7e6
+
+      
+
+   .. py:method:: execute(context)
+
+      This is the main method to derive when creating an operator.
+      Context is the same dictionary used as when rendering jinja templates.
+
+      Refer to get_template_context for more context.
+
+
+
+.. py:class:: SQLIntervalCheckOperator(*, table, metrics_thresholds, date_filter_column = 'ds', days_back = -7, ratio_formula = 'max_over_min', ignore_zero = True, conn_id = None, database = None, **kwargs)
+
+   Bases: :py:obj:`BaseSQLOperator`
+
+   Checks that the values of metrics given as SQL expressions are within
+   a certain tolerance of the ones from days_back before.
+
+   :param table: the table name
+   :param conn_id: the connection ID used to connect to the database.
+   :param database: name of database which will overwrite the defined one in connection
+   :param days_back: number of days between ds and the ds we want to check
+       against. Defaults to 7 days
+   :param date_filter_column: The column name for the dates to filter on. Defaults to 'ds'
+   :param ratio_formula: which formula to use to compute the ratio between
+       the two metrics. Assuming cur is the metric of today and ref is
+       the metric to today - days_back.
+
+       max_over_min: computes max(cur, ref) / min(cur, ref)
+       relative_diff: computes abs(cur-ref) / ref
+
+       Default: 'max_over_min'
+   :param ignore_zero: whether we should ignore zero metrics
+   :param metrics_thresholds: a dictionary of ratios indexed by metrics
+
+   .. py:attribute:: __mapper_args__
+      
+
+      
+
+   .. py:attribute:: template_fields
+      :annotation: :Sequence[str] = ['sql1', 'sql2']
+
+      
+
+   .. py:attribute:: template_ext
+      :annotation: :Sequence[str] = ['.hql', '.sql']
+
+      
+
+   .. py:attribute:: template_fields_renderers
+      
+
+      
+
+   .. py:attribute:: ui_color
+      :annotation: = #fff7e6
+
+      
+
+   .. py:attribute:: ratio_formulas
+      
+
+      
+
+   .. py:method:: execute(context)
+
+      This is the main method to derive when creating an operator.
+      Context is the same dictionary used as when rendering jinja templates.
+
+      Refer to get_template_context for more context.
+
+
+
+.. py:class:: SQLThresholdCheckOperator(*, sql, min_threshold, max_threshold, conn_id = None, database = None, **kwargs)
+
+   Bases: :py:obj:`BaseSQLOperator`
+
+   Performs a value check using sql code against a minimum threshold
+   and a maximum threshold. Thresholds can be in the form of a numeric
+   value OR a sql statement that results a numeric.
+
+   :param sql: the sql to be executed. (templated)
+   :param conn_id: the connection ID used to connect to the database.
+   :param database: name of database which overwrite the defined one in connection
+   :param min_threshold: numerical value or min threshold sql to be executed (templated)
+   :param max_threshold: numerical value or max threshold sql to be executed (templated)
+
+   .. py:attribute:: template_fields
+      :annotation: :Sequence[str] = ['sql', 'min_threshold', 'max_threshold']
+
+      
+
+   .. py:attribute:: template_ext
+      :annotation: :Sequence[str] = ['.hql', '.sql']
+
+      
+
+   .. py:attribute:: template_fields_renderers
+      
+
+      
+
+   .. py:method:: execute(context)
+
+      This is the main method to derive when creating an operator.
+      Context is the same dictionary used as when rendering jinja templates.
+
+      Refer to get_template_context for more context.
+
+
+   .. py:method:: push(meta_data)
+
+      Optional: Send data check info and metadata to an external database.
+      Default functionality will log metadata.
+
+
+
+.. py:class:: BranchSQLOperator(*, sql, follow_task_ids_if_true, follow_task_ids_if_false, conn_id = 'default_conn_id', database = None, parameters = None, **kwargs)
+
+   Bases: :py:obj:`BaseSQLOperator`, :py:obj:`airflow.models.SkipMixin`
+
+   Allows a DAG to "branch" or follow a specified path based on the results of a SQL query.
+
+   :param sql: The SQL code to be executed, should return true or false (templated)
+      Template reference are recognized by str ending in '.sql'.
+      Expected SQL query to return Boolean (True/False), integer (0 = False, Otherwise = 1)
+      or string (true/y/yes/1/on/false/n/no/0/off).
+   :param follow_task_ids_if_true: task id or task ids to follow if query returns true
+   :param follow_task_ids_if_false: task id or task ids to follow if query returns false
+   :param conn_id: the connection ID used to connect to the database.
+   :param database: name of database which overwrite the defined one in connection
+   :param parameters: (optional) the parameters to render the SQL query with.
+
+   .. py:attribute:: template_fields
+      :annotation: :Sequence[str] = ['sql']
+
+      
+
+   .. py:attribute:: template_ext
+      :annotation: :Sequence[str] = ['.sql']
+
+      
+
+   .. py:attribute:: template_fields_renderers
+      
+
+      
+
+   .. py:attribute:: ui_color
+      :annotation: = #a22034
+
+      
+
+   .. py:attribute:: ui_fgcolor
+      :annotation: = #F7F7F7
+
+      
+
+   .. py:method:: execute(context)
+
+      This is the main method to derive when creating an operator.
+      Context is the same dictionary used as when rendering jinja templates.
+
+      Refer to get_template_context for more context.
+
+
+
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/sensors/index.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/sensors/index.rst.txt
new file mode 100644
index 0000000000..737d23d5e1
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/sensors/index.rst.txt
@@ -0,0 +1,15 @@
+:py:mod:`airflow.providers.common.sql.sensors`
+==============================================
+
+.. py:module:: airflow.providers.common.sql.sensors
+
+
+Submodules
+----------
+.. toctree::
+   :titlesonly:
+   :maxdepth: 1
+
+   sql/index.rst
+
+
diff --git a/docs/apache-airflow-providers-common-sql/stable/_sources/_api/airflow/providers/common/sql/sensors/sql/index.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/sensors/sql/index.rst.txt
similarity index 98%
copy from docs/apache-airflow-providers-common-sql/stable/_sources/_api/airflow/providers/common/sql/sensors/sql/index.rst.txt
copy to docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/sensors/sql/index.rst.txt
index 750309f6f1..02e035b820 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_sources/_api/airflow/providers/common/sql/sensors/sql/index.rst.txt
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/airflow/providers/common/sql/sensors/sql/index.rst.txt
@@ -56,7 +56,7 @@ Classes
 
       
 
-   .. py:method:: poke(self, context)
+   .. py:method:: poke(context)
 
       Function that the sensors defined while deriving this class should
       override.
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/tests/system/providers/common/sql/example_sql_column_table_check/index.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/tests/system/providers/common/sql/example_sql_column_table_check/index.rst.txt
new file mode 100644
index 0000000000..09b8df2b2e
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/tests/system/providers/common/sql/example_sql_column_table_check/index.rst.txt
@@ -0,0 +1,29 @@
+:py:mod:`tests.system.providers.common.sql.example_sql_column_table_check`
+==========================================================================
+
+.. py:module:: tests.system.providers.common.sql.example_sql_column_table_check
+
+
+Module Contents
+---------------
+
+.. py:data:: AIRFLOW_DB_METADATA_TABLE
+   :annotation: = ab_role
+
+   
+
+.. py:data:: connection_args
+   
+
+   
+
+.. py:data:: column_check
+   
+
+   
+
+.. py:data:: test_run
+   
+
+   
+
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/tests/system/providers/common/sql/index.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/tests/system/providers/common/sql/index.rst.txt
new file mode 100644
index 0000000000..e2448c4813
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/_api/tests/system/providers/common/sql/index.rst.txt
@@ -0,0 +1,15 @@
+:py:mod:`tests.system.providers.common.sql`
+===========================================
+
+.. py:module:: tests.system.providers.common.sql
+
+
+Submodules
+----------
+.. toctree::
+   :titlesonly:
+   :maxdepth: 1
+
+   example_sql_column_table_check/index.rst
+
+
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/commits.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/commits.rst.txt
new file mode 100644
index 0000000000..780eee630a
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/commits.rst.txt
@@ -0,0 +1,59 @@
+
+ .. Licensed to the Apache Software Foundation (ASF) under one
+    or more contributor license agreements.  See the NOTICE file
+    distributed with this work for additional information
+    regarding copyright ownership.  The ASF licenses this file
+    to you under the Apache License, Version 2.0 (the
+    "License"); you may not use this file except in compliance
+    with the License.  You may obtain a copy of the License at
+
+ ..   http://www.apache.org/licenses/LICENSE-2.0
+
+ .. Unless required by applicable law or agreed to in writing,
+    software distributed under the License is distributed on an
+    "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+    KIND, either express or implied.  See the License for the
+    specific language governing permissions and limitations
+    under the License.
+
+
+Package apache-airflow-providers-common-sql
+------------------------------------------------------
+
+`Common SQL Provider <https://en.wikipedia.org/wiki/SQL>`__
+
+
+This is detailed commit list of changes for versions provider package: ``common.sql``.
+For high-level changelog, see :doc:`package information including changelog <index>`.
+
+
+
+1.1.0
+.....
+
+Latest change: 2022-08-15
+
+=================================================================================================  ===========  ============================================================================
+Commit                                                                                             Committed    Subject
+=================================================================================================  ===========  ============================================================================
+`7a19651369 <https://github.com/apache/airflow/commit/7a19651369790e2abb563d96a42f41ec31ebfb85>`_  2022-08-15   ``Fix SQL split string to include ';-less' statements (#25713)``
+`5923788143 <https://github.com/apache/airflow/commit/5923788143e7871b56de5164b96a407b2fba75b8>`_  2022-08-10   ``Fix CHANGELOG for common.sql provider and add amazon commit (#25636)``
+`d82436b382 <https://github.com/apache/airflow/commit/d82436b382c41643a7385af8a58c50c106b0d01a>`_  2022-08-05   ``Fix fetch_all_handler & db-api tests for it (#25430)``
+`348a28957a <https://github.com/apache/airflow/commit/348a28957ae9c4601d69be4f312dae07a6a521a7>`_  2022-08-04   ``Align Common SQL provider logo location (#25538)``
+`acab8f52dd <https://github.com/apache/airflow/commit/acab8f52dd8d90fd6583779127895dd343780f79>`_  2022-07-29   ``Move all "old" SQL operators to common.sql providers (#25350)``
+`b0fd105f4a <https://github.com/apache/airflow/commit/b0fd105f4ade9933476470f6e247dd5fa518ffc9>`_  2022-07-28   ``Allow Legacy SqlSensor to use the common.sql providers (#25293)``
+`5d4abbd58c <https://github.com/apache/airflow/commit/5d4abbd58c33e7dfa8505e307d43420459d3df55>`_  2022-07-27   ``Deprecate hql parameters and synchronize DBApiHook method APIs (#25299)``
+`df00436569 <https://github.com/apache/airflow/commit/df00436569bb6fb79ce8c0b7ca71dddf02b854ef>`_  2022-07-22   ``Unify DbApiHook.run() method with the methods which override it (#23971)``
+`be7cb1e837 <https://github.com/apache/airflow/commit/be7cb1e837b875f44fcf7903329755245dd02dc3>`_  2022-07-22   ``Common SQLCheckOperators Various Functionality Update (#25164)``
+=================================================================================================  ===========  ============================================================================
+
+1.0.0
+.....
+
+Latest change: 2022-07-07
+
+=================================================================================================  ===========  ========================================================
+Commit                                                                                             Committed    Subject
+=================================================================================================  ===========  ========================================================
+`46bbfdade0 <https://github.com/apache/airflow/commit/46bbfdade0638cb8a5d187e47034b84e68ddf762>`_  2022-07-07   ``Move all SQL classes to common-sql provider (#24836)``
+=================================================================================================  ===========  ========================================================
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/connections.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/connections.rst.txt
new file mode 100644
index 0000000000..ad06ed4b8e
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/connections.rst.txt
@@ -0,0 +1,32 @@
+ .. Licensed to the Apache Software Foundation (ASF) under one
+    or more contributor license agreements.  See the NOTICE file
+    distributed with this work for additional information
+    regarding copyright ownership.  The ASF licenses this file
+    to you under the Apache License, Version 2.0 (the
+    "License"); you may not use this file except in compliance
+    with the License.  You may obtain a copy of the License at
+
+ ..   http://www.apache.org/licenses/LICENSE-2.0
+
+ .. Unless required by applicable law or agreed to in writing,
+    software distributed under the License is distributed on an
+    "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+    KIND, either express or implied.  See the License for the
+    specific language governing permissions and limitations
+    under the License.
+
+.. _howto/connection:sql:
+
+Connecting to a SQL DB
+=======================
+
+The SQL Provider package operators allow access to various SQL-like databases. For
+databases that can be connected to with a DBApi Hook directly, simply passing the
+connection ID with these operators is sufficient. For other connections with more
+complicated hooks, the additional parameters can be passed as key word args to the
+operators.
+
+Default Connection ID
+~~~~~~~~~~~~~~~~~~~~~
+
+SQL Operators under this provider do not default to any connection ID.
diff --git a/docs/apache-airflow-providers-common-sql/stable/_sources/index.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/index.rst.txt
similarity index 92%
copy from docs/apache-airflow-providers-common-sql/stable/_sources/index.rst.txt
copy to docs/apache-airflow-providers-common-sql/1.1.0/_sources/index.rst.txt
index 9a3c7a272b..f2aae5e65d 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_sources/index.rst.txt
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/index.rst.txt
@@ -64,7 +64,7 @@ Package apache-airflow-providers-common-sql
 `Common SQL Provider <https://en.wikipedia.org/wiki/SQL>`__
 
 
-Release: 1.0.0
+Release: 1.1.0
 
 Provider package
 ----------------
@@ -79,4 +79,13 @@ You can install this package on top of an existing Airflow 2 installation (see `
 for the minimum Airflow version supported) via
 ``pip install apache-airflow-providers-common-sql``
 
+Requirements
+------------
+
+=============  ==================
+PIP package    Version required
+=============  ==================
+``sqlparse``   ``>=0.4.2``
+=============  ==================
+
 .. include:: ../../airflow/providers/common/sql/CHANGELOG.rst
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/installing-providers-from-sources.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/installing-providers-from-sources.rst.txt
new file mode 100644
index 0000000000..1c90205d15
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/installing-providers-from-sources.rst.txt
@@ -0,0 +1,18 @@
+ .. Licensed to the Apache Software Foundation (ASF) under one
+    or more contributor license agreements.  See the NOTICE file
+    distributed with this work for additional information
+    regarding copyright ownership.  The ASF licenses this file
+    to you under the Apache License, Version 2.0 (the
+    "License"); you may not use this file except in compliance
+    with the License.  You may obtain a copy of the License at
+
+ ..   http://www.apache.org/licenses/LICENSE-2.0
+
+ .. Unless required by applicable law or agreed to in writing,
+    software distributed under the License is distributed on an
+    "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+    KIND, either express or implied.  See the License for the
+    specific language governing permissions and limitations
+    under the License.
+
+.. include:: ../installing-providers-from-sources.rst
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_sources/operators.rst.txt b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/operators.rst.txt
new file mode 100644
index 0000000000..039e10b966
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_sources/operators.rst.txt
@@ -0,0 +1,112 @@
+ .. Licensed to the Apache Software Foundation (ASF) under one
+    or more contributor license agreements.  See the NOTICE file
+    distributed with this work for additional information
+    regarding copyright ownership.  The ASF licenses this file
+    to you under the Apache License, Version 2.0 (the
+    "License"); you may not use this file except in compliance
+    with the License.  You may obtain a copy of the License at
+
+ ..   http://www.apache.org/licenses/LICENSE-2.0
+
+ .. Unless required by applicable law or agreed to in writing,
+    software distributed under the License is distributed on an
+    "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+    KIND, either express or implied.  See the License for the
+    specific language governing permissions and limitations
+    under the License.
+
+SQL Operators
+=============
+
+These operators perform various queries against a SQL database, including
+column- and table-level data quality checks.
+
+.. _howto/operator:SQLColumnCheckOperator:
+
+Check SQL Table Columns
+~~~~~~~~~~~~~~~~~~~~~~~
+
+Use the :class:`~airflow.providers.common.sql.operators.sql.SQLColumnCheckOperator` to run data quality
+checks against columns of a given table. As well as a connection ID and table, a column_mapping
+describing the relationship between columns and tests to run must be supplied. An example column
+mapping is a set of three nested dictionaries and looks like:
+
+.. code-block:: python
+
+        column_mapping = {
+            "col_name": {
+                "null_check": {
+                    "equal_to": 0,
+                },
+                "min": {
+                    "greater_than": 5,
+                    "leq_to": 10,
+                    "tolerance": 0.2,
+                },
+                "max": {"less_than": 1000, "geq_to": 10, "tolerance": 0.01},
+            }
+        }
+
+Where col_name is the name of the column to run checks on, and each entry in its dictionary is a check.
+The valid checks are:
+- null_check: checks the number of NULL values in the column
+- distinct_check: checks the COUNT of values in the column that are distinct
+- unique_check: checks the number of distinct values in a column against the number of rows
+- min: checks the minimum value in the column
+- max: checks the maximum value in the column
+
+Each entry in the check's dictionary is either a condition for success of the check or the tolerance. The
+conditions for success are:
+- greater_than
+- geq_to
+- less_than
+- leq_to
+- equal_to
+
+When specifying conditions, equal_to is not compatible with other conditions. Both a lower- and an upper-
+bound condition may be specified in the same check. The tolerance is a percentage that the result may
+be out of bounds but still considered successful.
+
+
+
+The below example demonstrates how to instantiate the SQLColumnCheckOperator task.
+
+.. exampleinclude:: /../../tests/system/providers/common/sql/example_sql_column_table_check.py
+    :language: python
+    :dedent: 4
+    :start-after: [START howto_operator_sql_column_check]
+    :end-before: [END howto_operator_sql_column_check]
+
+.. _howto/operator:SQLTableCheckOperator:
+
+Check SQL Table Values
+~~~~~~~~~~~~~~~~~~~~~~~
+
+Use the :class:`~airflow.providers.common.sql.operators.sql.SQLTableCheckOperator` to run data quality
+checks against a given table. As well as a connection ID and table, a checks dictionary
+describing the relationship between the table and tests to run must be supplied. An example
+checks argument is a set of two nested dictionaries and looks like:
+
+.. code-block:: python
+
+        checks = (
+            {
+                "row_count_check": {
+                    "check_statement": "COUNT(*) = 1000",
+                },
+                "column_sum_check": {"check_statement": "col_a + col_b < col_c"},
+            },
+        )
+
+The first set of keys are the check names, which are referenced in the templated query the operator builds.
+The dictionary key under the check name must be check_statement, with the value a SQL statement that
+resolves to a boolean (this can be any string or int that resolves to a boolean in
+airflow.operators.sql.parse_boolean).
+
+The below example demonstrates how to instantiate the SQLTableCheckOperator task.
+
+.. exampleinclude:: /../../tests/system/providers/common/sql/example_sql_column_table_check.py
+    :language: python
+    :dedent: 4
+    :start-after: [START howto_operator_sql_table_check]
+    :end-before: [END howto_operator_sql_table_check]
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/_gen/css/main-custom.min.css b/docs/apache-airflow-providers-common-sql/1.1.0/_static/_gen/css/main-custom.min.css
new file mode 100644
index 0000000000..10325b154c
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/_gen/css/main-custom.min.css
@@ -0,0 +1 @@
+@charset "UTF-8";@import "https://fonts.googleapis.com/css?family=Rubik:500&display=swap";@import "https://fonts.googleapis.com/css?family=Roboto:400,400i,500,700&display=swap";@import "https://fonts.googleapis.com/css?family=Roboto+Mono:400,700&display=swap";.header__large--cerulean-blue{font-family:rubik,sans-serif;font-weight:500;font-size:72px;line-height:1.17;color:#017cee}.header__large--shamrock{font-family:rubik,sans-serif;font-weight:500;font-size:72px;line-height:1.17;color:#00 [...]
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/_gen/css/main.min.css b/docs/apache-airflow-providers-common-sql/1.1.0/_static/_gen/css/main.min.css
new file mode 100644
index 0000000000..0ccc485909
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/_gen/css/main.min.css
@@ -0,0 +1,7 @@
+@import "https://fonts.googleapis.com/css?family=Open+Sans:300,300i,400,400i,700,700i";@fa-font-path:"../webfonts";/*!* Bootstrap v4.1.3 (https://getbootstrap.com/)
+* Copyright 2011-2018 The Bootstrap Authors
+* Copyright 2011-2018 Twitter, Inc.
+* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)*/:root{--blue:#72A1E5;--indigo:#6610f2;--purple:#6f42c1;--pink:#e83e8c;--red:#dc3545;--orange:#BA5A31;--yellow:#ffc107;--green:#28a745;--teal:#20c997;--cyan:#17a2b8;--white:#fff;--gray:#888;--gray-dark:#333;--primary:#30638E;--secondary:#FFA630;--success:#3772FF;--info:#C0E0DE;--warning:#ED6A5A;--danger:#ED6A5A;--light:#D3F3EE;--dark:#403F4C;--breakpoint-xs:0;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpo [...]
+* License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)*/.fa,.fas,.far,.fal,.fad,.fab{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:inline-block;font-style:normal;font-variant:normal;text-rendering:auto;line-height:1}.fa-lg{font-size:1.33333333em;line-height:.75em;vertical-align:-.0667em}.fa-xs{font-size:.75em}.fa-sm{font-size:.875em}.fa-1x{font-size:1em}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font [...]
+* License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)*/@font-face{font-family:'font awesome 5 free';font-style:normal;font-weight:900;font-display:auto;src:url(../webfonts/fa-solid-900.eot);src:url(../webfonts/fa-solid-900.eot?#iefix)format("embedded-opentype"),url(../webfonts/fa-solid-900.woff2)format("woff2"),url(../webfonts/fa-solid-900.woff)format("woff"),url(../webfonts/fa-solid-900.ttf)format("truetype"),url(../webfonts/fa-solid- [...]
+* License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)*/@font-face{font-family:'font awesome 5 brands';font-style:normal;font-weight:400;font-display:auto;src:url(../webfonts/fa-brands-400.eot);src:url(../webfonts/fa-brands-400.eot?#iefix)format("embedded-opentype"),url(../webfonts/fa-brands-400.woff2)format("woff2"),url(../webfonts/fa-brands-400.woff)format("woff"),url(../webfonts/fa-brands-400.ttf)format("truetype"),url(../webfonts/fa [...]
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/stable/_static/_gen/js/docs.js b/docs/apache-airflow-providers-common-sql/1.1.0/_static/_gen/js/docs.js
similarity index 79%
copy from docs/apache-airflow-providers-common-sql/stable/_static/_gen/js/docs.js
copy to docs/apache-airflow-providers-common-sql/1.1.0/_static/_gen/js/docs.js
index 90898d86d5..2029b9f814 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_static/_gen/js/docs.js
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/_gen/js/docs.js
@@ -1 +1 @@
-!function(r){var n={};function o(t){if(n[t])return n[t].exports;var e=n[t]={i:t,l:!1,exports:{}};return r[t].call(e.exports,e,e.exports,o),e.l=!0,e.exports}o.m=r,o.c=n,o.d=function(t,e,r){o.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},o.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typ [...]
\ No newline at end of file
+!function(r){var n={};function o(t){if(n[t])return n[t].exports;var e=n[t]={i:t,l:!1,exports:{}};return r[t].call(e.exports,e,e.exports,o),e.l=!0,e.exports}o.m=r,o.c=n,o.d=function(t,e,r){o.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},o.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typ [...]
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/_sphinx_javascript_frameworks_compat.js b/docs/apache-airflow-providers-common-sql/1.1.0/_static/_sphinx_javascript_frameworks_compat.js
new file mode 100644
index 0000000000..8549469dc2
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/_sphinx_javascript_frameworks_compat.js
@@ -0,0 +1,134 @@
+/*
+ * _sphinx_javascript_frameworks_compat.js
+ * ~~~~~~~~~~
+ *
+ * Compatability shim for jQuery and underscores.js.
+ *
+ * WILL BE REMOVED IN Sphinx 6.0
+ * xref RemovedInSphinx60Warning
+ *
+ */
+
+/**
+ * select a different prefix for underscore
+ */
+$u = _.noConflict();
+
+
+/**
+ * small helper function to urldecode strings
+ *
+ * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL
+ */
+jQuery.urldecode = function(x) {
+    if (!x) {
+        return x
+    }
+    return decodeURIComponent(x.replace(/\+/g, ' '));
+};
+
+/**
+ * small helper function to urlencode strings
+ */
+jQuery.urlencode = encodeURIComponent;
+
+/**
+ * This function returns the parsed url parameters of the
+ * current request. Multiple values per key are supported,
+ * it will always return arrays of strings for the value parts.
+ */
+jQuery.getQueryParameters = function(s) {
+    if (typeof s === 'undefined')
+        s = document.location.search;
+    var parts = s.substr(s.indexOf('?') + 1).split('&');
+    var result = {};
+    for (var i = 0; i < parts.length; i++) {
+        var tmp = parts[i].split('=', 2);
+        var key = jQuery.urldecode(tmp[0]);
+        var value = jQuery.urldecode(tmp[1]);
+        if (key in result)
+            result[key].push(value);
+        else
+            result[key] = [value];
+    }
+    return result;
+};
+
+/**
+ * highlight a given string on a jquery object by wrapping it in
+ * span elements with the given class name.
+ */
+jQuery.fn.highlightText = function(text, className) {
+    function highlight(node, addItems) {
+        if (node.nodeType === 3) {
+            var val = node.nodeValue;
+            var pos = val.toLowerCase().indexOf(text);
+            if (pos >= 0 &&
+                !jQuery(node.parentNode).hasClass(className) &&
+                !jQuery(node.parentNode).hasClass("nohighlight")) {
+                var span;
+                var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg");
+                if (isInSVG) {
+                    span = document.createElementNS("http://www.w3.org/2000/svg", "tspan");
+                } else {
+                    span = document.createElement("span");
+                    span.className = className;
+                }
+                span.appendChild(document.createTextNode(val.substr(pos, text.length)));
+                node.parentNode.insertBefore(span, node.parentNode.insertBefore(
+                    document.createTextNode(val.substr(pos + text.length)),
+                    node.nextSibling));
+                node.nodeValue = val.substr(0, pos);
+                if (isInSVG) {
+                    var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect");
+                    var bbox = node.parentElement.getBBox();
+                    rect.x.baseVal.value = bbox.x;
+                    rect.y.baseVal.value = bbox.y;
+                    rect.width.baseVal.value = bbox.width;
+                    rect.height.baseVal.value = bbox.height;
+                    rect.setAttribute('class', className);
+                    addItems.push({
+                        "parent": node.parentNode,
+                        "target": rect});
+                }
+            }
+        }
+        else if (!jQuery(node).is("button, select, textarea")) {
+            jQuery.each(node.childNodes, function() {
+                highlight(this, addItems);
+            });
+        }
+    }
+    var addItems = [];
+    var result = this.each(function() {
+        highlight(this, addItems);
+    });
+    for (var i = 0; i < addItems.length; ++i) {
+        jQuery(addItems[i].parent).before(addItems[i].target);
+    }
+    return result;
+};
+
+/*
+ * backward compatibility for jQuery.browser
+ * This will be supported until firefox bug is fixed.
+ */
+if (!jQuery.browser) {
+    jQuery.uaMatch = function(ua) {
+        ua = ua.toLowerCase();
+
+        var match = /(chrome)[ \/]([\w.]+)/.exec(ua) ||
+            /(webkit)[ \/]([\w.]+)/.exec(ua) ||
+            /(opera)(?:.*version|)[ \/]([\w.]+)/.exec(ua) ||
+            /(msie) ([\w.]+)/.exec(ua) ||
+            ua.indexOf("compatible") < 0 && /(mozilla)(?:.*? rv:([\w.]+)|)/.exec(ua) ||
+            [];
+
+        return {
+            browser: match[ 1 ] || "",
+            version: match[ 2 ] || "0"
+        };
+    };
+    jQuery.browser = {};
+    jQuery.browser[jQuery.uaMatch(navigator.userAgent).browser] = true;
+}
diff --git a/docs/apache-airflow-providers-databricks/stable/_static/basic.css b/docs/apache-airflow-providers-common-sql/1.1.0/_static/basic.css
similarity index 96%
copy from docs/apache-airflow-providers-databricks/stable/_static/basic.css
copy to docs/apache-airflow-providers-common-sql/1.1.0/_static/basic.css
index 7d5974c322..eeb0519a69 100644
--- a/docs/apache-airflow-providers-databricks/stable/_static/basic.css
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/basic.css
@@ -608,8 +608,6 @@ ol.simple p,
 ul.simple p {
     margin-bottom: 0;
 }
-
-/* Docutils 0.17 and older (footnotes & citations) */
 dl.footnote > dt,
 dl.citation > dt {
     float: left;
@@ -627,33 +625,6 @@ dl.citation > dd:after {
     clear: both;
 }
 
-/* Docutils 0.18+ (footnotes & citations) */
-aside.footnote > span,
-div.citation > span {
-    float: left;
-}
-aside.footnote > span:last-of-type,
-div.citation > span:last-of-type {
-  padding-right: 0.5em;
-}
-aside.footnote > p {
-  margin-left: 2em;
-}
-div.citation > p {
-  margin-left: 4em;
-}
-aside.footnote > p:last-of-type,
-div.citation > p:last-of-type {
-    margin-bottom: 0em;
-}
-aside.footnote > p:last-of-type:after,
-div.citation > p:last-of-type:after {
-    content: "";
-    clear: both;
-}
-
-/* Footnotes & citations ends */
-
 dl.field-list {
     display: grid;
     grid-template-columns: fit-content(30%) auto;
@@ -665,11 +636,11 @@ dl.field-list > dt {
     padding-left: 0.5em;
     padding-right: 5px;
 }
-
 dl.field-list > dt:after {
     content: ":";
 }
 
+
 dl.field-list > dd {
     padding-left: 0.5em;
     margin-top: 0em;
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/check-solid.svg b/docs/apache-airflow-providers-common-sql/1.1.0/_static/check-solid.svg
new file mode 100644
index 0000000000..92fad4b5c0
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/check-solid.svg
@@ -0,0 +1,4 @@
+<svg xmlns="http://www.w3.org/2000/svg" class="icon icon-tabler icon-tabler-check" width="44" height="44" viewBox="0 0 24 24" stroke-width="2" stroke="#22863a" fill="none" stroke-linecap="round" stroke-linejoin="round">
+  <path stroke="none" d="M0 0h24v24H0z" fill="none"/>
+  <path d="M5 12l5 5l10 -10" />
+</svg>
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/clipboard.min.js b/docs/apache-airflow-providers-common-sql/1.1.0/_static/clipboard.min.js
new file mode 100644
index 0000000000..54b3c46381
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/clipboard.min.js
@@ -0,0 +1,7 @@
+/*!
+ * clipboard.js v2.0.8
+ * https://clipboardjs.com/
+ *
+ * Licensed MIT © Zeno Rocha
+ */
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.ClipboardJS=e():t.ClipboardJS=e()}(this,function(){return n={686:function(t,e,n){"use strict";n.d(e,{default:function(){return o}});var e=n(279),i=n.n(e),e=n(370),u=n.n(e),e=n(817),c=n.n(e);function a(t){try{return document.execCommand(t)}catch(t){return}}var f=function(t){t=c()(t);return a("cut"),t};var l=function(t){var  [...]
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/copy-button.svg b/docs/apache-airflow-providers-common-sql/1.1.0/_static/copy-button.svg
new file mode 100644
index 0000000000..9c074dae52
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/copy-button.svg
@@ -0,0 +1,5 @@
+<svg xmlns="http://www.w3.org/2000/svg" class="icon icon-tabler icon-tabler-copy" width="44" height="44" viewBox="0 0 24 24" stroke-width="1.5" stroke="#000000" fill="none" stroke-linecap="round" stroke-linejoin="round">
+  <path stroke="none" d="M0 0h24v24H0z" fill="none"/>
+  <rect x="8" y="8" width="12" height="12" rx="2" />
+  <path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2" />
+</svg>
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/copybutton.css b/docs/apache-airflow-providers-common-sql/1.1.0/_static/copybutton.css
new file mode 100644
index 0000000000..40eafe5fc2
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/copybutton.css
@@ -0,0 +1,93 @@
+/* Copy buttons */
+button.copybtn {
+    position: absolute;
+    display: flex;
+    top: .3em;
+    right: .3em;
+    width: 1.7em;
+    height: 1.7em;
+	opacity: 0;
+    transition: opacity 0.3s, border .3s, background-color .3s;
+    user-select: none;
+    padding: 0;
+    border: none;
+    outline: none;
+    border-radius: 0.4em;
+    /* The colors that GitHub uses */
+    border: #1b1f2426 1px solid;
+    background-color: #f6f8fa;
+    color: #57606a;
+}
+
+button.copybtn.success {
+    border-color: #22863a;
+    color: #22863a;
+}
+
+button.copybtn svg {
+    stroke: currentColor;
+    width: 1.5em;
+    height: 1.5em;
+    padding: 0.1em;
+}
+
+div.highlight  {
+    position: relative;
+}
+
+.highlight:hover button.copybtn {
+	opacity: 1;
+}
+
+.highlight button.copybtn:hover {
+    background-color: rgb(235, 235, 235);
+}
+
+.highlight button.copybtn:active {
+    background-color: rgb(187, 187, 187);
+}
+
+/**
+ * A minimal CSS-only tooltip copied from:
+ *   https://codepen.io/mildrenben/pen/rVBrpK
+ *
+ * To use, write HTML like the following:
+ *
+ * <p class="o-tooltip--left" data-tooltip="Hey">Short</p>
+ */
+ .o-tooltip--left {
+  position: relative;
+ }
+
+ .o-tooltip--left:after {
+    opacity: 0;
+    visibility: hidden;
+    position: absolute;
+    content: attr(data-tooltip);
+    padding: .2em;
+    font-size: .8em;
+    left: -.2em;
+    background: grey;
+    color: white;
+    white-space: nowrap;
+    z-index: 2;
+    border-radius: 2px;
+    transform: translateX(-102%) translateY(0);
+    transition: opacity 0.2s cubic-bezier(0.64, 0.09, 0.08, 1), transform 0.2s cubic-bezier(0.64, 0.09, 0.08, 1);
+}
+
+.o-tooltip--left:hover:after {
+    display: block;
+    opacity: 1;
+    visibility: visible;
+    transform: translateX(-100%) translateY(0);
+    transition: opacity 0.2s cubic-bezier(0.64, 0.09, 0.08, 1), transform 0.2s cubic-bezier(0.64, 0.09, 0.08, 1);
+    transition-delay: .5s;
+}
+
+/* By default the copy button shouldn't show up when printing a page */
+@media print {
+    button.copybtn {
+        display: none;
+    }
+}
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/copybutton.js b/docs/apache-airflow-providers-common-sql/1.1.0/_static/copybutton.js
new file mode 100644
index 0000000000..40ac331086
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/copybutton.js
@@ -0,0 +1,220 @@
+// Localization support
+const messages = {
+  'en': {
+    'copy': 'Copy',
+    'copy_to_clipboard': 'Copy to clipboard',
+    'copy_success': 'Copied!',
+    'copy_failure': 'Failed to copy',
+  },
+  'es' : {
+    'copy': 'Copiar',
+    'copy_to_clipboard': 'Copiar al portapapeles',
+    'copy_success': '¡Copiado!',
+    'copy_failure': 'Error al copiar',
+  },
+  'de' : {
+    'copy': 'Kopieren',
+    'copy_to_clipboard': 'In die Zwischenablage kopieren',
+    'copy_success': 'Kopiert!',
+    'copy_failure': 'Fehler beim Kopieren',
+  },
+  'fr' : {
+    'copy': 'Copier',
+    'copy_to_clipboard': 'Copié dans le presse-papier',
+    'copy_success': 'Copié !',
+    'copy_failure': 'Échec de la copie',
+  },
+  'ru': {
+    'copy': 'Скопировать',
+    'copy_to_clipboard': 'Скопировать в буфер',
+    'copy_success': 'Скопировано!',
+    'copy_failure': 'Не удалось скопировать',
+  },
+  'zh-CN': {
+    'copy': '复制',
+    'copy_to_clipboard': '复制到剪贴板',
+    'copy_success': '复制成功!',
+    'copy_failure': '复制失败',
+  },
+  'it' : {
+    'copy': 'Copiare',
+    'copy_to_clipboard': 'Copiato negli appunti',
+    'copy_success': 'Copiato!',
+    'copy_failure': 'Errore durante la copia',
+  }
+}
+
+let locale = 'en'
+if( document.documentElement.lang !== undefined
+    && messages[document.documentElement.lang] !== undefined ) {
+  locale = document.documentElement.lang
+}
+
+let doc_url_root = DOCUMENTATION_OPTIONS.URL_ROOT;
+if (doc_url_root == '#') {
+    doc_url_root = '';
+}
+
+/**
+ * SVG files for our copy buttons
+ */
+let iconCheck = `<svg xmlns="http://www.w3.org/2000/svg" class="icon icon-tabler icon-tabler-check" width="44" height="44" viewBox="0 0 24 24" stroke-width="2" stroke="#22863a" fill="none" stroke-linecap="round" stroke-linejoin="round">
+  <title>${messages[locale]['copy_success']}</title>
+  <path stroke="none" d="M0 0h24v24H0z" fill="none"/>
+  <path d="M5 12l5 5l10 -10" />
+</svg>`
+
+// If the user specified their own SVG use that, otherwise use the default
+let iconCopy = ``;
+if (!iconCopy) {
+  iconCopy = `<svg xmlns="http://www.w3.org/2000/svg" class="icon icon-tabler icon-tabler-copy" width="44" height="44" viewBox="0 0 24 24" stroke-width="1.5" stroke="#000000" fill="none" stroke-linecap="round" stroke-linejoin="round">
+  <title>${messages[locale]['copy_to_clipboard']}</title>
+  <path stroke="none" d="M0 0h24v24H0z" fill="none"/>
+  <rect x="8" y="8" width="12" height="12" rx="2" />
+  <path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2" />
+</svg>`
+}
+
+/**
+ * Set up copy/paste for code blocks
+ */
+
+const runWhenDOMLoaded = cb => {
+  if (document.readyState != 'loading') {
+    cb()
+  } else if (document.addEventListener) {
+    document.addEventListener('DOMContentLoaded', cb)
+  } else {
+    document.attachEvent('onreadystatechange', function() {
+      if (document.readyState == 'complete') cb()
+    })
+  }
+}
+
+const codeCellId = index => `codecell${index}`
+
+// Clears selected text since ClipboardJS will select the text when copying
+const clearSelection = () => {
+  if (window.getSelection) {
+    window.getSelection().removeAllRanges()
+  } else if (document.selection) {
+    document.selection.empty()
+  }
+}
+
+// Changes tooltip text for two seconds, then changes it back
+const temporarilyChangeTooltip = (el, oldText, newText) => {
+  el.setAttribute('data-tooltip', newText)
+  el.classList.add('success')
+  setTimeout(() => el.setAttribute('data-tooltip', oldText), 2000)
+  setTimeout(() => el.classList.remove('success'), 2000)
+}
+
+// Changes the copy button icon for two seconds, then changes it back
+const temporarilyChangeIcon = (el) => {
+  el.innerHTML = iconCheck;
+  setTimeout(() => {el.innerHTML = iconCopy}, 2000)
+}
+
+const addCopyButtonToCodeCells = () => {
+  // If ClipboardJS hasn't loaded, wait a bit and try again. This
+  // happens because we load ClipboardJS asynchronously.
+  if (window.ClipboardJS === undefined) {
+    setTimeout(addCopyButtonToCodeCells, 250)
+    return
+  }
+
+  // Add copybuttons to all of our code cells
+  const codeCells = document.querySelectorAll('div.highlight pre')
+  codeCells.forEach((codeCell, index) => {
+    const id = codeCellId(index)
+    codeCell.setAttribute('id', id)
+
+    const clipboardButton = id =>
+    `<button class="copybtn o-tooltip--left" data-tooltip="${messages[locale]['copy']}" data-clipboard-target="#${id}">
+      ${iconCopy}
+    </button>`
+    codeCell.insertAdjacentHTML('afterend', clipboardButton(id))
+  })
+
+function escapeRegExp(string) {
+    return string.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string
+}
+
+// Callback when a copy button is clicked. Will be passed the node that was clicked
+// should then grab the text and replace pieces of text that shouldn't be used in output
+function formatCopyText(textContent, copybuttonPromptText, isRegexp = false, onlyCopyPromptLines = true, removePrompts = true, copyEmptyLines = true, lineContinuationChar = "", hereDocDelim = "") {
+
+    var regexp;
+    var match;
+
+    // Do we check for line continuation characters and "HERE-documents"?
+    var useLineCont = !!lineContinuationChar
+    var useHereDoc = !!hereDocDelim
+
+    // create regexp to capture prompt and remaining line
+    if (isRegexp) {
+        regexp = new RegExp('^(' + copybuttonPromptText + ')(.*)')
+    } else {
+        regexp = new RegExp('^(' + escapeRegExp(copybuttonPromptText) + ')(.*)')
+    }
+
+    const outputLines = [];
+    var promptFound = false;
+    var gotLineCont = false;
+    var gotHereDoc = false;
+    const lineGotPrompt = [];
+    for (const line of textContent.split('\n')) {
+        match = line.match(regexp)
+        if (match || gotLineCont || gotHereDoc) {
+            promptFound = regexp.test(line)
+            lineGotPrompt.push(promptFound)
+            if (removePrompts && promptFound) {
+                outputLines.push(match[2])
+            } else {
+                outputLines.push(line)
+            }
+            gotLineCont = line.endsWith(lineContinuationChar) & useLineCont
+            if (line.includes(hereDocDelim) & useHereDoc)
+                gotHereDoc = !gotHereDoc
+        } else if (!onlyCopyPromptLines) {
+            outputLines.push(line)
+        } else if (copyEmptyLines && line.trim() === '') {
+            outputLines.push(line)
+        }
+    }
+
+    // If no lines with the prompt were found then just use original lines
+    if (lineGotPrompt.some(v => v === true)) {
+        textContent = outputLines.join('\n');
+    }
+
+    // Remove a trailing newline to avoid auto-running when pasting
+    if (textContent.endsWith("\n")) {
+        textContent = textContent.slice(0, -1)
+    }
+    return textContent
+}
+
+
+var copyTargetText = (trigger) => {
+  var target = document.querySelector(trigger.attributes['data-clipboard-target'].value);
+  return formatCopyText(target.innerText, '', false, true, true, true, '', '')
+}
+
+  // Initialize with a callback so we can modify the text before copy
+  const clipboard = new ClipboardJS('.copybtn', {text: copyTargetText})
+
+  // Update UI with error/success messages
+  clipboard.on('success', event => {
+    clearSelection()
+    temporarilyChangeTooltip(event.trigger, messages[locale]['copy'], messages[locale]['copy_success'])
+    temporarilyChangeIcon(event.trigger)
+  })
+
+  clipboard.on('error', event => {
+    temporarilyChangeTooltip(event.trigger, messages[locale]['copy'], messages[locale]['copy_failure'])
+  })
+}
+
+runWhenDOMLoaded(addCopyButtonToCodeCells)
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/copybutton_funcs.js b/docs/apache-airflow-providers-common-sql/1.1.0/_static/copybutton_funcs.js
new file mode 100644
index 0000000000..b9168c5565
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/copybutton_funcs.js
@@ -0,0 +1,58 @@
+function escapeRegExp(string) {
+    return string.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string
+}
+
+// Callback when a copy button is clicked. Will be passed the node that was clicked
+// should then grab the text and replace pieces of text that shouldn't be used in output
+export function formatCopyText(textContent, copybuttonPromptText, isRegexp = false, onlyCopyPromptLines = true, removePrompts = true, copyEmptyLines = true, lineContinuationChar = "", hereDocDelim = "") {
+
+    var regexp;
+    var match;
+
+    // Do we check for line continuation characters and "HERE-documents"?
+    var useLineCont = !!lineContinuationChar
+    var useHereDoc = !!hereDocDelim
+
+    // create regexp to capture prompt and remaining line
+    if (isRegexp) {
+        regexp = new RegExp('^(' + copybuttonPromptText + ')(.*)')
+    } else {
+        regexp = new RegExp('^(' + escapeRegExp(copybuttonPromptText) + ')(.*)')
+    }
+
+    const outputLines = [];
+    var promptFound = false;
+    var gotLineCont = false;
+    var gotHereDoc = false;
+    const lineGotPrompt = [];
+    for (const line of textContent.split('\n')) {
+        match = line.match(regexp)
+        if (match || gotLineCont || gotHereDoc) {
+            promptFound = regexp.test(line)
+            lineGotPrompt.push(promptFound)
+            if (removePrompts && promptFound) {
+                outputLines.push(match[2])
+            } else {
+                outputLines.push(line)
+            }
+            gotLineCont = line.endsWith(lineContinuationChar) & useLineCont
+            if (line.includes(hereDocDelim) & useHereDoc)
+                gotHereDoc = !gotHereDoc
+        } else if (!onlyCopyPromptLines) {
+            outputLines.push(line)
+        } else if (copyEmptyLines && line.trim() === '') {
+            outputLines.push(line)
+        }
+    }
+
+    // If no lines with the prompt were found then just use original lines
+    if (lineGotPrompt.some(v => v === true)) {
+        textContent = outputLines.join('\n');
+    }
+
+    // Remove a trailing newline to avoid auto-running when pasting
+    if (textContent.endsWith("\n")) {
+        textContent = textContent.slice(0, -1)
+    }
+    return textContent
+}
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/doctools.js b/docs/apache-airflow-providers-common-sql/1.1.0/_static/doctools.js
new file mode 100644
index 0000000000..c3db08d1c3
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/doctools.js
@@ -0,0 +1,264 @@
+/*
+ * doctools.js
+ * ~~~~~~~~~~~
+ *
+ * Base JavaScript utilities for all Sphinx HTML documentation.
+ *
+ * :copyright: Copyright 2007-2022 by the Sphinx team, see AUTHORS.
+ * :license: BSD, see LICENSE for details.
+ *
+ */
+"use strict";
+
+const _ready = (callback) => {
+  if (document.readyState !== "loading") {
+    callback();
+  } else {
+    document.addEventListener("DOMContentLoaded", callback);
+  }
+};
+
+/**
+ * highlight a given string on a node by wrapping it in
+ * span elements with the given class name.
+ */
+const _highlight = (node, addItems, text, className) => {
+  if (node.nodeType === Node.TEXT_NODE) {
+    const val = node.nodeValue;
+    const parent = node.parentNode;
+    const pos = val.toLowerCase().indexOf(text);
+    if (
+      pos >= 0 &&
+      !parent.classList.contains(className) &&
+      !parent.classList.contains("nohighlight")
+    ) {
+      let span;
+
+      const closestNode = parent.closest("body, svg, foreignObject");
+      const isInSVG = closestNode && closestNode.matches("svg");
+      if (isInSVG) {
+        span = document.createElementNS("http://www.w3.org/2000/svg", "tspan");
+      } else {
+        span = document.createElement("span");
+        span.classList.add(className);
+      }
+
+      span.appendChild(document.createTextNode(val.substr(pos, text.length)));
+      parent.insertBefore(
+        span,
+        parent.insertBefore(
+          document.createTextNode(val.substr(pos + text.length)),
+          node.nextSibling
+        )
+      );
+      node.nodeValue = val.substr(0, pos);
+
+      if (isInSVG) {
+        const rect = document.createElementNS(
+          "http://www.w3.org/2000/svg",
+          "rect"
+        );
+        const bbox = parent.getBBox();
+        rect.x.baseVal.value = bbox.x;
+        rect.y.baseVal.value = bbox.y;
+        rect.width.baseVal.value = bbox.width;
+        rect.height.baseVal.value = bbox.height;
+        rect.setAttribute("class", className);
+        addItems.push({ parent: parent, target: rect });
+      }
+    }
+  } else if (node.matches && !node.matches("button, select, textarea")) {
+    node.childNodes.forEach((el) => _highlight(el, addItems, text, className));
+  }
+};
+const _highlightText = (thisNode, text, className) => {
+  let addItems = [];
+  _highlight(thisNode, addItems, text, className);
+  addItems.forEach((obj) =>
+    obj.parent.insertAdjacentElement("beforebegin", obj.target)
+  );
+};
+
+/**
+ * Small JavaScript module for the documentation.
+ */
+const Documentation = {
+  init: () => {
+    Documentation.highlightSearchWords();
+    Documentation.initDomainIndexTable();
+    Documentation.initOnKeyListeners();
+  },
+
+  /**
+   * i18n support
+   */
+  TRANSLATIONS: {},
+  PLURAL_EXPR: (n) => (n === 1 ? 0 : 1),
+  LOCALE: "unknown",
+
+  // gettext and ngettext don't access this so that the functions
+  // can safely bound to a different name (_ = Documentation.gettext)
+  gettext: (string) => {
+    const translated = Documentation.TRANSLATIONS[string];
+    switch (typeof translated) {
+      case "undefined":
+        return string; // no translation
+      case "string":
+        return translated; // translation exists
+      default:
+        return translated[0]; // (singular, plural) translation tuple exists
+    }
+  },
+
+  ngettext: (singular, plural, n) => {
+    const translated = Documentation.TRANSLATIONS[singular];
+    if (typeof translated !== "undefined")
+      return translated[Documentation.PLURAL_EXPR(n)];
+    return n === 1 ? singular : plural;
+  },
+
+  addTranslations: (catalog) => {
+    Object.assign(Documentation.TRANSLATIONS, catalog.messages);
+    Documentation.PLURAL_EXPR = new Function(
+      "n",
+      `return (${catalog.plural_expr})`
+    );
+    Documentation.LOCALE = catalog.locale;
+  },
+
+  /**
+   * highlight the search words provided in the url in the text
+   */
+  highlightSearchWords: () => {
+    const highlight =
+      new URLSearchParams(window.location.search).get("highlight") || "";
+    const terms = highlight.toLowerCase().split(/\s+/).filter(x => x);
+    if (terms.length === 0) return; // nothing to do
+
+    // There should never be more than one element matching "div.body"
+    const divBody = document.querySelectorAll("div.body");
+    const body = divBody.length ? divBody[0] : document.querySelector("body");
+    window.setTimeout(() => {
+      terms.forEach((term) => _highlightText(body, term, "highlighted"));
+    }, 10);
+
+    const searchBox = document.getElementById("searchbox");
+    if (searchBox === null) return;
+    searchBox.appendChild(
+      document
+        .createRange()
+        .createContextualFragment(
+          '<p class="highlight-link">' +
+            '<a href="javascript:Documentation.hideSearchWords()">' +
+            Documentation.gettext("Hide Search Matches") +
+            "</a></p>"
+        )
+    );
+  },
+
+  /**
+   * helper function to hide the search marks again
+   */
+  hideSearchWords: () => {
+    document
+      .querySelectorAll("#searchbox .highlight-link")
+      .forEach((el) => el.remove());
+    document
+      .querySelectorAll("span.highlighted")
+      .forEach((el) => el.classList.remove("highlighted"));
+    const url = new URL(window.location);
+    url.searchParams.delete("highlight");
+    window.history.replaceState({}, "", url);
+  },
+
+  /**
+   * helper function to focus on search bar
+   */
+  focusSearchBar: () => {
+    document.querySelectorAll("input[name=q]")[0]?.focus();
+  },
+
+  /**
+   * Initialise the domain index toggle buttons
+   */
+  initDomainIndexTable: () => {
+    const toggler = (el) => {
+      const idNumber = el.id.substr(7);
+      const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`);
+      if (el.src.substr(-9) === "minus.png") {
+        el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`;
+        toggledRows.forEach((el) => (el.style.display = "none"));
+      } else {
+        el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`;
+        toggledRows.forEach((el) => (el.style.display = ""));
+      }
+    };
+
+    const togglerElements = document.querySelectorAll("img.toggler");
+    togglerElements.forEach((el) =>
+      el.addEventListener("click", (event) => toggler(event.currentTarget))
+    );
+    togglerElements.forEach((el) => (el.style.display = ""));
+    if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler);
+  },
+
+  initOnKeyListeners: () => {
+    // only install a listener if it is really needed
+    if (
+      !DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS &&
+      !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS
+    )
+      return;
+
+    const blacklistedElements = new Set([
+      "TEXTAREA",
+      "INPUT",
+      "SELECT",
+      "BUTTON",
+    ]);
+    document.addEventListener("keydown", (event) => {
+      if (blacklistedElements.has(document.activeElement.tagName)) return; // bail for input elements
+      if (event.altKey || event.ctrlKey || event.metaKey) return; // bail with special keys
+
+      if (!event.shiftKey) {
+        switch (event.key) {
+          case "ArrowLeft":
+            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break;
+
+            const prevLink = document.querySelector('link[rel="prev"]');
+            if (prevLink && prevLink.href) {
+              window.location.href = prevLink.href;
+              event.preventDefault();
+            }
+            break;
+          case "ArrowRight":
+            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break;
+
+            const nextLink = document.querySelector('link[rel="next"]');
+            if (nextLink && nextLink.href) {
+              window.location.href = nextLink.href;
+              event.preventDefault();
+            }
+            break;
+          case "Escape":
+            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break;
+            Documentation.hideSearchWords();
+            event.preventDefault();
+        }
+      }
+
+      // some keyboard layouts may need Shift to get /
+      switch (event.key) {
+        case "/":
+          if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break;
+          Documentation.focusSearchBar();
+          event.preventDefault();
+      }
+    });
+  },
+};
+
+// quick alias for translations
+const _ = Documentation.gettext;
+
+_ready(Documentation.init);
diff --git a/docs/apache-airflow-providers-common-sql/stable/_static/documentation_options.js b/docs/apache-airflow-providers-common-sql/1.1.0/_static/documentation_options.js
similarity index 85%
copy from docs/apache-airflow-providers-common-sql/stable/_static/documentation_options.js
copy to docs/apache-airflow-providers-common-sql/1.1.0/_static/documentation_options.js
index 95926d9eea..5016d1608a 100644
--- a/docs/apache-airflow-providers-common-sql/stable/_static/documentation_options.js
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/documentation_options.js
@@ -1,6 +1,6 @@
 var DOCUMENTATION_OPTIONS = {
     URL_ROOT: document.getElementById("documentation_options").getAttribute('data-url_root'),
-    VERSION: '1.0.0',
+    VERSION: '1.1.0',
     LANGUAGE: 'en',
     COLLAPSE_INDEX: false,
     BUILDER: 'html',
@@ -10,5 +10,5 @@ var DOCUMENTATION_OPTIONS = {
     SOURCELINK_SUFFIX: '.txt',
     NAVIGATION_WITH_KEYS: false,
     SHOW_SEARCH_SUMMARY: true,
-    ENABLE_SEARCH_SHORTCUTS: false,
+    ENABLE_SEARCH_SHORTCUTS: true,
 };
\ No newline at end of file
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/file.png b/docs/apache-airflow-providers-common-sql/1.1.0/_static/file.png
new file mode 100644
index 0000000000..a858a410e4
Binary files /dev/null and b/docs/apache-airflow-providers-common-sql/1.1.0/_static/file.png differ
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/graphviz.css b/docs/apache-airflow-providers-common-sql/1.1.0/_static/graphviz.css
new file mode 100644
index 0000000000..19e7afd385
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/graphviz.css
@@ -0,0 +1,19 @@
+/*
+ * graphviz.css
+ * ~~~~~~~~~~~~
+ *
+ * Sphinx stylesheet -- graphviz extension.
+ *
+ * :copyright: Copyright 2007-2022 by the Sphinx team, see AUTHORS.
+ * :license: BSD, see LICENSE for details.
+ *
+ */
+
+img.graphviz {
+    border: 0;
+    max-width: 100%;
+}
+
+object.graphviz {
+    max-width: 100%;
+}
diff --git a/docs/apache-airflow-providers-common-sql/1.1.0/_static/jquery-3.6.0.js b/docs/apache-airflow-providers-common-sql/1.1.0/_static/jquery-3.6.0.js
new file mode 100644
index 0000000000..fc6c299b73
--- /dev/null
+++ b/docs/apache-airflow-providers-common-sql/1.1.0/_static/jquery-3.6.0.js
@@ -0,0 +1,10881 @@
+/*!
+ * jQuery JavaScript Library v3.6.0
+ * https://jquery.com/
+ *
+ * Includes Sizzle.js
+ * https://sizzlejs.com/
+ *
+ * Copyright OpenJS Foundation and other contributors
+ * Released under the MIT license
+ * https://jquery.org/license
+ *
+ * Date: 2021-03-02T17:08Z
+ */
+( function( global, factory ) {
+
+	"use strict";
+
+	if ( typeof module === "object" && typeof module.exports === "object" ) {
+
+		// For CommonJS and CommonJS-like environments where a proper `window`
+		// is present, execute the factory and get jQuery.
+		// For environments that do not have a `window` with a `document`
+		// (such as Node.js), expose a factory as module.exports.
+		// This accentuates the need for the creation of a real `window`.
+		// e.g. var jQuery = require("jquery")(window);
+		// See ticket #14549 for more info.
+		module.exports = global.document ?
+			factory( global, true ) :
+			function( w ) {
+				if ( !w.document ) {
+					throw new Error( "jQuery requires a window with a document" );
+				}
+				return factory( w );
+			};
+	} else {
+		factory( global );
+	}
+
+// Pass this if window is not defined yet
+} )( typeof window !== "undefined" ? window : this, function( window, noGlobal ) {
+
+// Edge <= 12 - 13+, Firefox <=18 - 45+, IE 10 - 11, Safari 5.1 - 9+, iOS 6 - 9.1
+// throw exceptions when non-strict code (e.g., ASP.NET 4.5) accesses strict mode
+// arguments.callee.caller (trac-13335). But as of jQuery 3.0 (2016), strict mode should be common
+// enough that all such attempts are guarded in a try block.
+"use strict";
+
+var arr = [];
+
+var getProto = Object.getPrototypeOf;
+
+var slice = arr.slice;
+
+var flat = arr.flat ? function( array ) {
+	return arr.flat.call( array );
+} : function( array ) {
+	return arr.concat.apply( [], array );
+};
+
+
+var push = arr.push;
+
+var indexOf = arr.indexOf;
+
+var class2type = {};
+
+var toString = class2type.toString;
+
+var hasOwn = class2type.hasOwnProperty;
+
+var fnToString = hasOwn.toString;
+
+var ObjectFunctionString = fnToString.call( Object );
+
+var support = {};
+
+var isFunction = function isFunction( obj ) {
+
+		// Support: Chrome <=57, Firefox <=52
+		// In some browsers, typeof returns "function" for HTML <object> elements
+		// (i.e., `typeof document.createElement( "object" ) === "function"`).
+		// We don't want to classify *any* DOM node as a function.
+		// Support: QtWeb <=3.8.5, WebKit <=534.34, wkhtmltopdf tool <=0.12.5
+		// Plus for old WebKit, typeof returns "function" for HTML collections
+		// (e.g., `typeof document.getElementsByTagName("div") === "function"`). (gh-4756)
+		return typeof obj === "function" && typeof obj.nodeType !== "number" &&
+			typeof obj.item !== "function";
+	};
+
+
+var isWindow = function isWindow( obj ) {
+		return obj != null && obj === obj.window;
+	};
+
+
+var document = window.document;
+
+
+
+	var preservedScriptAttributes = {
+		type: true,
+		src: true,
+		nonce: true,
+		noModule: true
+	};
+
+	function DOMEval( code, node, doc ) {
+		doc = doc || document;
+
+		var i, val,
+			script = doc.createElement( "script" );
+
+		script.text = code;
+		if ( node ) {
+			for ( i in preservedScriptAttributes ) {
+
+				// Support: Firefox 64+, Edge 18+
+				// Some browsers don't support the "nonce" property on scripts.
+				// On the other hand, just using `getAttribute` is not enough as
+				// the `nonce` attribute is reset to an empty string whenever it
+				// becomes browsing-context connected.
+				// See https://github.com/whatwg/html/issues/2369
+				// See https://html.spec.whatwg.org/#nonce-attributes
+				// The `node.getAttribute` check was added for the sake of
+				// `jQuery.globalEval` so that it can fake a nonce-containing node
+				// via an object.
+				val = node[ i ] || node.getAttribute && node.getAttribute( i );
+				if ( val ) {
+					script.setAttribute( i, val );
+				}
+			}
+		}
+		doc.head.appendChild( script ).parentNode.removeChild( script );
+	}
+
+
+function toType( obj ) {
+	if ( obj == null ) {
+		return obj + "";
+	}
+
+	// Support: Android <=2.3 only (functionish RegExp)
+	return typeof obj === "object" || typeof obj === "function" ?
+		class2type[ toString.call( obj ) ] || "object" :
+		typeof obj;
+}
+/* global Symbol */
+// Defining this global in .eslintrc.json would create a danger of using the global
+// unguarded in another place, it seems safer to define global only for this module
+
+
+
+var
+	version = "3.6.0",
+
+	// Define a local copy of jQuery
+	jQuery = function( selector, context ) {
+
+		// The jQuery object is actually just the init constructor 'enhanced'
+		// Need init if jQuery is called (just allow error to be thrown if not included)
+		return new jQuery.fn.init( selector, context );
+	};
+
+jQuery.fn = jQuery.prototype = {
+
+	// The current version of jQuery being used
+	jquery: version,
+
+	constructor: jQuery,
+
+	// The default length of a jQuery object is 0
+	length: 0,
+
+	toArray: function() {
+		return slice.call( this );
+	},
+
+	// Get the Nth element in the matched element set OR
+	// Get the whole matched element set as a clean array
+	get: function( num ) {
+
+		// Return all the elements in a clean array
+		if ( num == null ) {
+			return slice.call( this );
+		}
+
+		// Return just the one element from the set
+		return num < 0 ? this[ num + this.length ] : this[ num ];
+	},
+
+	// Take an array of elements and push it onto the stack
+	// (returning the new matched element set)
+	pushStack: function( elems ) {
+
+		// Build a new jQuery matched element set
+		var ret = jQuery.merge( this.constructor(), elems );
+
+		// Add the old object onto the stack (as a reference)
+		ret.prevObject = this;
+
+		// Return the newly-formed element set
+		return ret;
+	},
+
+	// Execute a callback for every element in the matched set.
+	each: function( callback ) {
+		return jQuery.each( this, callback );
+	},
+
+	map: function( callback ) {
+		return this.pushStack( jQuery.map( this, function( elem, i ) {
+			return callback.call( elem, i, elem );
+		} ) );
+	},
+
+	slice: function() {
+		return this.pushStack( slice.apply( this, arguments ) );
+	},
+
+	first: function() {
+		return this.eq( 0 );
+	},
+
+	last: function() {
+		return this.eq( -1 );
+	},
+
+	even: function() {
+		return this.pushStack( jQuery.grep( this, function( _elem, i ) {
+			return ( i + 1 ) % 2;
+		} ) );
+	},
+
+	odd: function() {
+		return this.pushStack( jQuery.grep( this, function( _elem, i ) {
+			return i % 2;
+		} ) );
+	},
+
+	eq: function( i ) {
+		var len = this.length,
+			j = +i + ( i < 0 ? len : 0 );
+		return this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] );
+	},
+
+	end: function() {
+		return this.prevObject || this.constructor();
+	},
+
+	// For internal use only.
+	// Behaves like an Array's method, not like a jQuery method.
+	push: push,
+	sort: arr.sort,
+	splice: arr.splice
+};
+
+jQuery.extend = jQuery.fn.extend = function() {
+	var options, name, src, copy, copyIsArray, clone,
+		target = arguments[ 0 ] || {},
+		i = 1,
+		length = arguments.length,
+		deep = false;
+
+	// Handle a deep copy situation
+	if ( typeof target === "boolean" ) {
+		deep = target;
+
+		// Skip the boolean and the target
+		target = arguments[ i ] || {};
+		i++;
+	}
+
+	// Handle case when target is a string or something (possible in deep copy)
+	if ( typeof target !== "object" && !isFunction( target ) ) {
+		target = {};
+	}
+
+	// Extend jQuery itself if only one argument is passed
+	if ( i === length ) {
+		target = this;
+		i--;
+	}
+
+	for ( ; i < length; i++ ) {
+
+		// Only deal with non-null/undefined values
+		if ( ( options = arguments[ i ] ) != null ) {
+
+			// Extend the base object
+			for ( name in options ) {
+				copy = options[ name ];
+
+				// Prevent Object.prototype pollution
+				// Prevent never-ending loop
+				if ( name === "__proto__" || target === copy ) {
+					continue;
+				}
+
+				// Recurse if we're merging plain objects or arrays
+				if ( deep && copy && ( jQuery.isPlainObject( copy ) ||
+					( copyIsArray = Array.isArray( copy ) ) ) ) {
+					src = target[ name ];
+
+					// Ensure proper type for the source value
+					if ( copyIsArray && !Array.isArray( src ) ) {
+						clone = [];
+					} else if ( !copyIsArray && !jQuery.isPlainObject( src ) ) {
+						clone = {};
+					} else {
+						clone = src;
+					}
+					copyIsArray = false;
+
+					// Never move original objects, clone them
+					target[ name ] = jQuery.extend( deep, clone, copy );
+
+				// Don't bring in undefined values
+				} else if ( copy !== undefined ) {
+					target[ name ] = copy;
+				}
+			}
+		}
+	}
+
+	// Return the modified object
+	return target;
+};
+
+jQuery.extend( {
+
+	// Unique for each copy of jQuery on the page
+	expando: "jQuery" + ( version + Math.random() ).replace( /\D/g, "" ),
+
+	// Assume jQuery is ready without the ready module
+	isReady: true,
+
+	error: function( msg ) {
+		throw new Error( msg );
+	},
+
+	noop: function() {},
+
+	isPlainObject: function( obj ) {
+		var proto, Ctor;
+
+		// Detect obvious negatives
+		// Use toString instead of jQuery.type to catch host objects
+		if ( !obj || toString.call( obj ) !== "[object Object]" ) {
+			return false;
+		}
+
+		proto = getProto( obj );
+
+		// Objects with no prototype (e.g., `Object.create( null )`) are plain
+		if ( !proto ) {
+			return true;
+		}
+
+		// Objects with prototype are plain iff they were constructed by a global Object function
+		Ctor = hasOwn.call( proto, "constructor" ) && proto.constructor;
+		return typeof Ctor === "function" && fnToString.call( Ctor ) === ObjectFunctionString;
+	},
+
+	isEmptyObject: function( obj ) {
+		var name;
+
+		for ( name in obj ) {
+			return false;
+		}
+		return true;
+	},
+
+	// Evaluates a script in a provided context; falls back to the global one
+	// if not specified.
+	globalEval: function( code, options, doc ) {
+		DOMEval( code, { nonce: options && options.nonce }, doc );
+	},
+
+	each: function( obj, callback ) {
+		var length, i = 0;
+
+		if ( isArrayLike( obj ) ) {
+			length = obj.length;
+			for ( ; i < length; i++ ) {
+				if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {
+					break;
+				}
+			}
+		} else {
+			for ( i in obj ) {
+				if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {
+					break;
+				}
+			}
+		}
+
+		return obj;
+	},
+
+	// results is for internal usage only
+	makeArray: function( arr, results ) {
+		var ret = results || [];
+
+		if ( arr != null ) {
+			if ( isArrayLike( Object( arr ) ) ) {
+				jQuery.merge( ret,
+					typeof arr === "string" ?
+						[ arr ] : arr
+				);
+			} else {
+				push.call( ret, arr );
+			}
+		}
+
+		return ret;
+	},
+
+	inArray: function( elem, arr, i ) {
+		return arr == null ? -1 : indexOf.call( arr, elem, i );
+	},
+
+	// Support: Android <=4.0 only, PhantomJS 1 only
+	// push.apply(_, arraylike) throws on ancient WebKit
+	merge: function( first, second ) {
+		var len = +second.length,
+			j = 0,
+			i = first.length;
+
+		for ( ; j < len; j++ ) {
+			first[ i++ ] = second[ j ];
+		}
+
+		first.length = i;
+
+		return first;
+	},
+
+	grep: function( elems, callback, invert ) {
+		var callbackInverse,
+			matches = [],
+			i = 0,
+			length = elems.length,
+			callbackExpect = !invert;
+
+		// Go through the array, only saving the items
+		// that pass the validator function
+		for ( ; i < length; i++ ) {
+			callbackInverse = !callback( elems[ i ], i );
+			if ( callbackInverse !== callbackExpect ) {
+				matches.push( elems[ i ] );
+			}
+		}
+
+		return matches;
+	},
+
+	// arg is for internal usage only
+	map: function( elems, callback, arg ) {
+		var length, value,
+			i = 0,
+			ret = [];
+
+		// Go through the array, translating each of the items to their new values
+		if ( isArrayLike( elems ) ) {
+			length = elems.length;
+			for ( ; i < length; i++ ) {
+				value = callback( elems[ i ], i, arg );
+
+				if ( value != null ) {
+					ret.push( value );
+				}
+			}
+
+		// Go through every key on the object,
+		} else {
+			for ( i in elems ) {
+				value = callback( elems[ i ], i, arg );
+
+				if ( value != null ) {
+					ret.push( value );
+				}
+			}
+		}
+
+		// Flatten any nested arrays
+		return flat( ret );
+	},
+
+	// A global GUID counter for objects
+	guid: 1,
+
+	// jQuery.support is not used in Core but other projects attach their
+	// properties to it so it needs to exist.
+	support: support
+} );
+
+if ( typeof Symbol === "function" ) {
+	jQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ];
+}
+
+// Populate the class2type map
+jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ),
+	function( _i, name ) {
+		class2type[ "[object " + name + "]" ] = name.toLowerCase();
+	} );
+
+function isArrayLike( obj ) {
+
+	// Support: real iOS 8.2 only (not reproducible in simulator)
+	// `in` check used to prevent JIT error (gh-2145)
+	// hasOwn isn't used here due to false negatives
+	// regarding Nodelist length in IE
+	var length = !!obj && "length" in obj && obj.length,
+		type = toType( obj );
+
+	if ( isFunction( obj ) || isWindow( obj ) ) {
+		return false;
+	}
+
+	return type === "array" || length === 0 ||
+		typeof length === "number" && length > 0 && ( length - 1 ) in obj;
+}
+var Sizzle =
+/*!
+ * Sizzle CSS Selector Engine v2.3.6
+ * https://sizzlejs.com/
+ *
+ * Copyright JS Foundation and other contributors
+ * Released under the MIT license
+ * https://js.foundation/
+ *
+ * Date: 2021-02-16
+ */
+( function( window ) {
+var i,
+	support,
+	Expr,
+	getText,
+	isXML,
+	tokenize,
+	compile,
+	select,
+	outermostContext,
+	sortInput,
+	hasDuplicate,
+
+	// Local document vars
+	setDocument,
+	document,
+	docElem,
+	documentIsHTML,
+	rbuggyQSA,
+	rbuggyMatches,
+	matches,
+	contains,
+
+	// Instance-specific data
+	expando = "sizzle" + 1 * new Date(),
+	preferredDoc = window.document,
+	dirruns = 0,
+	done = 0,
+	classCache = createCache(),
+	tokenCache = createCache(),
+	compilerCache = createCache(),
+	nonnativeSelectorCache = createCache(),
+	sortOrder = function( a, b ) {
+		if ( a === b ) {
+			hasDuplicate = true;
+		}
+		return 0;
+	},
+
+	// Instance methods
+	hasOwn = ( {} ).hasOwnProperty,
+	arr = [],
+	pop = arr.pop,
+	pushNative = arr.push,
+	push = arr.push,
+	slice = arr.slice,
+
+	// Use a stripped-down indexOf as it's faster than native
+	// https://jsperf.com/thor-indexof-vs-for/5
+	indexOf = function( list, elem ) {
+		var i = 0,
+			len = list.length;
+		for ( ; i < len; i++ ) {
+			if ( list[ i ] === elem ) {
+				return i;
+			}
+		}
+		return -1;
+	},
+
+	booleans = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|" +
+		"ismap|loop|multiple|open|readonly|required|scoped",
+
+	// Regular expressions
+
+	// http://www.w3.org/TR/css3-selectors/#whitespace
+	whitespace = "[\\x20\\t\\r\\n\\f]",
+
+	// https://www.w3.org/TR/css-syntax-3/#ident-token-diagram
+	identifier = "(?:\\\\[\\da-fA-F]{1,6}" + whitespace +
+		"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",
+
+	// Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors
+	attributes = "\\[" + whitespace + "*(" + identifier + ")(?:" + whitespace +
+
+		// Operator (capture 2)
+		"*([*^$|!~]?=)" + whitespace +
+
+		// "Attribute values must be CSS identifiers [capture 5]
+		// or strings [capture 3 or capture 4]"
+		"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + identifier + "))|)" +
+		whitespace + "*\\]",
+
+	pseudos = ":(" + identifier + ")(?:\\((" +
+
+		// To reduce the number of selectors needing tokenize in the preFilter, prefer arguments:
+		// 1. quoted (capture 3; capture 4 or capture 5)
+		"('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|" +
+
+		// 2. simple (capture 6)
+		"((?:\\\\.|[^\\\\()[\\]]|" + attributes + ")*)|" +
+
+		// 3. anything else (capture 2)
+		".*" +
+		")\\)|)",
+
+	// Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter
+	rwhitespace = new RegExp( whitespace + "+", "g" ),
+	rtrim = new RegExp( "^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" +
+		whitespace + "+$", "g" ),
+
+	rcomma = new RegExp( "^" + whitespace + "*," + whitespace + "*" ),
+	rcombinators = new RegExp( "^" + whitespace + "*([>+~]|" + whitespace + ")" + whitespace +
+		"*" ),
+	rdescend = new RegExp( whitespace + "|>" ),
+
+	rpseudo = new RegExp( pseudos ),
+	ridentifier = new RegExp( "^" + identifier + "$" ),
+
+	matchExpr = {
+		"ID": new RegExp( "^#(" + identifier + ")" ),
+		"CLASS": new RegExp( "^\\.(" + identifier + ")" ),
+		"TAG": new RegExp( "^(" + identifier + "|[*])" ),
+		"ATTR": new RegExp( "^" + attributes ),
+		"PSEUDO": new RegExp( "^" + pseudos ),
+		"CHILD": new RegExp( "^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" +
+			whitespace + "*(even|odd|(([+-]|)(\\d*)n|)" + whitespace + "*(?:([+-]|)" +
+			whitespace + "*(\\d+)|))" + whitespace + "*\\)|)", "i" ),
+		"bool": new RegExp( "^(?:" + booleans + ")$", "i" ),
+
+		// For use in libraries implementing .is()
+		// We use this for POS matching in `select`
+		"needsContext": new RegExp( "^" + whitespace +
+			"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + whitespace +
+			"*((?:-\\d)?\\d*)" + whitespace + "*\\)|)(?=[^-]|$)", "i" )
+	},
+
+	rhtml = /HTML$/i,
+	rinputs = /^(?:input|select|textarea|button)$/i,
+	rheader = /^h\d$/i,
+
+	rnative = /^[^{]+\{\s*\[native \w/,
+
+	// Easily-parseable/retrievable ID or TAG or CLASS selectors
+	rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
+
+	rsibling = /[+~]/,
+
+	// CSS escapes
+	// http://www.w3.org/TR/CSS21/syndata.html#escaped-characters
+	runescape = new RegExp( "\\\\[\\da-fA-F]{1,6}" + whitespace + "?|\\\\([^\\r\\n\\f])", "g" ),
+	funescape = function( escape, nonHex ) {
+		var high = "0x" + escape.slice( 1 ) - 0x10000;
+
+		return nonHex ?
+
+			// Strip the backslash prefix from a non-hex escape sequence
+			nonHex :
+
+			// Replace a hexadecimal escape sequence with the encoded Unicode code point
+			// Support: IE <=11+
+			// For values outside the Basic Multilingual Plane (BMP), manually construct a
+			// surrogate pair
+			high < 0 ?
+				String.fromCharCode( high + 0x10000 ) :
+				String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 );
+	},
+
+	// CSS string/identifier serialization
+	// https://drafts.csswg.org/cssom/#common-serializing-idioms
+	rcssescape = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,
+	fcssescape = function( ch, asCodePoint ) {
+		if ( asCodePoint ) {
+
+			// U+0000 NULL becomes U+FFFD REPLACEMENT CHARACTER
+			if ( ch === "\0" ) {
+				return "\uFFFD";
+			}
+
+			// Control characters and (dependent upon position) numbers get escaped as code points
+			return ch.slice( 0, -1 ) + "\\" +
+				ch.charCodeAt( ch.length - 1 ).toString( 16 ) + " ";
+		}
+
+		// Other potentially-special ASCII characters get backslash-escaped
+		return "\\" + ch;
+	},
+
+	// Used for iframes
+	// See setDocument()
+	// Removing the function wrapper causes a "Permission Denied"
+	// error in IE
+	unloadHandler = function() {
+		setDocument();
+	},
+
+	inDisabledFieldset = addCombinator(
+		function( elem ) {
+			return elem.disabled === true && elem.nodeName.toLowerCase() === "fieldset";
+		},
+		{ dir: "parentNode", next: "legend" }
+	);
+
+// Optimize for push.apply( _, NodeList )
+try {
+	push.apply(
+		( arr = slice.call( preferredDoc.childNodes ) ),
+		preferredDoc.childNodes
+	);
+
+	// Support: Android<4.0
+	// Detect silently failing push.apply
+	// eslint-disable-next-line no-unused-expressions
+	arr[ preferredDoc.childNodes.length ].nodeType;
+} catch ( e ) {
+	push = { apply: arr.length ?
+
+		// Leverage slice if possible
+		function( target, els ) {
+			pushNative.apply( target, slice.call( els ) );
+		} :
+
+		// Support: IE<9
+		// Otherwise append directly
+		function( target, els ) {
+			var j = target.length,
+				i = 0;
+
+			// Can't trust NodeList.length
+			while ( ( target[ j++ ] = els[ i++ ] ) ) {}
+			target.length = j - 1;
+		}
+	};
+}
+
+function Sizzle( selector, context, results, seed ) {
+	var m, i, elem, nid, match, groups, newSelector,
+		newContext = context && context.ownerDocument,
+
+		// nodeType defaults to 9, since context defaults to document
+		nodeType = context ? context.nodeType : 9;
+
+	results = results || [];
+
+	// Return early from calls with invalid selector or context
+	if ( typeof selector !== "string" || !selector ||
+		nodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) {
+
+		return results;
+	}
+
+	// Try to shortcut find operations (as opposed to filters) in HTML documents
+	if ( !seed ) {
+		setDocument( context );
+		context = context || document;
+
+		if ( documentIsHTML ) {
+
+			// If the selector is sufficiently simple, try using a "get*By*" DOM method
+			// (excepting DocumentFragment context, where the methods don't exist)
+			if ( nodeType !== 11 && ( match = rquickExpr.exec( selector ) ) ) {
+
+				// ID selector
+				if ( ( m = match[ 1 ] ) ) {
+
+					// Document context
+					if ( nodeType === 9 ) {
+						if ( ( elem = context.getElementById( m ) ) ) {
+
+							// Support: IE, Opera, Webkit
+							// TODO: identify versions
+							// getElementById can match elements by name instead of ID
+							if ( elem.id === m ) {
+								results.push( elem );
+								return results;
+							}
+						} else {
+							return results;
+						}
+
+					// Element context
+					} else {
+
+						// Support: IE, Opera, Webkit
+						// TODO: identify versions
+						// getElementById can match elements by name instead of ID
+						if ( newContext && ( elem = newContext.getElementById( m ) ) &&
+							contains( context, elem ) &&
+							elem.id === m ) {
+
+							results.push( elem );
+							return results;
+						}
+					}
+
+				// Type selector
+				} else if ( match[ 2 ] ) {
+					push.apply( results, context.getElementsByTagName( selector ) );
+					return results;
+
+				// Class selector
+				} else if ( ( m = match[ 3 ] ) && support.getElementsByClassName &&
+					context.getElementsByClassName ) {
+
+					push.apply( results, context.getElementsByClassName( m ) );
+					return results;
+				}
+			}
+
+			// Take advantage of querySelectorAll
+			if ( support.qsa &&
+				!nonnativeSelectorCache[ selector + " " ] &&
+				( !rbuggyQSA || !rbuggyQSA.test( selector ) ) &&
+
+				// Support: IE 8 only
+				// Exclude object elements
+				( nodeType !== 1 || context.nodeName.toLowerCase() !== "object" ) ) {
+
+				newSelector = selector;
+				newContext = context;
+
+				// qSA considers elements outside a scoping root when evaluating child or
+				// descendant combinators, which is not what we want.
+				// In such cases, we work around the behavior by prefixing every selector in the
+				// list with an ID selector referencing the scope context.
+				// The technique has to be used as well when a leading combinator is used
+				// as such selectors are not recognized by querySelectorAll.
+				// Thanks to Andrew Dupont for this technique.
+				if ( nodeType === 1 &&
+					( rdescend.test( selector ) || rcombinators.test( selector ) ) ) {
+
+					// Expand context for sibling selectors
+					newContext = rsibling.test( selector ) && testContext( context.parentNode ) ||
+						context;
+
+					// We can use :scope instead of the ID hack if the browser
+					// supports it & if we're not changing the context.
+					if ( newContext !== context || !support.scope ) {
+
+						// Capture the context ID, setting it first if necessary
+						if ( ( nid = context.getAttribute( "id" ) ) ) {
+							nid = nid.replace( rcssescape, fcssescape );
+						} else {
+							context.setAttribute( "id", ( nid = expando ) );
+						}
+					}
+
+					// Prefix every selector in the list
+					groups = tokenize( selector );
+					i = groups.length;
+					while ( i-- ) {
+						groups[ i ] = ( nid ? "#" + nid : ":scope" ) + " " +
+							toSelector( groups[ i ] );
+					}
+					newSelector = groups.join( "," );
+				}
+
+				try {
+					push.apply( results,
+						newContext.querySelectorAll( newSelector )
+					);
+					return results;
+				} catch ( qsaError ) {
+					nonnativeSelectorCache( selector, true );
+				} finally {
+					if ( nid === expando ) {
+						context.removeAttribute( "id" );
+					}
+				}
+			}
+		}
+	}
+
+	// All others
+	return select( selector.replace( rtrim, "$1" ), context, results, seed );
+}
+
+/**
+ * Create key-value caches of limited size
+ * @returns {function(string, object)} Returns the Object data after storing it on itself with
+ *	property name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength)
+ *	deleting the oldest entry
+ */
+function createCache() {
+	var keys = [];
+
+	function cache( key, value ) {
+
+		// Use (key + " ") to avoid collision with native prototype properties (see Issue #157)
+		if ( keys.push( key + " " ) > Expr.cacheLength ) {
+
+			// Only keep the most recent entries
+			delete cache[ keys.shift() ];
+		}
+		return ( cache[ key + " " ] = value );
+	}
+	return cache;
+}
+
+/**
+ * Mark a function for special use by Sizzle
+ * @param {Function} fn The function to mark
+ */
+function markFunction( fn ) {
+	fn[ expando ] = true;
+	return fn;
+}
+
+/**
+ * Support testing using an element
+ * @param {Function} fn Passed the created element and returns a boolean result
+ */
+function assert( fn ) {
+	var el = document.createElement( "fieldset" );
+
+	try {
+		return !!fn( el );
+	} catch ( e ) {
+		return false;
+	} finally {
+
+		// Remove from its parent by default
+		if ( el.parentNode ) {
+			el.parentNode.removeChild( el );
+		}
+
+		// release memory in IE
+		el = null;
+	}
+}
+
+/**
+ * Adds the same handler for all of the specified attrs
+ * @param {String} attrs Pipe-separated list of attributes
+ * @param {Function} handler The method that will be applied
+ */
+function addHandle( attrs, handler ) {
+	var arr = attrs.split( "|" ),
+		i = arr.length;
+
+	while ( i-- ) {
+		Expr.attrHandle[ arr[ i ] ] = handler;
+	}
+}
+
+/**
+ * Checks document order of two siblings
+ * @param {Element} a
+ * @param {Element} b
+ * @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b
+ */
+function siblingCheck( a, b ) {
+	var cur = b && a,
+		diff = cur && a.nodeType === 1 && b.nodeType === 1 &&
+			a.sourceIndex - b.sourceIndex;
+
+	// Use IE sourceIndex if available on both nodes
+	if ( diff ) {
+		return diff;
+	}
+
+	// Check if b follows a
+	if ( cur ) {
+		while ( ( cur = cur.nextSibling ) ) {
+			if ( cur === b ) {
+				return -1;
+			}
+		}
+	}
+
+	return a ? 1 : -1;
+}
+
+/**
+ * Returns a function to use in pseudos for input types
+ * @param {String} type
+ */
+function createInputPseudo( type ) {
+	return function( elem ) {
+		var name = elem.nodeName.toLowerCase();
+		return name === "input" && elem.type === type;
+	};
+}
+
+/**
+ * Returns a function to use in pseudos for buttons
+ * @param {String} type
+ */
+function createButtonPseudo( type ) {
+	return function( elem ) {
+		var name = elem.nodeName.toLowerCase();
+		return ( name === "input" || name === "button" ) && elem.type === type;
+	};
+}
+
+/**
+ * Returns a function to use in pseudos for :enabled/:disabled
+ * @param {Boolean} disabled true for :disabled; false for :enabled
+ */
+function createDisabledPseudo( disabled ) {
+
+	// Known :disabled false positives: fieldset[disabled] > legend:nth-of-type(n+2) :can-disable
+	return function( elem ) {
+
+		// Only certain elements can match :enabled or :disabled
+		// https://html.spec.whatwg.org/multipage/scripting.html#selector-enabled
+		// https://html.spec.whatwg.org/multipage/scripting.html#selector-disabled
+		if ( "form" in elem ) {
+
+			// Check for inherited disabledness on relevant non-disabled elements:
+			// * listed form-associated elements in a disabled fieldset
+			//   https://html.spec.whatwg.org/multipage/forms.html#category-listed
+			//   https://html.spec.whatwg.org/multipage/forms.html#concept-fe-disabled
+			// * option elements in a disabled optgroup
+			//   https://html.spec.whatwg.org/multipage/forms.html#concept-option-disabled
+			// All such elements have a "form" property.
+			if ( elem.parentNode && elem.disabled === false ) {
+
+				// Option elements defer to a parent optgroup if present
+				if ( "label" in elem ) {
+					if ( "label" in elem.parentNode ) {
+						return elem.parentNode.disabled === disabled;
+					} else {
+						return elem.disabled === disabled;
+					}
+				}
+
+				// Support: IE 6 - 11
+				// Use the isDisabled shortcut property to check for disabled fieldset ancestors
+				return elem.isDisabled === disabled ||
+
+					// Where there is no isDisabled, check manually
+					/* jshint -W018 */
+					elem.isDisabled !== !disabled &&
+					inDisabledFieldset( elem ) === disabled;
+			}
+
+			return elem.disabled === disabled;
+
+		// Try to winnow out elements that can't be disabled before trusting the disabled property.
+		// Some victims get caught in our net (label, legend, menu, track), but it shouldn't
+		// even exist on them, let alone have a boolean value.
+		} else if ( "label" in elem ) {
+			return elem.disabled === disabled;
+		}
+
+		// Remaining elements are neither :enabled nor :disabled
+		return false;
+	};
+}
+
+/**
+ * Returns a function to use in pseudos for positionals
+ * @param {Function} fn
+ */
+function createPositionalPseudo( fn ) {
+	return markFunction( function( argument ) {
+		argument = +argument;
+		return markFunction( function( seed, matches ) {
+			var j,
+				matchIndexes = fn( [], seed.length, argument ),
+				i = matchIndexes.length;
+
+			// Match elements found at the specified indexes
+			while ( i-- ) {
+				if ( seed[ ( j = matchIndexes[ i ] ) ] ) {
+					seed[ j ] = !( matches[ j ] = seed[ j ] );
+				}
+			}
+		} );
+	} );
+}
+
+/**
+ * Checks a node for validity as a Sizzle context
+ * @param {Element|Object=} context
+ * @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value
+ */
+function testContext( context ) {
+	return context && typeof context.getElementsByTagName !== "undefined" && context;
+}
+
+// Expose support vars for convenience
+support = Sizzle.support = {};
+
+/**
+ * Detects XML nodes
+ * @param {Element|Object} elem An element or a document
+ * @returns {Boolean} True iff elem is a non-HTML XML node
+ */
+isXML = Sizzle.isXML = function( elem ) {
+	var namespace = elem && elem.namespaceURI,
+		docElem = elem && ( elem.ownerDocument || elem ).documentElement;
+
+	// Support: IE <=8
+	// Assume HTML when documentElement doesn't yet exist, such as inside loading iframes
+	// https://bugs.jquery.com/ticket/4833
+	return !rhtml.test( namespace || docElem && docElem.nodeName || "HTML" );
+};
+
+/**
+ * Sets document-related variables once based on the current document
+ * @param {Element|Object} [doc] An element or document object to use to set the document
+ * @returns {Object} Returns the current document
+ */
+setDocument = Sizzle.setDocument = function( node ) {
+	var hasCompare, subWindow,
+		doc = node ? node.ownerDocument || node : preferredDoc;
+
+	// Return early if doc is invalid or already selected
+	// Support: IE 11+, Edge 17 - 18+
+	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+	// two documents; shallow comparisons work.
+	// eslint-disable-next-line eqeqeq
+	if ( doc == document || doc.nodeType !== 9 || !doc.documentElement ) {
+		return document;
+	}
+
+	// Update global variables
+	document = doc;
+	docElem = document.documentElement;
+	documentIsHTML = !isXML( document );
+
+	// Support: IE 9 - 11+, Edge 12 - 18+
+	// Accessing iframe documents after unload throws "permission denied" errors (jQuery #13936)
+	// Support: IE 11+, Edge 17 - 18+
+	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+	// two documents; shallow comparisons work.
+	// eslint-disable-next-line eqeqeq
+	if ( preferredDoc != document &&
+		( subWindow = document.defaultView ) && subWindow.top !== subWindow ) {
+
+		// Support: IE 11, Edge
+		if ( subWindow.addEventListener ) {
+			subWindow.addEventListener( "unload", unloadHandler, false );
+
+		// Support: IE 9 - 10 only
+		} else if ( subWindow.attachEvent ) {
+			subWindow.attachEvent( "onunload", unloadHandler );
+		}
+	}
+
+	// Support: IE 8 - 11+, Edge 12 - 18+, Chrome <=16 - 25 only, Firefox <=3.6 - 31 only,
+	// Safari 4 - 5 only, Opera <=11.6 - 12.x only
+	// IE/Edge & older browsers don't support the :scope pseudo-class.
+	// Support: Safari 6.0 only
+	// Safari 6.0 supports :scope but it's an alias of :root there.
+	support.scope = assert( function( el ) {
+		docElem.appendChild( el ).appendChild( document.createElement( "div" ) );
+		return typeof el.querySelectorAll !== "undefined" &&
+			!el.querySelectorAll( ":scope fieldset div" ).length;
+	} );
+
+	/* Attributes
+	---------------------------------------------------------------------- */
+
+	// Support: IE<8
+	// Verify that getAttribute really returns attributes and not properties
+	// (excepting IE8 booleans)
+	support.attributes = assert( function( el ) {
+		el.className = "i";
+		return !el.getAttribute( "className" );
+	} );
+
+	/* getElement(s)By*
+	---------------------------------------------------------------------- */
+
+	// Check if getElementsByTagName("*") returns only elements
+	support.getElementsByTagName = assert( function( el ) {
+		el.appendChild( document.createComment( "" ) );
+		return !el.getElementsByTagName( "*" ).length;
+	} );
+
+	// Support: IE<9
+	support.getElementsByClassName = rnative.test( document.getElementsByClassName );
+
+	// Support: IE<10
+	// Check if getElementById returns elements by name
+	// The broken getElementById methods don't pick up programmatically-set names,
+	// so use a roundabout getElementsByName test
+	support.getById = assert( function( el ) {
+		docElem.appendChild( el ).id = expando;
+		return !document.getElementsByName || !document.getElementsByName( expando ).length;
+	} );
+
+	// ID filter and find
+	if ( support.getById ) {
+		Expr.filter[ "ID" ] = function( id ) {
+			var attrId = id.replace( runescape, funescape );
+			return function( elem ) {
+				return elem.getAttribute( "id" ) === attrId;
+			};
+		};
+		Expr.find[ "ID" ] = function( id, context ) {
+			if ( typeof context.getElementById !== "undefined" && documentIsHTML ) {
+				var elem = context.getElementById( id );
+				return elem ? [ elem ] : [];
+			}
+		};
+	} else {
+		Expr.filter[ "ID" ] =  function( id ) {
+			var attrId = id.replace( runescape, funescape );
+			return function( elem ) {
+				var node = typeof elem.getAttributeNode !== "undefined" &&
+					elem.getAttributeNode( "id" );
+				return node && node.value === attrId;
+			};
+		};
+
+		// Support: IE 6 - 7 only
+		// getElementById is not reliable as a find shortcut
+		Expr.find[ "ID" ] = function( id, context ) {
+			if ( typeof context.getElementById !== "undefined" && documentIsHTML ) {
+				var node, i, elems,
+					elem = context.getElementById( id );
+
+				if ( elem ) {
+
+					// Verify the id attribute
+					node = elem.getAttributeNode( "id" );
+					if ( node && node.value === id ) {
+						return [ elem ];
+					}
+
+					// Fall back on getElementsByName
+					elems = context.getElementsByName( id );
+					i = 0;
+					while ( ( elem = elems[ i++ ] ) ) {
+						node = elem.getAttributeNode( "id" );
+						if ( node && node.value === id ) {
+							return [ elem ];
+						}
+					}
+				}
+
+				return [];
+			}
+		};
+	}
+
+	// Tag
+	Expr.find[ "TAG" ] = support.getElementsByTagName ?
+		function( tag, context ) {
+			if ( typeof context.getElementsByTagName !== "undefined" ) {
+				return context.getElementsByTagName( tag );
+
+			// DocumentFragment nodes don't have gEBTN
+			} else if ( support.qsa ) {
+				return context.querySelectorAll( tag );
+			}
+		} :
+
+		function( tag, context ) {
+			var elem,
+				tmp = [],
+				i = 0,
+
+				// By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too
+				results = context.getElementsByTagName( tag );
+
+			// Filter out possible comments
+			if ( tag === "*" ) {
+				while ( ( elem = results[ i++ ] ) ) {
+					if ( elem.nodeType === 1 ) {
+						tmp.push( elem );
+					}
+				}
+
+				return tmp;
+			}
+			return results;
+		};
+
+	// Class
+	Expr.find[ "CLASS" ] = support.getElementsByClassName && function( className, context ) {
+		if ( typeof context.getElementsByClassName !== "undefined" && documentIsHTML ) {
+			return context.getElementsByClassName( className );
+		}
+	};
+
+	/* QSA/matchesSelector
+	---------------------------------------------------------------------- */
+
+	// QSA and matchesSelector support
+
+	// matchesSelector(:active) reports false when true (IE9/Opera 11.5)
+	rbuggyMatches = [];
+
+	// qSa(:focus) reports false when true (Chrome 21)
+	// We allow this because of a bug in IE8/9 that throws an error
+	// whenever `document.activeElement` is accessed on an iframe
+	// So, we allow :focus to pass through QSA all the time to avoid the IE error
+	// See https://bugs.jquery.com/ticket/13378
+	rbuggyQSA = [];
+
+	if ( ( support.qsa = rnative.test( document.querySelectorAll ) ) ) {
+
+		// Build QSA regex
+		// Regex strategy adopted from Diego Perini
+		assert( function( el ) {
+
+			var input;
+
+			// Select is set to empty string on purpose
+			// This is to test IE's treatment of not explicitly
+			// setting a boolean content attribute,
+			// since its presence should be enough
+			// https://bugs.jquery.com/ticket/12359
+			docElem.appendChild( el ).innerHTML = "<a id='" + expando + "'></a>" +
+				"<select id='" + expando + "-\r\\' msallowcapture=''>" +
+				"<option selected=''></option></select>";
+
+			// Support: IE8, Opera 11-12.16
+			// Nothing should be selected when empty strings follow ^= or $= or *=
+			// The test attribute must be unknown in Opera but "safe" for WinRT
+			// https://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section
+			if ( el.querySelectorAll( "[msallowcapture^='']" ).length ) {
+				rbuggyQSA.push( "[*^$]=" + whitespace + "*(?:''|\"\")" );
+			}
+
+			// Support: IE8
+			// Boolean attributes and "value" are not treated correctly
+			if ( !el.querySelectorAll( "[selected]" ).length ) {
+				rbuggyQSA.push( "\\[" + whitespace + "*(?:value|" + booleans + ")" );
+			}
+
+			// Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+
+			if ( !el.querySelectorAll( "[id~=" + expando + "-]" ).length ) {
+				rbuggyQSA.push( "~=" );
+			}
+
+			// Support: IE 11+, Edge 15 - 18+
+			// IE 11/Edge don't find elements on a `[name='']` query in some cases.
+			// Adding a temporary attribute to the document before the selection works
+			// around the issue.
+			// Interestingly, IE 10 & older don't seem to have the issue.
+			input = document.createElement( "input" );
+			input.setAttribute( "name", "" );
+			el.appendChild( input );
+			if ( !el.querySelectorAll( "[name='']" ).length ) {
+				rbuggyQSA.push( "\\[" + whitespace + "*name" + whitespace + "*=" +
+					whitespace + "*(?:''|\"\")" );
+			}
+
+			// Webkit/Opera - :checked should return selected option elements
+			// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked
+			// IE8 throws error here and will not see later tests
+			if ( !el.querySelectorAll( ":checked" ).length ) {
+				rbuggyQSA.push( ":checked" );
+			}
+
+			// Support: Safari 8+, iOS 8+
+			// https://bugs.webkit.org/show_bug.cgi?id=136851
+			// In-page `selector#id sibling-combinator selector` fails
+			if ( !el.querySelectorAll( "a#" + expando + "+*" ).length ) {
+				rbuggyQSA.push( ".#.+[+~]" );
+			}
+
+			// Support: Firefox <=3.6 - 5 only
+			// Old Firefox doesn't throw on a badly-escaped identifier.
+			el.querySelectorAll( "\\\f" );
+			rbuggyQSA.push( "[\\r\\n\\f]" );
+		} );
+
+		assert( function( el ) {
+			el.innerHTML = "<a href='' disabled='disabled'></a>" +
+				"<select disabled='disabled'><option/></select>";
+
+			// Support: Windows 8 Native Apps
+			// The type and name attributes are restricted during .innerHTML assignment
+			var input = document.createElement( "input" );
+			input.setAttribute( "type", "hidden" );
+			el.appendChild( input ).setAttribute( "name", "D" );
+
+			// Support: IE8
+			// Enforce case-sensitivity of name attribute
+			if ( el.querySelectorAll( "[name=d]" ).length ) {
+				rbuggyQSA.push( "name" + whitespace + "*[*^$|!~]?=" );
+			}
+
+			// FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled)
+			// IE8 throws error here and will not see later tests
+			if ( el.querySelectorAll( ":enabled" ).length !== 2 ) {
+				rbuggyQSA.push( ":enabled", ":disabled" );
+			}
+
+			// Support: IE9-11+
+			// IE's :disabled selector does not pick up the children of disabled fieldsets
+			docElem.appendChild( el ).disabled = true;
+			if ( el.querySelectorAll( ":disabled" ).length !== 2 ) {
+				rbuggyQSA.push( ":enabled", ":disabled" );
+			}
+
+			// Support: Opera 10 - 11 only
+			// Opera 10-11 does not throw on post-comma invalid pseudos
+			el.querySelectorAll( "*,:x" );
+			rbuggyQSA.push( ",.*:" );
+		} );
+	}
+
+	if ( ( support.matchesSelector = rnative.test( ( matches = docElem.matches ||
+		docElem.webkitMatchesSelector ||
+		docElem.mozMatchesSelector ||
+		docElem.oMatchesSelector ||
+		docElem.msMatchesSelector ) ) ) ) {
+
+		assert( function( el ) {
+
+			// Check to see if it's possible to do matchesSelector
+			// on a disconnected node (IE 9)
+			support.disconnectedMatch = matches.call( el, "*" );
+
+			// This should fail with an exception
+			// Gecko does not error, returns false instead
+			matches.call( el, "[s!='']:x" );
+			rbuggyMatches.push( "!=", pseudos );
+		} );
+	}
+
+	rbuggyQSA = rbuggyQSA.length && new RegExp( rbuggyQSA.join( "|" ) );
+	rbuggyMatches = rbuggyMatches.length && new RegExp( rbuggyMatches.join( "|" ) );
+
+	/* Contains
+	---------------------------------------------------------------------- */
+	hasCompare = rnative.test( docElem.compareDocumentPosition );
+
+	// Element contains another
+	// Purposefully self-exclusive
+	// As in, an element does not contain itself
+	contains = hasCompare || rnative.test( docElem.contains ) ?
+		function( a, b ) {
+			var adown = a.nodeType === 9 ? a.documentElement : a,
+				bup = b && b.parentNode;
+			return a === bup || !!( bup && bup.nodeType === 1 && (
+				adown.contains ?
+					adown.contains( bup ) :
+					a.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16
+			) );
+		} :
+		function( a, b ) {
+			if ( b ) {
+				while ( ( b = b.parentNode ) ) {
+					if ( b === a ) {
+						return true;
+					}
+				}
+			}
+			return false;
+		};
+
+	/* Sorting
+	---------------------------------------------------------------------- */
+
+	// Document order sorting
+	sortOrder = hasCompare ?
+	function( a, b ) {
+
+		// Flag for duplicate removal
+		if ( a === b ) {
+			hasDuplicate = true;
+			return 0;
+		}
+
+		// Sort on method existence if only one input has compareDocumentPosition
+		var compare = !a.compareDocumentPosition - !b.compareDocumentPosition;
+		if ( compare ) {
+			return compare;
+		}
+
+		// Calculate position if both inputs belong to the same document
+		// Support: IE 11+, Edge 17 - 18+
+		// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+		// two documents; shallow comparisons work.
+		// eslint-disable-next-line eqeqeq
+		compare = ( a.ownerDocument || a ) == ( b.ownerDocument || b ) ?
+			a.compareDocumentPosition( b ) :
+
+			// Otherwise we know they are disconnected
+			1;
+
+		// Disconnected nodes
+		if ( compare & 1 ||
+			( !support.sortDetached && b.compareDocumentPosition( a ) === compare ) ) {
+
+			// Choose the first element that is related to our preferred document
+			// Support: IE 11+, Edge 17 - 18+
+			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+			// two documents; shallow comparisons work.
+			// eslint-disable-next-line eqeqeq
+			if ( a == document || a.ownerDocument == preferredDoc &&
+				contains( preferredDoc, a ) ) {
+				return -1;
+			}
+
+			// Support: IE 11+, Edge 17 - 18+
+			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+			// two documents; shallow comparisons work.
+			// eslint-disable-next-line eqeqeq
+			if ( b == document || b.ownerDocument == preferredDoc &&
+				contains( preferredDoc, b ) ) {
+				return 1;
+			}
+
+			// Maintain original order
+			return sortInput ?
+				( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :
+				0;
+		}
+
+		return compare & 4 ? -1 : 1;
+	} :
+	function( a, b ) {
+
+		// Exit early if the nodes are identical
+		if ( a === b ) {
+			hasDuplicate = true;
+			return 0;
+		}
+
+		var cur,
+			i = 0,
+			aup = a.parentNode,
+			bup = b.parentNode,
+			ap = [ a ],
+			bp = [ b ];
+
+		// Parentless nodes are either documents or disconnected
+		if ( !aup || !bup ) {
+
+			// Support: IE 11+, Edge 17 - 18+
+			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+			// two documents; shallow comparisons work.
+			/* eslint-disable eqeqeq */
+			return a == document ? -1 :
+				b == document ? 1 :
+				/* eslint-enable eqeqeq */
+				aup ? -1 :
+				bup ? 1 :
+				sortInput ?
+				( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :
+				0;
+
+		// If the nodes are siblings, we can do a quick check
+		} else if ( aup === bup ) {
+			return siblingCheck( a, b );
+		}
+
+		// Otherwise we need full lists of their ancestors for comparison
+		cur = a;
+		while ( ( cur = cur.parentNode ) ) {
+			ap.unshift( cur );
+		}
+		cur = b;
+		while ( ( cur = cur.parentNode ) ) {
+			bp.unshift( cur );
+		}
+
+		// Walk down the tree looking for a discrepancy
+		while ( ap[ i ] === bp[ i ] ) {
+			i++;
+		}
+
+		return i ?
+
+			// Do a sibling check if the nodes have a common ancestor
+			siblingCheck( ap[ i ], bp[ i ] ) :
+
+			// Otherwise nodes in our document sort first
+			// Support: IE 11+, Edge 17 - 18+
+			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+			// two documents; shallow comparisons work.
+			/* eslint-disable eqeqeq */
+			ap[ i ] == preferredDoc ? -1 :
+			bp[ i ] == preferredDoc ? 1 :
+			/* eslint-enable eqeqeq */
+			0;
+	};
+
+	return document;
+};
+
+Sizzle.matches = function( expr, elements ) {
+	return Sizzle( expr, null, null, elements );
+};
+
+Sizzle.matchesSelector = function( elem, expr ) {
+	setDocument( elem );
+
+	if ( support.matchesSelector && documentIsHTML &&
+		!nonnativeSelectorCache[ expr + " " ] &&
+		( !rbuggyMatches || !rbuggyMatches.test( expr ) ) &&
+		( !rbuggyQSA     || !rbuggyQSA.test( expr ) ) ) {
+
+		try {
+			var ret = matches.call( elem, expr );
+
+			// IE 9's matchesSelector returns false on disconnected nodes
+			if ( ret || support.disconnectedMatch ||
+
+				// As well, disconnected nodes are said to be in a document
+				// fragment in IE 9
+				elem.document && elem.document.nodeType !== 11 ) {
+				return ret;
+			}
+		} catch ( e ) {
+			nonnativeSelectorCache( expr, true );
+		}
+	}
+
+	return Sizzle( expr, document, null, [ elem ] ).length > 0;
+};
+
+Sizzle.contains = function( context, elem ) {
+
+	// Set document vars if needed
+	// Support: IE 11+, Edge 17 - 18+
+	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+	// two documents; shallow comparisons work.
+	// eslint-disable-next-line eqeqeq
+	if ( ( context.ownerDocument || context ) != document ) {
+		setDocument( context );
+	}
+	return contains( context, elem );
+};
+
+Sizzle.attr = function( elem, name ) {
+
+	// Set document vars if needed
+	// Support: IE 11+, Edge 17 - 18+
+	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+	// two documents; shallow comparisons work.
+	// eslint-disable-next-line eqeqeq
+	if ( ( elem.ownerDocument || elem ) != document ) {
+		setDocument( elem );
+	}
+
+	var fn = Expr.attrHandle[ name.toLowerCase() ],
+
+		// Don't get fooled by Object.prototype properties (jQuery #13807)
+		val = fn && hasOwn.call( Expr.attrHandle, name.toLowerCase() ) ?
+			fn( elem, name, !documentIsHTML ) :
+			undefined;
+
+	return val !== undefined ?
+		val :
+		support.attributes || !documentIsHTML ?
+			elem.getAttribute( name ) :
+			( val = elem.getAttributeNode( name ) ) && val.specified ?
+				val.value :
+				null;
+};
+
+Sizzle.escape = function( sel ) {
+	return ( sel + "" ).replace( rcssescape, fcssescape );
+};
+
+Sizzle.error = function( msg ) {
+	throw new Error( "Syntax error, unrecognized expression: " + msg );
+};
+
+/**
+ * Document sorting and removing duplicates
+ * @param {ArrayLike} results
+ */
+Sizzle.uniqueSort = function( results ) {
+	var elem,
+		duplicates = [],
+		j = 0,
+		i = 0;
+
+	// Unless we *know* we can detect duplicates, assume their presence
+	hasDuplicate = !support.detectDuplicates;
+	sortInput = !support.sortStable && results.slice( 0 );
+	results.sort( sortOrder );
+
+	if ( hasDuplicate ) {
+		while ( ( elem = results[ i++ ] ) ) {
+			if ( elem === results[ i ] ) {
+				j = duplicates.push( i );
+			}
+		}
+		while ( j-- ) {
+			results.splice( duplicates[ j ], 1 );
+		}
+	}
+
+	// Clear input after sorting to release objects
+	// See https://github.com/jquery/sizzle/pull/225
+	sortInput = null;
+
+	return results;
+};
+
+/**
+ * Utility function for retrieving the text value of an array of DOM nodes
+ * @param {Array|Element} elem
+ */
+getText = Sizzle.getText = function( elem ) {
+	var node,
+		ret = "",
+		i = 0,
+		nodeType = elem.nodeType;
+
+	if ( !nodeType ) {
+
+		// If no nodeType, this is expected to be an array
+		while ( ( node = elem[ i++ ] ) ) {
+
+			// Do not traverse comment nodes
+			ret += getText( node );
+		}
+	} else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) {
+
+		// Use textContent for elements
+		// innerText usage removed for consistency of new lines (jQuery #11153)
+		if ( typeof elem.textContent === "string" ) {
+			return elem.textContent;
+		} else {
+
+			// Traverse its children
+			for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {
+				ret += getText( elem );
+			}
+		}
+	} else if ( nodeType === 3 || nodeType === 4 ) {
+		return elem.nodeValue;
+	}
+
+	// Do not include comment or processing instruction nodes
+
+	return ret;
+};
+
+Expr = Sizzle.selectors = {
+
+	// Can be adjusted by the user
+	cacheLength: 50,
+
+	createPseudo: markFunction,
+
+	match: matchExpr,
+
+	attrHandle: {},
+
+	find: {},
+
+	relative: {
+		">": { dir: "parentNode", first: true },
+		" ": { dir: "parentNode" },
+		"+": { dir: "previousSibling", first: true },
+		"~": { dir: "previousSibling" }
+	},
+
+	preFilter: {
+		"ATTR": function( match ) {
+			match[ 1 ] = match[ 1 ].replace( runescape, funescape );
+
+			// Move the given value to match[3] whether quoted or unquoted
+			match[ 3 ] = ( match[ 3 ] || match[ 4 ] ||
+				match[ 5 ] || "" ).replace( runescape, funescape );
+
+			if ( match[ 2 ] === "~=" ) {
+				match[ 3 ] = " " + match[ 3 ] + " ";
+			}
+
+			return match.slice( 0, 4 );
+		},
+
+		"CHILD": function( match ) {
+
+			/* matches from matchExpr["CHILD"]
+				1 type (only|nth|...)
+				2 what (child|of-type)
+				3 argument (even|odd|\d*|\d*n([+-]\d+)?|...)
+				4 xn-component of xn+y argument ([+-]?\d*n|)
+				5 sign of xn-component
+				6 x of xn-component
+				7 sign of y-component
+				8 y of y-component
+			*/
+			match[ 1 ] = match[ 1 ].toLowerCase();
+
+			if ( match[ 1 ].slice( 0, 3 ) === "nth" ) {
+
+				// nth-* requires argument
+				if ( !match[ 3 ] ) {
+					Sizzle.error( match[ 0 ] );
+				}
+
+				// numeric x and y parameters for Expr.filter.CHILD
+				// remember that false/true cast respectively to 0/1
+				match[ 4 ] = +( match[ 4 ] ?
+					match[ 5 ] + ( match[ 6 ] || 1 ) :
+					2 * ( match[ 3 ] === "even" || match[ 3 ] === "odd" ) );
+				match[ 5 ] = +( ( match[ 7 ] + match[ 8 ] ) || match[ 3 ] === "odd" );
+
+				// other types prohibit arguments
+			} else if ( match[ 3 ] ) {
+				Sizzle.error( match[ 0 ] );
+			}
+
+			return match;
+		},
+
+		"PSEUDO": function( match ) {
+			var excess,
+				unquoted = !match[ 6 ] && match[ 2 ];
+
+			if ( matchExpr[ "CHILD" ].test( match[ 0 ] ) ) {
+				return null;
+			}
+
+			// Accept quoted arguments as-is
+			if ( match[ 3 ] ) {
+				match[ 2 ] = match[ 4 ] || match[ 5 ] || "";
+
+			// Strip excess characters from unquoted arguments
+			} else if ( unquoted && rpseudo.test( unquoted ) &&
+
+				// Get excess from tokenize (recursively)
+				( excess = tokenize( unquoted, true ) ) &&
+
+				// advance to the next closing parenthesis
+				( excess = unquoted.indexOf( ")", unquoted.length - excess ) - unquoted.length ) ) {
+
+				// excess is a negative index
+				match[ 0 ] = match[ 0 ].slice( 0, excess );
+				match[ 2 ] = unquoted.slice( 0, excess );
+			}
+
+			// Return only captures needed by the pseudo filter method (type and argument)
+			return match.slice( 0, 3 );
+		}
+	},
+
+	filter: {
+
+		"TAG": function( nodeNameSelector ) {
+			var nodeName = nodeNameSelector.replace( runescape, funescape ).toLowerCase();
+			return nodeNameSelector === "*" ?
+				function() {
+					return true;
+				} :
+				function( elem ) {
+					return elem.nodeName && elem.nodeName.toLowerCase() === nodeName;
+				};
+		},
+
+		"CLASS": function( className ) {
+			var pattern = classCache[ className + " " ];
+
+			return pattern ||
+				( pattern = new RegExp( "(^|" + whitespace +
+					")" + className + "(" + whitespace + "|$)" ) ) && classCache(
+						className, function( elem ) {
+							return pattern.test(
+								typeof elem.className === "string" && elem.className ||
+								typeof elem.getAttribute !== "undefined" &&
+									elem.getAttribute( "class" ) ||
+								""
+							);
+				} );
+		},
+
+		"ATTR": function( name, operator, check ) {
+			return function( elem ) {
+				var result = Sizzle.attr( elem, name );
+
+				if ( result == null ) {
+					return operator === "!=";
+				}
+				if ( !operator ) {
+					return true;
+				}
+
+				result += "";
+
+				/* eslint-disable max-len */
+
+				return operator === "=" ? result === check :
+					operator === "!=" ? result !== check :
+					operator === "^=" ? check && result.indexOf( check ) === 0 :
+					operator === "*=" ? check && result.indexOf( check ) > -1 :
+					operator === "$=" ? check && result.slice( -check.length ) === check :
+					operator === "~=" ? ( " " + result.replace( rwhitespace, " " ) + " " ).indexOf( check ) > -1 :
+					operator === "|=" ? result === check || result.slice( 0, check.length + 1 ) === check + "-" :
+					false;
+				/* eslint-enable max-len */
+
+			};
+		},
+
+		"CHILD": function( type, what, _argument, first, last ) {
+			var simple = type.slice( 0, 3 ) !== "nth",
+				forward = type.slice( -4 ) !== "last",
+				ofType = what === "of-type";
+
+			return first === 1 && last === 0 ?
+
+				// Shortcut for :nth-*(n)
+				function( elem ) {
+					return !!elem.parentNode;
+				} :
+
+				function( elem, _context, xml ) {
+					var cache, uniqueCache, outerCache, node, nodeIndex, start,
+						dir = simple !== forward ? "nextSibling" : "previousSibling",
+						parent = elem.parentNode,
+						name = ofType && elem.nodeName.toLowerCase(),
+						useCache = !xml && !ofType,
+						diff = false;
+
+					if ( parent ) {
+
+						// :(first|last|only)-(child|of-type)
+						if ( simple ) {
+							while ( dir ) {
+								node = elem;
+								while ( ( node = node[ dir ] ) ) {
+									if ( ofType ?
+										node.nodeName.toLowerCase() === name :
+										node.nodeType === 1 ) {
+
+										return false;
+									}
+								}
+
+								// Reverse direction for :only-* (if we haven't yet done so)
+								start = dir = type === "only" && !start && "nextSibling";
+							}
+							return true;
+						}
+
+						start = [ forward ? parent.firstChild : parent.lastChild ];
+
+						// non-xml :nth-child(...) stores cache data on `parent`
+						if ( forward && useCache ) {
+
+							// Seek `elem` from a previously-cached index
+
+							// ...in a gzip-friendly way
+							node = parent;
+							outerCache = node[ expando ] || ( node[ expando ] = {} );
+
+							// Support: IE <9 only
+							// Defend against cloned attroperties (jQuery gh-1709)
+							uniqueCache = outerCache[ node.uniqueID ] ||
+								( outerCache[ node.uniqueID ] = {} );
+
+							cache = uniqueCache[ type ] || [];
+							nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];
+							diff = nodeIndex && cache[ 2 ];
+							node = nodeIndex && parent.childNodes[ nodeIndex ];
+
+							while ( ( node = ++nodeIndex && node && node[ dir ] ||
+
+								// Fallback to seeking `elem` from the start
+								( diff = nodeIndex = 0 ) || start.pop() ) ) {
+
+								// When found, cache indexes on `parent` and break
+								if ( node.nodeType === 1 && ++diff && node === elem ) {
+									uniqueCache[ type ] = [ dirruns, nodeIndex, diff ];
+									break;
+								}
+							}
+
+						} else {
+
+							// Use previously-cached element index if available
+							if ( useCache ) {
+
+								// ...in a gzip-friendly way
+								node = elem;
+								outerCache = node[ expando ] || ( node[ expando ] = {} );
+
+								// Support: IE <9 only
+								// Defend against cloned attroperties (jQuery gh-1709)
+								uniqueCache = outerCache[ node.uniqueID ] ||
+									( outerCache[ node.uniqueID ] = {} );
+
+								cache = uniqueCache[ type ] || [];
+								nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];
+								diff = nodeIndex;
+							}
+
+							// xml :nth-child(...)
+							// or :nth-last-child(...) or :nth(-last)?-of-type(...)
+							if ( diff === false ) {
+
+								// Use the same loop as above to seek `elem` from the start
+								while ( ( node = ++nodeIndex && node && node[ dir ] ||
+									( diff = nodeIndex = 0 ) || start.pop() ) ) {
+
+									if ( ( ofType ?
+										node.nodeName.toLowerCase() === name :
+										node.nodeType === 1 ) &&
+										++diff ) {
+
+										// Cache the index of each encountered element
+										if ( useCache ) {
+											outerCache = node[ expando ] ||
+												( node[ expando ] = {} );
+
+											// Support: IE <9 only
+											// Defend against cloned attroperties (jQuery gh-1709)
+											uniqueCache = outerCache[ node.uniqueID ] ||
+												( outerCache[ node.uniqueID ] = {} );
+
+											uniqueCache[ type ] = [ dirruns, diff ];
+										}
+
+										if ( node === elem ) {
+											break;
+										}
+									}
+								}
+							}
+						}
+
+						// Incorporate the offset, then check against cycle size
+						diff -= last;
+						return diff === first || ( diff % first === 0 && diff / first >= 0 );
+					}
+				};
+		},
+
+		"PSEUDO": function( pseudo, argument ) {
+
+			// pseudo-class names are case-insensitive
+			// http://www.w3.org/TR/selectors/#pseudo-classes
+			// Prioritize by case sensitivity in case custom pseudos are added with uppercase letters
+			// Remember that setFilters inherits from pseudos
+			var args,
+				fn = Expr.pseudos[ pseudo ] || Expr.setFilters[ pseudo.toLowerCase() ] ||
+					Sizzle.error( "unsupported pseudo: " + pseudo );
+
+			// The user may use createPseudo to indicate that
+			// arguments are needed to create the filter function
+			// just as Sizzle does
+			if ( fn[ expando ] ) {
+				return fn( argument );
+			}
+
+			// But maintain support for old signatures
+			if ( fn.length > 1 ) {
+				args = [ pseudo, pseudo, "", argument ];
+				return Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ?
+					markFunction( function( seed, matches ) {
+						var idx,
+							matched = fn( seed, argument ),
+							i = matched.length;
+						while ( i-- ) {
+							idx = indexOf( seed, matched[ i ] );
+							seed[ idx ] = !( matches[ idx ] = matched[ i ] );
+						}
+					} ) :
+					function( elem ) {
+						return fn( elem, 0, args );
+					};
+			}
+
+			return fn;
+		}
+	},
+
+	pseudos: {
+
+		// Potentially complex pseudos
+		"not": markFunction( function( selector ) {
+
+			// Trim the selector passed to compile
+			// to avoid treating leading and trailing
+			// spaces as combinators
+			var input = [],
+				results = [],
+				matcher = compile( selector.replace( rtrim, "$1" ) );
+
+			return matcher[ expando ] ?
+				markFunction( function( seed, matches, _context, xml ) {
+					var elem,
+						unmatched = matcher( seed, null, xml, [] ),
+						i = seed.length;
+
+					// Match elements unmatched by `matcher`
+					while ( i-- ) {
+						if ( ( elem = unmatched[ i ] ) ) {
+							seed[ i ] = !( matches[ i ] = elem );
+						}
+					}
+				} ) :
+				function( elem, _context, xml ) {
+					input[ 0 ] = elem;
+					matcher( input, null, xml, results );
+
+					// Don't keep the element (issue #299)
+					input[ 0 ] = null;
+					return !results.pop();
+				};
+		} ),
+
+		"has": markFunction( function( selector ) {
+			return function( elem ) {
+				return Sizzle( selector, elem ).length > 0;
+			};
+		} ),
+
+		"contains": markFunction( function( text ) {
+			text = text.replace( runescape, funescape );
+			return function( elem ) {
+				return ( elem.textContent || getText( elem ) ).indexOf( text ) > -1;
+			};
+		} ),
+
+		// "Whether an element is represented by a :lang() selector
+		// is based solely on the element's language value
+		// being equal to the identifier C,
+		// or beginning with the identifier C immediately followed by "-".
+		// The matching of C against the element's language value is performed case-insensitively.
+		// The identifier C does not have to be a valid language name."
+		// http://www.w3.org/TR/selectors/#lang-pseudo
+		"lang": markFunction( function( lang ) {
+
+			// lang value must be a valid identifier
+			if ( !ridentifier.test( lang || "" ) ) {
+				Sizzle.error( "unsupported lang: " + lang );
+			}
+			lang = lang.replace( runescape, funescape ).toLowerCase();
+			return function( elem ) {
+				var elemLang;
+				do {
+					if ( ( elemLang = documentIsHTML ?
+						elem.lang :
+						elem.getAttribute( "xml:lang" ) || elem.getAttribute( "lang" ) ) ) {
+
+						elemLang = elemLang.toLowerCase();
+						return elemLang === lang || elemLang.indexOf( lang + "-" ) === 0;
+					}
+				} while ( ( elem = elem.parentNode ) && elem.nodeType === 1 );
+				return false;
+			};
+		} ),
+
+		// Miscellaneous
+		"target": function( elem ) {
+			var hash = window.location && window.location.hash;
+			return hash && hash.slice( 1 ) === elem.id;
+		},
+
+		"root": function( elem ) {
+			return elem === docElem;
+		},
+
+		"focus": function( elem ) {
+			return elem === document.activeElement &&
+				( !document.hasFocus || document.hasFocus() ) &&
+				!!( elem.type || elem.href || ~elem.tabIndex );
+		},
+
+		// Boolean properties
+		"enabled": createDisabledPseudo( false ),
+		"disabled": createDisabledPseudo( true ),
+
+		"checked": function( elem ) {
+
+			// In CSS3, :checked should return both checked and selected elements
+			// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked
+			var nodeName = elem.nodeName.toLowerCase();
+			return ( nodeName === "input" && !!elem.checked ) ||
+				( nodeName === "option" && !!elem.selected );
+		},
+
+		"selected": function( elem ) {
+
+			// Accessing this property makes selected-by-default
+			// options in Safari work properly
+			if ( elem.parentNode ) {
+				// eslint-disable-next-line no-unused-expressions
+				elem.parentNode.selectedIndex;
+			}
+
+			return elem.selected === true;
+		},
+
+		// Contents
+		"empty": function( elem ) {
+
+			// http://www.w3.org/TR/selectors/#empty-pseudo
+			// :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5),
+			//   but not by others (comment: 8; processing instruction: 7; etc.)
+			// nodeType < 6 works because attributes (2) do not appear as children
+			for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {
+				if ( elem.nodeType < 6 ) {
+					return false;
+				}
+			}
+			return true;
+		},
+
+		"parent": function( elem ) {
+			return !Expr.pseudos[ "empty" ]( elem );
+		},
+
+		// Element/input types
+		"header": function( elem ) {
+			return rheader.test( elem.nodeName );
+		},
+
+		"input": function( elem ) {
+			return rinputs.test( elem.nodeName );
+		},
+
+		"button": function( elem ) {
+			var name = elem.nodeName.toLowerCase();
+			return name === "input" && elem.type === "button" || name === "button";
+		},
+
+		"text": function( elem ) {
+			var attr;
+			return elem.nodeName.toLowerCase() === "input" &&
+				elem.type === "text" &&
+
+				// Support: IE<8
+				// New HTML5 attribute values (e.g., "search") appear with elem.type === "text"
+				( ( attr = elem.getAttribute( "type" ) ) == null ||
+					attr.toLowerCase() === "text" );
+		},
+
+		// Position-in-collection
+		"first": createPositionalPseudo( function() {
+			return [ 0 ];
+		} ),
+
+		"last": createPositionalPseudo( function( _matchIndexes, length ) {
+			return [ length - 1 ];
+		} ),
+
+		"eq": createPositionalPseudo( function( _matchIndexes, length, argument ) {
+			return [ argument < 0 ? argument + length : argument ];
+		} ),
+
+		"even": createPositionalPseudo( function( matchIndexes, length ) {
+			var i = 0;
+			for ( ; i < length; i += 2 ) {
+				matchIndexes.push( i );
+			}
+			return matchIndexes;
+		} ),
+
+		"odd": createPositionalPseudo( function( matchIndexes, length ) {
+			var i = 1;
+			for ( ; i < length; i += 2 ) {
+				matchIndexes.push( i );
+			}
+			return matchIndexes;
+		} ),
+
+		"lt": createPositionalPseudo( function( matchIndexes, length, argument ) {
+			var i = argument < 0 ?
+				argument + length :
+				argument > length ?
+					length :
+					argument;
+			for ( ; --i >= 0; ) {
+				matchIndexes.push( i );
+			}
+			return matchIndexes;
+		} ),
+
+		"gt": createPositionalPseudo( function( matchIndexes, length, argument ) {
+			var i = argument < 0 ? argument + length : argument;
+			for ( ; ++i < length; ) {
+				matchIndexes.push( i );
+			}
+			return matchIndexes;
+		} )
+	}
+};
+
+Expr.pseudos[ "nth" ] = Expr.pseudos[ "eq" ];
+
+// Add button/input type pseudos
+for ( i in { radio: true, checkbox: true, file: true, password: true, image: true } ) {
+	Expr.pseudos[ i ] = createInputPseudo( i );
+}
+for ( i in { submit: true, reset: true } ) {
+	Expr.pseudos[ i ] = createButtonPseudo( i );
+}
+
+// Easy API for creating new setFilters
+function setFilters() {}
+setFilters.prototype = Expr.filters = Expr.pseudos;
+Expr.setFilters = new setFilters();
+
+tokenize = Sizzle.tokenize = function( selector, parseOnly ) {
+	var matched, match, tokens, type,
+		soFar, groups, preFilters,
+		cached = tokenCache[ selector + " " ];
+
+	if ( cached ) {
+		return parseOnly ? 0 : cached.slice( 0 );
+	}
+
+	soFar = selector;
+	groups = [];
+	preFilters = Expr.preFilter;
+
+	while ( soFar ) {
+
+		// Comma and first run
+		if ( !matched || ( match = rcomma.exec( soFar ) ) ) {
+			if ( match ) {
+
+				// Don't consume trailing commas as valid
+				soFar = soFar.slice( match[ 0 ].length ) || soFar;
+			}
+			groups.push( ( tokens = [] ) );
+		}
+
+		matched = false;
+
+		// Combinators
+		if ( ( match = rcombinators.exec( soFar ) ) ) {
+			matched = match.shift();
+			tokens.push( {
+				value: matched,
+
+				// Cast descendant combinators to space
+				type: match[ 0 ].replace( rtrim, " " )
+			} );
+			soFar = soFar.slice( matched.length );
+		}
+
+		// Filters
+		for ( type in Expr.filter ) {
+			if ( ( match = matchExpr[ type ].exec( soFar ) ) && ( !preFilters[ type ] ||
+				( match = preFilters[ type ]( match ) ) ) ) {
+				matched = match.shift();
+				tokens.push( {
+					value: matched,
+					type: type,
+					matches: match
+				} );
+				soFar = soFar.slice( matched.length );
+			}
+		}
+
+		if ( !matched ) {
+			break;
+		}
+	}
+
+	// Return the length of the invalid excess
+	// if we're just parsing
+	// Otherwise, throw an error or return tokens
+	return parseOnly ?
+		soFar.length :
+		soFar ?
+			Sizzle.error( selector ) :
+
+			// Cache the tokens
+			tokenCache( selector, groups ).slice( 0 );
+};
+
+function toSelector( tokens ) {
+	var i = 0,
+		len = tokens.length,
+		selector = "";
+	for ( ; i < len; i++ ) {
+		selector += tokens[ i ].value;
+	}
+	return selector;
+}
+
+function addCombinator( matcher, combinator, base ) {
+	var dir = combinator.dir,
+		skip = combinator.next,
+		key = skip || dir,
+		checkNonElements = base && key === "parentNode",
+		doneName = done++;
+
+	return combinator.first ?
+
+		// Check against closest ancestor/preceding element
+		function( elem, context, xml ) {
+			while ( ( elem = elem[ dir ] ) ) {
+				if ( elem.nodeType === 1 || checkNonElements ) {
+					return matcher( elem, context, xml );
+				}
+			}
+			return false;
+		} :
+
+		// Check against all ancestor/preceding elements
+		function( elem, context, xml ) {
+			var oldCache, uniqueCache, outerCache,
+				newCache = [ dirruns, doneName ];
+
+			// We can't set arbitrary data on XML nodes, so they don't benefit from combinator caching
+			if ( xml ) {
+				while ( ( elem = elem[ dir ] ) ) {
+					if ( elem.nodeType === 1 || checkNonElements ) {
+						if ( matcher( elem, context, xml ) ) {
+							return true;
+						}
+					}
+				}
+			} else {
+				while ( ( elem = elem[ dir ] ) ) {
+					if ( elem.nodeType === 1 || checkNonElements ) {
+						outerCache = elem[ expando ] || ( elem[ expando ] = {} );
+
+						// Support: IE <9 only
+						// Defend against cloned attroperties (jQuery gh-1709)
+						uniqueCache = outerCache[ elem.uniqueID ] ||
+							( outerCache[ elem.uniqueID ] = {} );
+
+						if ( skip && skip === elem.nodeName.toLowerCase() ) {
+							elem = elem[ dir ] || elem;
+						} else if ( ( oldCache = uniqueCache[ key ] ) &&
+							oldCache[ 0 ] === dirruns && oldCache[ 1 ] === doneName ) {
+
+							// Assign to newCache so results back-propagate to previous elements
+							return ( newCache[ 2 ] = oldCache[ 2 ] );
+						} else {
+
+							// Reuse newcache so results back-propagate to previous elements
+							uniqueCache[ key ] = newCache;
+
+							// A match means we're done; a fail means we have to keep checking
+							if ( ( newCache[ 2 ] = matcher( elem, context, xml ) ) ) {
+								return true;
+							}
+						}
+					}
+				}
+			}
+			return false;
+		};
+}
+
+function elementMatcher( matchers ) {
+	return matchers.length > 1 ?
+		function( elem, context, xml ) {
+			var i = matchers.length;
+			while ( i-- ) {
+				if ( !matchers[ i ]( elem, context, xml ) ) {
+					return false;
+				}
+			}
+			return true;
+		} :
+		matchers[ 0 ];
+}
+
+function multipleContexts( selector, contexts, results ) {
+	var i = 0,
+		len = contexts.length;
+	for ( ; i < len; i++ ) {
+		Sizzle( selector, contexts[ i ], results );
+	}
+	return results;
+}
+
+function condense( unmatched, map, filter, context, xml ) {
+	var elem,
+		newUnmatched = [],
+		i = 0,
+		len = unmatched.length,
+		mapped = map != null;
+
+	for ( ; i < len; i++ ) {
+		if ( ( elem = unmatched[ i ] ) ) {
+			if ( !filter || filter( elem, context, xml ) ) {
+				newUnmatched.push( elem );
+				if ( mapped ) {
+					map.push( i );
+				}
+			}
+		}
+	}
+
+	return newUnmatched;
+}
+
+function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) {
+	if ( postFilter && !postFilter[ expando ] ) {
+		postFilter = setMatcher( postFilter );
+	}
+	if ( postFinder && !postFinder[ expando ] ) {
+		postFinder = setMatcher( postFinder, postSelector );
+	}
+	return markFunction( function( seed, results, context, xml ) {
+		var temp, i, elem,
+			preMap = [],
+			postMap = [],
+			preexisting = results.length,
+
+			// Get initial elements from seed or context
+			elems = seed || multipleContexts(
+				selector || "*",
+				context.nodeType ? [ context ] : context,
+				[]
+			),
+
+			// Prefilter to get matcher input, preserving a map for seed-results synchronization
+			matcherIn = preFilter && ( seed || !selector ) ?
+				condense( elems, preMap, preFilter, context, xml ) :
+				elems,
+
+			matcherOut = matcher ?
+
+				// If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results,
+				postFinder || ( seed ? preFilter : preexisting || postFilter ) ?
+
+					// ...intermediate processing is necessary
+					[] :
+
+					// ...otherwise use results directly
+					results :
+				matcherIn;
+
+		// Find primary matches
+		if ( matcher ) {
+			matcher( matcherIn, matcherOut, context, xml );
+		}
+
+		// Apply postFilter
+		if ( postFilter ) {
+			temp = condense( matcherOut, postMap );
+			postFilter( temp, [], context, xml );
+
+			// Un-match failing elements by moving them back to matcherIn
+			i = temp.length;
+			while ( i-- ) {
+				if ( ( elem = temp[ i ] ) ) {
+					matcherOut[ postMap[ i ] ] = !( matcherIn[ postMap[ i ] ] = elem );
+				}
+			}
+		}
+
+		if ( seed ) {
+			if ( postFinder || preFilter ) {
+				if ( postFinder ) {
+
+					// Get the final matcherOut by condensing this intermediate into postFinder contexts
+					temp = [];
+					i = matcherOut.length;
+					while ( i-- ) {
+						if ( ( elem = matcherOut[ i ] ) ) {
+
+							// Restore matcherIn since elem is not yet a final match
+							temp.push( ( matcherIn[ i ] = elem ) );
+						}
+					}
+					postFinder( null, ( matcherOut = [] ), temp, xml );
+				}
+
+				// Move matched elements from seed to results to keep them synchronized
+				i = matcherOut.length;
+				while ( i-- ) {
+					if ( ( elem = matcherOut[ i ] ) &&
+						( temp = postFinder ? indexOf( seed, elem ) : preMap[ i ] ) > -1 ) {
+
+						seed[ temp ] = !( results[ temp ] = elem );
+					}
+				}
+			}
+
+		// Add elements to results, through postFinder if defined
+		} else {
+			matcherOut = condense(
+				matcherOut === results ?
+					matcherOut.splice( preexisting, matcherOut.length ) :
+					matcherOut
+			);
+			if ( postFinder ) {
+				postFinder( null, results, matcherOut, xml );
+			} else {
+				push.apply( results, matcherOut );
+			}
+		}
+	} );
+}
+
+function matcherFromTokens( tokens ) {
+	var checkContext, matcher, j,
+		len = tokens.length,
+		leadingRelative = Expr.relative[ tokens[ 0 ].type ],
+		implicitRelative = leadingRelative || Expr.relative[ " " ],
+		i = leadingRelative ? 1 : 0,
+
+		// The foundational matcher ensures that elements are reachable from top-level context(s)
+		matchContext = addCombinator( function( elem ) {
+			return elem === checkContext;
+		}, implicitRelative, true ),
+		matchAnyContext = addCombinator( function( elem ) {
+			return indexOf( checkContext, elem ) > -1;
+		}, implicitRelative, true ),
+		matchers = [ function( elem, context, xml ) {
+			var ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || (
+				( checkContext = context ).nodeType ?
+					matchContext( elem, context, xml ) :
+					matchAnyContext( elem, context, xml ) );
+
+			// Avoid hanging onto element (issue #299)
+			checkContext = null;
+			return ret;
+		} ];
+
+	for ( ; i < len; i++ ) {
+		if ( ( matcher = Expr.relative[ tokens[ i ].type ] ) ) {
+			matchers = [ addCombinator( elementMatcher( matchers ), matcher ) ];
+		} else {
+			matcher = Expr.filter[ tokens[ i ].type ].apply( null, tokens[ i ].matches );
+
+			// Return special upon seeing a positional matcher
+			if ( matcher[ expando ] ) {
+
+				// Find the next relative operator (if any) for proper handling
+				j = ++i;
+				for ( ; j < len; j++ ) {
+					if ( Expr.relative[ tokens[ j ].type ] ) {
+						break;
+					}
+				}
+				return setMatcher(
+					i > 1 && elementMatcher( matchers ),
+					i > 1 && toSelector(
+
+					// If the preceding token was a descendant combinator, insert an implicit any-element `*`
+					tokens
+						.slice( 0, i - 1 )
+						.concat( { value: tokens[ i - 2 ].type === " " ? "*" : "" } )
+					).replace( rtrim, "$1" ),
+					matcher,
+					i < j && matcherFromTokens( tokens.slice( i, j ) ),
+					j < len && matcherFromTokens( ( tokens = tokens.slice( j ) ) ),
+					j < len && toSelector( tokens )
+				);
+			}
+			matchers.push( matcher );
+		}
+	}
+
+	return elementMatcher( matchers );
+}
+
+function matcherFromGroupMatchers( elementMatchers, setMatchers ) {
+	var bySet = setMatchers.length > 0,
+		byElement = elementMatchers.length > 0,
+		superMatcher = function( seed, context, xml, results, outermost ) {
+			var elem, j, matcher,
+				matchedCount = 0,
+				i = "0",
+				unmatched = seed && [],
+				setMatched = [],
+				contextBackup = outermostContext,
+
+				// We must always have either seed elements or outermost context
+				elems = seed || byElement && Expr.find[ "TAG" ]( "*", outermost ),
+
+				// Use integer dirruns iff this is the outermost matcher
+				dirrunsUnique = ( dirruns += contextBackup == null ? 1 : Math.random() || 0.1 ),
+				len = elems.length;
+
+			if ( outermost ) {
+
+				// Support: IE 11+, Edge 17 - 18+
+				// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+				// two documents; shallow comparisons work.
+				// eslint-disable-next-line eqeqeq
+				outermostContext = context == document || context || outermost;
+			}
+
+			// Add elements passing elementMatchers directly to results
+			// Support: IE<9, Safari
+			// Tolerate NodeList properties (IE: "length"; Safari: <number>) matching elements by id
+			for ( ; i !== len && ( elem = elems[ i ] ) != null; i++ ) {
+				if ( byElement && elem ) {
+					j = 0;
+
+					// Support: IE 11+, Edge 17 - 18+
+					// IE/Edge sometimes throw a "Permission denied" error when strict-comparing
+					// two documents; shallow comparisons work.
+					// eslint-disable-next-line eqeqeq
+					if ( !context && elem.ownerDocument != document ) {
+						setDocument( elem );
+						xml = !documentIsHTML;
+					}
+					while ( ( matcher = elementMatchers[ j++ ] ) ) {
+						if ( matcher( elem, context || document, xml ) ) {
+							results.push( elem );
+							break;
+						}
+					}
+					if ( outermost ) {
+						dirruns = dirrunsUnique;
+					}
+				}
+
+				// Track unmatched elements for set filters
+				if ( bySet ) {
+
+					// They will have gone through all possible matchers
+					if ( ( elem = !matcher && elem ) ) {
+						matchedCount--;
+					}
+
+					// Lengthen the array for every element, matched or not
+					if ( seed ) {
+						unmatched.push( elem );
+					}
+				}
+			}
+
+			// `i` is now the count of elements visited above, and adding it to `matchedCount`
+			// makes the latter nonnegative.
+			matchedCount += i;
+
+			// Apply set filters to unmatched elements
+			// NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount`
+			// equals `i`), unless we didn't visit _any_ elements in the above loop because we have
+			// no element matchers and no seed.
+			// Incrementing an initially-string "0" `i` allows `i` to remain a string only in that
+			// case, which will result in a "00" `matchedCount` that differs from `i` but is also
+			// numerically zero.
+			if ( bySet && i !== matchedCount ) {
+				j = 0;
+				while ( ( matcher = setMatchers[ j++ ] ) ) {
+					matcher( unmatched, setMatched, context, xml );
+				}
+
+				if ( seed ) {
+
+					// Reintegrate element matches to eliminate the need for sorting
+					if ( matchedCount > 0 ) {
+						while ( i-- ) {
+							if ( !( unmatched[ i ] || setMatched[ i ] ) ) {
+								setMatched[ i ] = pop.call( results );
+							}
+						}
+					}
+
+					// Discard index placeholder values to get only actual matches
+					setMatched = condense( setMatched );
+				}
+
+				// Add matches to results
+				push.apply( results, setMatched );
+
+				// Seedless set matches succeeding multiple successful matchers stipulate sorting
+				if ( outermost && !seed && setMatched.length > 0 &&
+					( matchedCount + setMatchers.length ) > 1 ) {
+
+					Sizzle.uniqueSort( results );
+				}
+			}
+
+			// Override manipulation of globals by nested matchers
+			if ( outermost ) {
+				dirruns = dirrunsUnique;
+				outermostContext = contextBackup;
+			}
+
+			return unmatched;
+		};
+
+	return bySet ?
+		markFunction( superMatcher ) :
+		superMatcher;
+}
+
+compile = Sizzle.compile = function( selector, match /* Internal Use Only */ ) {
+	var i,
+		setMatchers = [],
+		elementMatchers = [],
+		cached = compilerCache[ selector + " " ];
+
+	if ( !cached ) {
+
+		// Generate a function of recursive functions that can be used to check each element
+		if ( !match ) {
+			match = tokenize( selector );
+		}
+		i = match.length;
+		while ( i-- ) {
+			cached = matcherFromTokens( match[ i ] );
+			if ( cached[ expando ] ) {
+				setMatchers.push( cached );
+			} else {
+				elementMatchers.push( cached );
+			}
+		}
+
+		// Cache the compiled function
+		cached = compilerCache(
+			selector,
+			matcherFromGroupMatchers( elementMatchers, setMatchers )
+		);
+
+		// Save selector and tokenization
+		cached.selector = selector;
+	}
+	return cached;
+};
+
+/**
+ * A low-level selection function that works with Sizzle's compiled
+ *  selector functions
+ * @param {String|Function} selector A selector or a pre-compiled
+ *  selector function built with Sizzle.compile
+ * @param {Element} context
+ * @param {Array} [results]
+ * @param {Array} [seed] A set of elements to match against
+ */
+select = Sizzle.select = function( selector, context, results, seed ) {
+	var i, tokens, token, type, find,
+		compiled = typeof selector === "function" && selector,
+		match = !seed && tokenize( ( selector = compiled.selector || selector ) );
+
+	results = results || [];
+
+	// Try to minimize operations if there is only one selector in the list and no seed
+	// (the latter of which guarantees us context)
+	if ( match.length === 1 ) {
+
+		// Reduce context if the leading compound selector is an ID
+		tokens = match[ 0 ] = match[ 0 ].slice( 0 );
+		if ( tokens.length > 2 && ( token = tokens[ 0 ] ).type === "ID" &&
+			context.nodeType === 9 && documentIsHTML && Expr.relative[ tokens[ 1 ].type ] ) {
+
+			context = ( Expr.find[ "ID" ]( token.matches[ 0 ]
+				.replace( runescape, funescape ), context ) || [] )[ 0 ];
+			if ( !context ) {
+				return results;
+
+			// Precompiled matchers will still verify ancestry, so step up a level
+			} else if ( compiled ) {
+				context = context.parentNode;
+			}
+
+			selector = selector.slice( tokens.shift().value.length );
+		}
+
+		// Fetch a seed set for right-to-left matching
+		i = matchExpr[ "needsContext" ].test( selector ) ? 0 : tokens.length;
+		while ( i-- ) {
+			token = tokens[ i ];
+
+			// Abort if we hit a combinator
+			if ( Expr.relative[ ( type = token.type ) ] ) {
+				break;
+			}
+			if ( ( find = Expr.find[ type ] ) ) {
+
+				// Search, expanding context for leading sibling combinators
+				if ( ( seed = find(
+					token.matches[ 0 ].replace( runescape, funescape ),
+					rsibling.test( tokens[ 0 ].type ) && testContext( context.parentNode ) ||
+						context
+				) ) ) {
+
+					// If seed is empty or no tokens remain, we can return early
+					tokens.splice( i, 1 );
+					selector = seed.length && toSelector( tokens );
+					if ( !selector ) {
+						push.apply( results, seed );
+						return results;
+					}
+
+					break;
+				}
+			}
+		}
+	}
+
+	// Compile and execute a filtering function if one is not provided
+	// Provide `match` to avoid retokenization if we modified the selector above
+	( compiled || compile( selector, match ) )(
+		seed,
+		context,
+		!documentIsHTML,
+		results,
+		!context || rsibling.test( selector ) && testContext( context.parentNode ) || context
+	);
+	return results;
+};
+
+// One-time assignments
+
+// Sort stability
+support.sortStable = expando.split( "" ).sort( sortOrder ).join( "" ) === expando;
+
+// Support: Chrome 14-35+
+// Always assume duplicates if they aren't passed to the comparison function
+support.detectDuplicates = !!hasDuplicate;
+
+// Initialize against the default document
+setDocument();
+
+// Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27)
+// Detached nodes confoundingly follow *each other*
+support.sortDetached = assert( function( el ) {
+
+	// Should return 1, but returns 4 (following)
+	return el.compareDocumentPosition( document.createElement( "fieldset" ) ) & 1;
+} );
+
+// Support: IE<8
+// Prevent attribute/property "interpolation"
+// https://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx
+if ( !assert( function( el ) {
+	el.innerHTML = "<a href='#'></a>";
+	return el.firstChild.getAttribute( "href" ) === "#";
+} ) ) {
+	addHandle( "type|href|height|width", function( elem, name, isXML ) {
+		if ( !isXML ) {
+			return elem.getAttribute( name, name.toLowerCase() === "type" ? 1 : 2 );
+		}
+	} );
+}
+
+// Support: IE<9
+// Use defaultValue in place of getAttribute("value")
+if ( !support.attributes || !assert( function( el ) {
+	el.innerHTML = "<input/>";
+	el.firstChild.setAttribute( "value", "" );
+	return el.firstChild.getAttribute( "value" ) === "";
+} ) ) {
+	addHandle( "value", function( elem, _name, isXML ) {
+		if ( !isXML && elem.nodeName.toLowerCase() === "input" ) {
+			return elem.defaultValue;
+		}
+	} );
+}
+
+// Support: IE<9
+// Use getAttributeNode to fetch booleans when getAttribute lies
+if ( !assert( function( el ) {
+	return el.getAttribute( "disabled" ) == null;
+} ) ) {
+	addHandle( booleans, function( elem, name, isXML ) {
+		var val;
+		if ( !isXML ) {
+			return elem[ name ] === true ? name.toLowerCase() :
+				( val = elem.getAttributeNode( name ) ) && val.specified ?
+					val.value :
+					null;
+		}
+	} );
+}
+
+return Sizzle;
+
+} )( window );
+
+
+
+jQuery.find = Sizzle;
+jQuery.expr = Sizzle.selectors;
+
+// Deprecated
+jQuery.expr[ ":" ] = jQuery.expr.pseudos;
+jQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort;
+jQuery.text = Sizzle.getText;
+jQuery.isXMLDoc = Sizzle.isXML;
+jQuery.contains = Sizzle.contains;
+jQuery.escapeSelector = Sizzle.escape;
+
+
+
+
+var dir = function( elem, dir, until ) {
+	var matched = [],
+		truncate = until !== undefined;
+
+	while ( ( elem = elem[ dir ] ) && elem.nodeType !== 9 ) {
+		if ( elem.nodeType === 1 ) {
+			if ( truncate && jQuery( elem ).is( until ) ) {
+				break;
+			}
+			matched.push( elem );
+		}
+	}
+	return matched;
+};
+
+
+var siblings = function( n, elem ) {
+	var matched = [];
+
+	for ( ; n; n = n.nextSibling ) {
+		if ( n.nodeType === 1 && n !== elem ) {
+			matched.push( n );
+		}
+	}
+
+	return matched;
+};
+
+
+var rneedsContext = jQuery.expr.match.needsContext;
+
+
+
+function nodeName( elem, name ) {
+
+	return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase();
+
+}
+var rsingleTag = ( /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i );
+
+
+
+// Implement the identical functionality for filter and not
+function winnow( elements, qualifier, not ) {
+	if ( isFunction( qualifier ) ) {
+		return jQuery.grep( elements, function( elem, i ) {
+			return !!qualifier.call( elem, i, elem ) !== not;
+		} );
+	}
+
+	// Single element
+	if ( qualifier.nodeType ) {
+		return jQuery.grep( elements, function( elem ) {
+			return ( elem === qualifier ) !== not;
+		} );
+	}
+
+	// Arraylike of elements (jQuery, arguments, Array)
+	if ( typeof qualifier !== "string" ) {
+		return jQuery.grep( elements, function( elem ) {
+			return ( indexOf.call( qualifier, elem ) > -1 ) !== not;
+		} );
+	}
+
+	// Filtered directly for both simple and complex selectors
+	return jQuery.filter( qualifier, elements, not );
+}
+
+jQuery.filter = function( expr, elems, not ) {
+	var elem = elems[ 0 ];
+
+	if ( not ) {
+		expr = ":not(" + expr + ")";
+	}
+
+	if ( elems.length === 1 && elem.nodeType === 1 ) {
+		return jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [];
+	}
+
+	return jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) {
+		return elem.nodeType === 1;
+	} ) );
+};
+
+jQuery.fn.extend( {
+	find: function( selector ) {
+		var i, ret,
+			len = this.length,
+			self = this;
+
+		if ( typeof selector !== "string" ) {
+			return this.pushStack( jQuery( selector ).filter( function() {
+				for ( i = 0; i < len; i++ ) {
+					if ( jQuery.contains( self[ i ], this ) ) {
+						return true;
+					}
+				}
+			} ) );
+		}
... 40956 lines suppressed ...