summaryrefslogtreecommitdiffstats
path: root/docs/sqlglot/dialects/bigquery.html
diff options
context:
space:
mode:
Diffstat (limited to 'docs/sqlglot/dialects/bigquery.html')
-rw-r--r--docs/sqlglot/dialects/bigquery.html2313
1 files changed, 1152 insertions, 1161 deletions
diff --git a/docs/sqlglot/dialects/bigquery.html b/docs/sqlglot/dialects/bigquery.html
index acde151..384c5bc 100644
--- a/docs/sqlglot/dialects/bigquery.html
+++ b/docs/sqlglot/dialects/bigquery.html
@@ -3,7 +3,7 @@
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
- <meta name="generator" content="pdoc 14.4.0"/>
+ <meta name="generator" content="pdoc 14.5.0"/>
<title>sqlglot.dialects.bigquery API documentation</title>
<style>/*! * Bootstrap Reboot v5.0.0 (https://getbootstrap.com/) * Copyright 2011-2021 The Bootstrap Authors * Copyright 2011-2021 Twitter, Inc. * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) * Forked from Normalize.css, licensed MIT (https://github.com/necolas/normalize.css/blob/master/LICENSE.md) */*,::after,::before{box-sizing:border-box}@media (prefers-reduced-motion:no-preference){:root{scroll-behavior:smooth}}body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans","Liberation Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";font-size:1rem;font-weight:400;line-height:1.5;color:#212529;background-color:#fff;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}hr{margin:1rem 0;color:inherit;background-color:currentColor;border:0;opacity:.25}hr:not([size]){height:1px}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem;font-weight:500;line-height:1.2}h1{font-size:calc(1.375rem + 1.5vw)}@media (min-width:1200px){h1{font-size:2.5rem}}h2{font-size:calc(1.325rem + .9vw)}@media (min-width:1200px){h2{font-size:2rem}}h3{font-size:calc(1.3rem + .6vw)}@media (min-width:1200px){h3{font-size:1.75rem}}h4{font-size:calc(1.275rem + .3vw)}@media (min-width:1200px){h4{font-size:1.5rem}}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-top:0;margin-bottom:1rem}abbr[data-bs-original-title],abbr[title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none}address{margin-bottom:1rem;font-style:normal;line-height:inherit}ol,ul{padding-left:2rem}dl,ol,ul{margin-top:0;margin-bottom:1rem}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}b,strong{font-weight:bolder}small{font-size:.875em}mark{padding:.2em;background-color:#fcf8e3}sub,sup{position:relative;font-size:.75em;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#0d6efd;text-decoration:underline}a:hover{color:#0a58ca}a:not([href]):not([class]),a:not([href]):not([class]):hover{color:inherit;text-decoration:none}code,kbd,pre,samp{font-family:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1em;direction:ltr;unicode-bidi:bidi-override}pre{display:block;margin-top:0;margin-bottom:1rem;overflow:auto;font-size:.875em}pre code{font-size:inherit;color:inherit;word-break:normal}code{font-size:.875em;color:#d63384;word-wrap:break-word}a>code{color:inherit}kbd{padding:.2rem .4rem;font-size:.875em;color:#fff;background-color:#212529;border-radius:.2rem}kbd kbd{padding:0;font-size:1em;font-weight:700}figure{margin:0 0 1rem}img,svg{vertical-align:middle}table{caption-side:bottom;border-collapse:collapse}caption{padding-top:.5rem;padding-bottom:.5rem;color:#6c757d;text-align:left}th{text-align:inherit;text-align:-webkit-match-parent}tbody,td,tfoot,th,thead,tr{border-color:inherit;border-style:solid;border-width:0}label{display:inline-block}button{border-radius:0}button:focus:not(:focus-visible){outline:0}button,input,optgroup,select,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,select{text-transform:none}[role=button]{cursor:pointer}select{word-wrap:normal}select:disabled{opacity:1}[list]::-webkit-calendar-picker-indicator{display:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]:not(:disabled),[type=reset]:not(:disabled),[type=submit]:not(:disabled),button:not(:disabled){cursor:pointer}::-moz-focus-inner{padding:0;border-style:none}textarea{resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{float:left;width:100%;padding:0;margin-bottom:.5rem;font-size:calc(1.275rem + .3vw);line-height:inherit}@media (min-width:1200px){legend{font-size:1.5rem}}legend+*{clear:left}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-fields-wrapper,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-text,::-webkit-datetime-edit-year-field{padding:0}::-webkit-inner-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:textfield}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-color-swatch-wrapper{padding:0}::file-selector-button{font:inherit}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}iframe{border:0}summary{display:list-item;cursor:pointer}progress{vertical-align:baseline}[hidden]{display:none!important}</style>
@@ -223,6 +223,9 @@
<a class="variable" href="#BigQuery.Generator.HEX_FUNC">HEX_FUNC</a>
</li>
<li>
+ <a class="variable" href="#BigQuery.Generator.WITH_PROPERTIES_PREFIX">WITH_PROPERTIES_PREFIX</a>
+ </li>
+ <li>
<a class="variable" href="#BigQuery.Generator.TRANSFORMS">TRANSFORMS</a>
</li>
<li>
@@ -271,9 +274,6 @@
<a class="function" href="#BigQuery.Generator.intersect_op">intersect_op</a>
</li>
<li>
- <a class="function" href="#BigQuery.Generator.with_properties">with_properties</a>
- </li>
- <li>
<a class="function" href="#BigQuery.Generator.version_sql">version_sql</a>
</li>
<li>
@@ -946,350 +946,348 @@
</span><span id="L-570"><a href="#L-570"><span class="linenos">570</span></a> <span class="n">SUPPORTS_TO_NUMBER</span> <span class="o">=</span> <span class="kc">False</span>
</span><span id="L-571"><a href="#L-571"><span class="linenos">571</span></a> <span class="n">NAMED_PLACEHOLDER_TOKEN</span> <span class="o">=</span> <span class="s2">&quot;@&quot;</span>
</span><span id="L-572"><a href="#L-572"><span class="linenos">572</span></a> <span class="n">HEX_FUNC</span> <span class="o">=</span> <span class="s2">&quot;TO_HEX&quot;</span>
-</span><span id="L-573"><a href="#L-573"><span class="linenos">573</span></a>
-</span><span id="L-574"><a href="#L-574"><span class="linenos">574</span></a> <span class="n">TRANSFORMS</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="L-575"><a href="#L-575"><span class="linenos">575</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TRANSFORMS</span><span class="p">,</span>
-</span><span id="L-576"><a href="#L-576"><span class="linenos">576</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ApproxDistinct</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;APPROX_COUNT_DISTINCT&quot;</span><span class="p">),</span>
-</span><span id="L-577"><a href="#L-577"><span class="linenos">577</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMax</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MAX_BY&quot;</span><span class="p">),</span>
-</span><span id="L-578"><a href="#L-578"><span class="linenos">578</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMin</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MIN_BY&quot;</span><span class="p">),</span>
-</span><span id="L-579"><a href="#L-579"><span class="linenos">579</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Array</span><span class="p">:</span> <span class="n">inline_array_unless_query</span><span class="p">,</span>
-</span><span id="L-580"><a href="#L-580"><span class="linenos">580</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayContains</span><span class="p">:</span> <span class="n">_array_contains_sql</span><span class="p">,</span>
-</span><span id="L-581"><a href="#L-581"><span class="linenos">581</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayFilter</span><span class="p">:</span> <span class="n">filter_array_using_unnest</span><span class="p">,</span>
-</span><span id="L-582"><a href="#L-582"><span class="linenos">582</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArraySize</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;ARRAY_LENGTH&quot;</span><span class="p">),</span>
-</span><span id="L-583"><a href="#L-583"><span class="linenos">583</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">transforms</span><span class="o">.</span><span class="n">remove_precision_parameterized_types</span><span class="p">]),</span>
-</span><span id="L-584"><a href="#L-584"><span class="linenos">584</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CollateProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
-</span><span id="L-585"><a href="#L-585"><span class="linenos">585</span></a> <span class="sa">f</span><span class="s2">&quot;DEFAULT COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="L-586"><a href="#L-586"><span class="linenos">586</span></a> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;default&quot;</span><span class="p">)</span>
-</span><span id="L-587"><a href="#L-587"><span class="linenos">587</span></a> <span class="k">else</span> <span class="sa">f</span><span class="s2">&quot;COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="L-588"><a href="#L-588"><span class="linenos">588</span></a> <span class="p">),</span>
-</span><span id="L-589"><a href="#L-589"><span class="linenos">589</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Commit</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;COMMIT TRANSACTION&quot;</span><span class="p">,</span>
-</span><span id="L-590"><a href="#L-590"><span class="linenos">590</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CountIf</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;COUNTIF&quot;</span><span class="p">),</span>
-</span><span id="L-591"><a href="#L-591"><span class="linenos">591</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Create</span><span class="p">:</span> <span class="n">_create_sql</span><span class="p">,</span>
-</span><span id="L-592"><a href="#L-592"><span class="linenos">592</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CTE</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">_pushdown_cte_column_names</span><span class="p">]),</span>
-</span><span id="L-593"><a href="#L-593"><span class="linenos">593</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="L-594"><a href="#L-594"><span class="linenos">594</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateDiff</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="L-595"><a href="#L-595"><span class="linenos">595</span></a> <span class="s2">&quot;DATE_DIFF&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span> <span class="n">unit_to_var</span><span class="p">(</span><span class="n">e</span><span class="p">)</span>
-</span><span id="L-596"><a href="#L-596"><span class="linenos">596</span></a> <span class="p">),</span>
-</span><span id="L-597"><a href="#L-597"><span class="linenos">597</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">),</span>
-</span><span id="L-598"><a href="#L-598"><span class="linenos">598</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateStrToDate</span><span class="p">:</span> <span class="n">datestrtodate_sql</span><span class="p">,</span>
-</span><span id="L-599"><a href="#L-599"><span class="linenos">599</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="L-600"><a href="#L-600"><span class="linenos">600</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="L-601"><a href="#L-601"><span class="linenos">601</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="L-602"><a href="#L-602"><span class="linenos">602</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateTrunc</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATE_TRUNC&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;unit&quot;</span><span class="p">)),</span>
-</span><span id="L-603"><a href="#L-603"><span class="linenos">603</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">FromTimeZone</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="L-604"><a href="#L-604"><span class="linenos">604</span></a> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)),</span> <span class="s2">&quot;&#39;UTC&#39;&quot;</span>
-</span><span id="L-605"><a href="#L-605"><span class="linenos">605</span></a> <span class="p">),</span>
-</span><span id="L-606"><a href="#L-606"><span class="linenos">606</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GenerateSeries</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;GENERATE_ARRAY&quot;</span><span class="p">),</span>
-</span><span id="L-607"><a href="#L-607"><span class="linenos">607</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GroupConcat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;STRING_AGG&quot;</span><span class="p">),</span>
-</span><span id="L-608"><a href="#L-608"><span class="linenos">608</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Hex</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;UPPER&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&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">e</span><span class="p">,</span> <span class="s2">&quot;this&quot;</span><span class="p">))),</span>
-</span><span id="L-609"><a href="#L-609"><span class="linenos">609</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">If</span><span class="p">:</span> <span class="n">if_sql</span><span class="p">(</span><span class="n">false_value</span><span class="o">=</span><span class="s2">&quot;NULL&quot;</span><span class="p">),</span>
-</span><span id="L-610"><a href="#L-610"><span class="linenos">610</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ILike</span><span class="p">:</span> <span class="n">no_ilike_sql</span><span class="p">,</span>
-</span><span id="L-611"><a href="#L-611"><span class="linenos">611</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">IntDiv</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DIV&quot;</span><span class="p">),</span>
-</span><span id="L-612"><a href="#L-612"><span class="linenos">612</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONFormat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TO_JSON_STRING&quot;</span><span class="p">),</span>
-</span><span id="L-613"><a href="#L-613"><span class="linenos">613</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Max</span><span class="p">:</span> <span class="n">max_or_greatest</span><span class="p">,</span>
-</span><span id="L-614"><a href="#L-614"><span class="linenos">614</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">)),</span>
-</span><span id="L-615"><a href="#L-615"><span class="linenos">615</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5Digest</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">),</span>
-</span><span id="L-616"><a href="#L-616"><span class="linenos">616</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Min</span><span class="p">:</span> <span class="n">min_or_least</span><span class="p">,</span>
-</span><span id="L-617"><a href="#L-617"><span class="linenos">617</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="sa">f</span><span class="s2">&quot;PARTITION BY </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">,</span>
-</span><span id="L-618"><a href="#L-618"><span class="linenos">618</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpExtract</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="L-619"><a href="#L-619"><span class="linenos">619</span></a> <span class="s2">&quot;REGEXP_EXTRACT&quot;</span><span class="p">,</span>
-</span><span id="L-620"><a href="#L-620"><span class="linenos">620</span></a> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span>
-</span><span id="L-621"><a href="#L-621"><span class="linenos">621</span></a> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span>
-</span><span id="L-622"><a href="#L-622"><span class="linenos">622</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;position&quot;</span><span class="p">),</span>
-</span><span id="L-623"><a href="#L-623"><span class="linenos">623</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;occurrence&quot;</span><span class="p">),</span>
-</span><span id="L-624"><a href="#L-624"><span class="linenos">624</span></a> <span class="p">),</span>
-</span><span id="L-625"><a href="#L-625"><span class="linenos">625</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpReplace</span><span class="p">:</span> <span class="n">regexp_replace_sql</span><span class="p">,</span>
-</span><span id="L-626"><a href="#L-626"><span class="linenos">626</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpLike</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;REGEXP_CONTAINS&quot;</span><span class="p">),</span>
-</span><span id="L-627"><a href="#L-627"><span class="linenos">627</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ReturnsProperty</span><span class="p">:</span> <span class="n">_returnsproperty_sql</span><span class="p">,</span>
-</span><span id="L-628"><a href="#L-628"><span class="linenos">628</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Rollback</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;ROLLBACK TRANSACTION&quot;</span><span class="p">,</span>
-</span><span id="L-629"><a href="#L-629"><span class="linenos">629</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Select</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">(</span>
-</span><span id="L-630"><a href="#L-630"><span class="linenos">630</span></a> <span class="p">[</span>
-</span><span id="L-631"><a href="#L-631"><span class="linenos">631</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">explode_to_unnest</span><span class="p">(),</span>
-</span><span id="L-632"><a href="#L-632"><span class="linenos">632</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">unqualify_unnest</span><span class="p">,</span>
-</span><span id="L-633"><a href="#L-633"><span class="linenos">633</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_distinct_on</span><span class="p">,</span>
-</span><span id="L-634"><a href="#L-634"><span class="linenos">634</span></a> <span class="n">_alias_ordered_group</span><span class="p">,</span>
-</span><span id="L-635"><a href="#L-635"><span class="linenos">635</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_semi_and_anti_joins</span><span class="p">,</span>
-</span><span id="L-636"><a href="#L-636"><span class="linenos">636</span></a> <span class="p">]</span>
-</span><span id="L-637"><a href="#L-637"><span class="linenos">637</span></a> <span class="p">),</span>
-</span><span id="L-638"><a href="#L-638"><span class="linenos">638</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;SHA1&quot;</span><span class="p">),</span>
-</span><span id="L-639"><a href="#L-639"><span class="linenos">639</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA2</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="L-640"><a href="#L-640"><span class="linenos">640</span></a> <span class="s2">&quot;SHA256&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;length&quot;</span><span class="p">)</span> <span class="o">==</span> <span class="s2">&quot;256&quot;</span> <span class="k">else</span> <span class="s2">&quot;SHA512&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span>
-</span><span id="L-641"><a href="#L-641"><span class="linenos">641</span></a> <span class="p">),</span>
-</span><span id="L-642"><a href="#L-642"><span class="linenos">642</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StabilityProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
-</span><span id="L-643"><a href="#L-643"><span class="linenos">643</span></a> <span class="s2">&quot;DETERMINISTIC&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;IMMUTABLE&quot;</span> <span class="k">else</span> <span class="s2">&quot;NOT DETERMINISTIC&quot;</span>
-</span><span id="L-644"><a href="#L-644"><span class="linenos">644</span></a> <span class="p">),</span>
-</span><span id="L-645"><a href="#L-645"><span class="linenos">645</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToDate</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;PARSE_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">),</span>
-</span><span id="L-646"><a href="#L-646"><span class="linenos">646</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToTime</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="L-647"><a href="#L-647"><span class="linenos">647</span></a> <span class="s2">&quot;PARSE_TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)</span>
-</span><span id="L-648"><a href="#L-648"><span class="linenos">648</span></a> <span class="p">),</span>
-</span><span id="L-649"><a href="#L-649"><span class="linenos">649</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="L-650"><a href="#L-650"><span class="linenos">650</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
-</span><span id="L-651"><a href="#L-651"><span class="linenos">651</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="L-652"><a href="#L-652"><span class="linenos">652</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="L-653"><a href="#L-653"><span class="linenos">653</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampDiff</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP_DIFF&quot;</span><span class="p">),</span>
-</span><span id="L-654"><a href="#L-654"><span class="linenos">654</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="L-655"><a href="#L-655"><span class="linenos">655</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeStrToTime</span><span class="p">:</span> <span class="n">timestrtotime_sql</span><span class="p">,</span>
-</span><span id="L-656"><a href="#L-656"><span class="linenos">656</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Transaction</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;BEGIN TRANSACTION&quot;</span><span class="p">,</span>
-</span><span id="L-657"><a href="#L-657"><span class="linenos">657</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Trim</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TRIM&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">),</span>
-</span><span id="L-658"><a href="#L-658"><span class="linenos">658</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsAdd</span><span class="p">:</span> <span class="n">_ts_or_ds_add_sql</span><span class="p">,</span>
-</span><span id="L-659"><a href="#L-659"><span class="linenos">659</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsDiff</span><span class="p">:</span> <span class="n">_ts_or_ds_diff_sql</span><span class="p">,</span>
-</span><span id="L-660"><a href="#L-660"><span class="linenos">660</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToTime</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
-</span><span id="L-661"><a href="#L-661"><span class="linenos">661</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Unhex</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;FROM_HEX&quot;</span><span class="p">),</span>
-</span><span id="L-662"><a href="#L-662"><span class="linenos">662</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixDate</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;UNIX_DATE&quot;</span><span class="p">),</span>
-</span><span id="L-663"><a href="#L-663"><span class="linenos">663</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixToTime</span><span class="p">:</span> <span class="n">_unix_to_time_sql</span><span class="p">,</span>
-</span><span id="L-664"><a href="#L-664"><span class="linenos">664</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Values</span><span class="p">:</span> <span class="n">_derived_table_values_to_unnest</span><span class="p">,</span>
-</span><span id="L-665"><a href="#L-665"><span class="linenos">665</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VariancePop</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;VAR_POP&quot;</span><span class="p">),</span>
-</span><span id="L-666"><a href="#L-666"><span class="linenos">666</span></a> <span class="p">}</span>
-</span><span id="L-667"><a href="#L-667"><span class="linenos">667</span></a>
-</span><span id="L-668"><a href="#L-668"><span class="linenos">668</span></a> <span class="n">SUPPORTED_JSON_PATH_PARTS</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="L-669"><a href="#L-669"><span class="linenos">669</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathKey</span><span class="p">,</span>
-</span><span id="L-670"><a href="#L-670"><span class="linenos">670</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathRoot</span><span class="p">,</span>
-</span><span id="L-671"><a href="#L-671"><span class="linenos">671</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathSubscript</span><span class="p">,</span>
-</span><span id="L-672"><a href="#L-672"><span class="linenos">672</span></a> <span class="p">}</span>
-</span><span id="L-673"><a href="#L-673"><span class="linenos">673</span></a>
-</span><span id="L-674"><a href="#L-674"><span class="linenos">674</span></a> <span class="n">TYPE_MAPPING</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="L-675"><a href="#L-675"><span class="linenos">675</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TYPE_MAPPING</span><span class="p">,</span>
-</span><span id="L-676"><a href="#L-676"><span class="linenos">676</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGDECIMAL</span><span class="p">:</span> <span class="s2">&quot;BIGNUMERIC&quot;</span><span class="p">,</span>
-</span><span id="L-677"><a href="#L-677"><span class="linenos">677</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="L-678"><a href="#L-678"><span class="linenos">678</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
-</span><span id="L-679"><a href="#L-679"><span class="linenos">679</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BOOLEAN</span><span class="p">:</span> <span class="s2">&quot;BOOL&quot;</span><span class="p">,</span>
-</span><span id="L-680"><a href="#L-680"><span class="linenos">680</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">CHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="L-681"><a href="#L-681"><span class="linenos">681</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DECIMAL</span><span class="p">:</span> <span class="s2">&quot;NUMERIC&quot;</span><span class="p">,</span>
-</span><span id="L-682"><a href="#L-682"><span class="linenos">682</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DOUBLE</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
-</span><span id="L-683"><a href="#L-683"><span class="linenos">683</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">FLOAT</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
-</span><span id="L-684"><a href="#L-684"><span class="linenos">684</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">INT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="L-685"><a href="#L-685"><span class="linenos">685</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="L-686"><a href="#L-686"><span class="linenos">686</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NVARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="L-687"><a href="#L-687"><span class="linenos">687</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">SMALLINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="L-688"><a href="#L-688"><span class="linenos">688</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TEXT</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="L-689"><a href="#L-689"><span class="linenos">689</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMP</span><span class="p">:</span> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span>
-</span><span id="L-690"><a href="#L-690"><span class="linenos">690</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
-</span><span id="L-691"><a href="#L-691"><span class="linenos">691</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPLTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
-</span><span id="L-692"><a href="#L-692"><span class="linenos">692</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TINYINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="L-693"><a href="#L-693"><span class="linenos">693</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARBINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
-</span><span id="L-694"><a href="#L-694"><span class="linenos">694</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">ROWVERSION</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
-</span><span id="L-695"><a href="#L-695"><span class="linenos">695</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="L-696"><a href="#L-696"><span class="linenos">696</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARIANT</span><span class="p">:</span> <span class="s2">&quot;ANY TYPE&quot;</span><span class="p">,</span>
-</span><span id="L-697"><a href="#L-697"><span class="linenos">697</span></a> <span class="p">}</span>
-</span><span id="L-698"><a href="#L-698"><span class="linenos">698</span></a>
-</span><span id="L-699"><a href="#L-699"><span class="linenos">699</span></a> <span class="n">PROPERTIES_LOCATION</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="L-700"><a href="#L-700"><span class="linenos">700</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">PROPERTIES_LOCATION</span><span class="p">,</span>
-</span><span id="L-701"><a href="#L-701"><span class="linenos">701</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">POST_SCHEMA</span><span class="p">,</span>
-</span><span id="L-702"><a href="#L-702"><span class="linenos">702</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VolatileProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">UNSUPPORTED</span><span class="p">,</span>
-</span><span id="L-703"><a href="#L-703"><span class="linenos">703</span></a> <span class="p">}</span>
-</span><span id="L-704"><a href="#L-704"><span class="linenos">704</span></a>
-</span><span id="L-705"><a href="#L-705"><span class="linenos">705</span></a> <span class="c1"># from: https://cloud.google.com/bigquery/docs/reference/standard-sql/lexical#reserved_keywords</span>
-</span><span id="L-706"><a href="#L-706"><span class="linenos">706</span></a> <span class="n">RESERVED_KEYWORDS</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="L-707"><a href="#L-707"><span class="linenos">707</span></a> <span class="o">*</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">RESERVED_KEYWORDS</span><span class="p">,</span>
-</span><span id="L-708"><a href="#L-708"><span class="linenos">708</span></a> <span class="s2">&quot;all&quot;</span><span class="p">,</span>
-</span><span id="L-709"><a href="#L-709"><span class="linenos">709</span></a> <span class="s2">&quot;and&quot;</span><span class="p">,</span>
-</span><span id="L-710"><a href="#L-710"><span class="linenos">710</span></a> <span class="s2">&quot;any&quot;</span><span class="p">,</span>
-</span><span id="L-711"><a href="#L-711"><span class="linenos">711</span></a> <span class="s2">&quot;array&quot;</span><span class="p">,</span>
-</span><span id="L-712"><a href="#L-712"><span class="linenos">712</span></a> <span class="s2">&quot;as&quot;</span><span class="p">,</span>
-</span><span id="L-713"><a href="#L-713"><span class="linenos">713</span></a> <span class="s2">&quot;asc&quot;</span><span class="p">,</span>
-</span><span id="L-714"><a href="#L-714"><span class="linenos">714</span></a> <span class="s2">&quot;assert_rows_modified&quot;</span><span class="p">,</span>
-</span><span id="L-715"><a href="#L-715"><span class="linenos">715</span></a> <span class="s2">&quot;at&quot;</span><span class="p">,</span>
-</span><span id="L-716"><a href="#L-716"><span class="linenos">716</span></a> <span class="s2">&quot;between&quot;</span><span class="p">,</span>
-</span><span id="L-717"><a href="#L-717"><span class="linenos">717</span></a> <span class="s2">&quot;by&quot;</span><span class="p">,</span>
-</span><span id="L-718"><a href="#L-718"><span class="linenos">718</span></a> <span class="s2">&quot;case&quot;</span><span class="p">,</span>
-</span><span id="L-719"><a href="#L-719"><span class="linenos">719</span></a> <span class="s2">&quot;cast&quot;</span><span class="p">,</span>
-</span><span id="L-720"><a href="#L-720"><span class="linenos">720</span></a> <span class="s2">&quot;collate&quot;</span><span class="p">,</span>
-</span><span id="L-721"><a href="#L-721"><span class="linenos">721</span></a> <span class="s2">&quot;contains&quot;</span><span class="p">,</span>
-</span><span id="L-722"><a href="#L-722"><span class="linenos">722</span></a> <span class="s2">&quot;create&quot;</span><span class="p">,</span>
-</span><span id="L-723"><a href="#L-723"><span class="linenos">723</span></a> <span class="s2">&quot;cross&quot;</span><span class="p">,</span>
-</span><span id="L-724"><a href="#L-724"><span class="linenos">724</span></a> <span class="s2">&quot;cube&quot;</span><span class="p">,</span>
-</span><span id="L-725"><a href="#L-725"><span class="linenos">725</span></a> <span class="s2">&quot;current&quot;</span><span class="p">,</span>
-</span><span id="L-726"><a href="#L-726"><span class="linenos">726</span></a> <span class="s2">&quot;default&quot;</span><span class="p">,</span>
-</span><span id="L-727"><a href="#L-727"><span class="linenos">727</span></a> <span class="s2">&quot;define&quot;</span><span class="p">,</span>
-</span><span id="L-728"><a href="#L-728"><span class="linenos">728</span></a> <span class="s2">&quot;desc&quot;</span><span class="p">,</span>
-</span><span id="L-729"><a href="#L-729"><span class="linenos">729</span></a> <span class="s2">&quot;distinct&quot;</span><span class="p">,</span>
-</span><span id="L-730"><a href="#L-730"><span class="linenos">730</span></a> <span class="s2">&quot;else&quot;</span><span class="p">,</span>
-</span><span id="L-731"><a href="#L-731"><span class="linenos">731</span></a> <span class="s2">&quot;end&quot;</span><span class="p">,</span>
-</span><span id="L-732"><a href="#L-732"><span class="linenos">732</span></a> <span class="s2">&quot;enum&quot;</span><span class="p">,</span>
-</span><span id="L-733"><a href="#L-733"><span class="linenos">733</span></a> <span class="s2">&quot;escape&quot;</span><span class="p">,</span>
-</span><span id="L-734"><a href="#L-734"><span class="linenos">734</span></a> <span class="s2">&quot;except&quot;</span><span class="p">,</span>
-</span><span id="L-735"><a href="#L-735"><span class="linenos">735</span></a> <span class="s2">&quot;exclude&quot;</span><span class="p">,</span>
-</span><span id="L-736"><a href="#L-736"><span class="linenos">736</span></a> <span class="s2">&quot;exists&quot;</span><span class="p">,</span>
-</span><span id="L-737"><a href="#L-737"><span class="linenos">737</span></a> <span class="s2">&quot;extract&quot;</span><span class="p">,</span>
-</span><span id="L-738"><a href="#L-738"><span class="linenos">738</span></a> <span class="s2">&quot;false&quot;</span><span class="p">,</span>
-</span><span id="L-739"><a href="#L-739"><span class="linenos">739</span></a> <span class="s2">&quot;fetch&quot;</span><span class="p">,</span>
-</span><span id="L-740"><a href="#L-740"><span class="linenos">740</span></a> <span class="s2">&quot;following&quot;</span><span class="p">,</span>
-</span><span id="L-741"><a href="#L-741"><span class="linenos">741</span></a> <span class="s2">&quot;for&quot;</span><span class="p">,</span>
-</span><span id="L-742"><a href="#L-742"><span class="linenos">742</span></a> <span class="s2">&quot;from&quot;</span><span class="p">,</span>
-</span><span id="L-743"><a href="#L-743"><span class="linenos">743</span></a> <span class="s2">&quot;full&quot;</span><span class="p">,</span>
-</span><span id="L-744"><a href="#L-744"><span class="linenos">744</span></a> <span class="s2">&quot;group&quot;</span><span class="p">,</span>
-</span><span id="L-745"><a href="#L-745"><span class="linenos">745</span></a> <span class="s2">&quot;grouping&quot;</span><span class="p">,</span>
-</span><span id="L-746"><a href="#L-746"><span class="linenos">746</span></a> <span class="s2">&quot;groups&quot;</span><span class="p">,</span>
-</span><span id="L-747"><a href="#L-747"><span class="linenos">747</span></a> <span class="s2">&quot;hash&quot;</span><span class="p">,</span>
-</span><span id="L-748"><a href="#L-748"><span class="linenos">748</span></a> <span class="s2">&quot;having&quot;</span><span class="p">,</span>
-</span><span id="L-749"><a href="#L-749"><span class="linenos">749</span></a> <span class="s2">&quot;if&quot;</span><span class="p">,</span>
-</span><span id="L-750"><a href="#L-750"><span class="linenos">750</span></a> <span class="s2">&quot;ignore&quot;</span><span class="p">,</span>
-</span><span id="L-751"><a href="#L-751"><span class="linenos">751</span></a> <span class="s2">&quot;in&quot;</span><span class="p">,</span>
-</span><span id="L-752"><a href="#L-752"><span class="linenos">752</span></a> <span class="s2">&quot;inner&quot;</span><span class="p">,</span>
-</span><span id="L-753"><a href="#L-753"><span class="linenos">753</span></a> <span class="s2">&quot;intersect&quot;</span><span class="p">,</span>
-</span><span id="L-754"><a href="#L-754"><span class="linenos">754</span></a> <span class="s2">&quot;interval&quot;</span><span class="p">,</span>
-</span><span id="L-755"><a href="#L-755"><span class="linenos">755</span></a> <span class="s2">&quot;into&quot;</span><span class="p">,</span>
-</span><span id="L-756"><a href="#L-756"><span class="linenos">756</span></a> <span class="s2">&quot;is&quot;</span><span class="p">,</span>
-</span><span id="L-757"><a href="#L-757"><span class="linenos">757</span></a> <span class="s2">&quot;join&quot;</span><span class="p">,</span>
-</span><span id="L-758"><a href="#L-758"><span class="linenos">758</span></a> <span class="s2">&quot;lateral&quot;</span><span class="p">,</span>
-</span><span id="L-759"><a href="#L-759"><span class="linenos">759</span></a> <span class="s2">&quot;left&quot;</span><span class="p">,</span>
-</span><span id="L-760"><a href="#L-760"><span class="linenos">760</span></a> <span class="s2">&quot;like&quot;</span><span class="p">,</span>
-</span><span id="L-761"><a href="#L-761"><span class="linenos">761</span></a> <span class="s2">&quot;limit&quot;</span><span class="p">,</span>
-</span><span id="L-762"><a href="#L-762"><span class="linenos">762</span></a> <span class="s2">&quot;lookup&quot;</span><span class="p">,</span>
-</span><span id="L-763"><a href="#L-763"><span class="linenos">763</span></a> <span class="s2">&quot;merge&quot;</span><span class="p">,</span>
-</span><span id="L-764"><a href="#L-764"><span class="linenos">764</span></a> <span class="s2">&quot;natural&quot;</span><span class="p">,</span>
-</span><span id="L-765"><a href="#L-765"><span class="linenos">765</span></a> <span class="s2">&quot;new&quot;</span><span class="p">,</span>
-</span><span id="L-766"><a href="#L-766"><span class="linenos">766</span></a> <span class="s2">&quot;no&quot;</span><span class="p">,</span>
-</span><span id="L-767"><a href="#L-767"><span class="linenos">767</span></a> <span class="s2">&quot;not&quot;</span><span class="p">,</span>
-</span><span id="L-768"><a href="#L-768"><span class="linenos">768</span></a> <span class="s2">&quot;null&quot;</span><span class="p">,</span>
-</span><span id="L-769"><a href="#L-769"><span class="linenos">769</span></a> <span class="s2">&quot;nulls&quot;</span><span class="p">,</span>
-</span><span id="L-770"><a href="#L-770"><span class="linenos">770</span></a> <span class="s2">&quot;of&quot;</span><span class="p">,</span>
-</span><span id="L-771"><a href="#L-771"><span class="linenos">771</span></a> <span class="s2">&quot;on&quot;</span><span class="p">,</span>
-</span><span id="L-772"><a href="#L-772"><span class="linenos">772</span></a> <span class="s2">&quot;or&quot;</span><span class="p">,</span>
-</span><span id="L-773"><a href="#L-773"><span class="linenos">773</span></a> <span class="s2">&quot;order&quot;</span><span class="p">,</span>
-</span><span id="L-774"><a href="#L-774"><span class="linenos">774</span></a> <span class="s2">&quot;outer&quot;</span><span class="p">,</span>
-</span><span id="L-775"><a href="#L-775"><span class="linenos">775</span></a> <span class="s2">&quot;over&quot;</span><span class="p">,</span>
-</span><span id="L-776"><a href="#L-776"><span class="linenos">776</span></a> <span class="s2">&quot;partition&quot;</span><span class="p">,</span>
-</span><span id="L-777"><a href="#L-777"><span class="linenos">777</span></a> <span class="s2">&quot;preceding&quot;</span><span class="p">,</span>
-</span><span id="L-778"><a href="#L-778"><span class="linenos">778</span></a> <span class="s2">&quot;proto&quot;</span><span class="p">,</span>
-</span><span id="L-779"><a href="#L-779"><span class="linenos">779</span></a> <span class="s2">&quot;qualify&quot;</span><span class="p">,</span>
-</span><span id="L-780"><a href="#L-780"><span class="linenos">780</span></a> <span class="s2">&quot;range&quot;</span><span class="p">,</span>
-</span><span id="L-781"><a href="#L-781"><span class="linenos">781</span></a> <span class="s2">&quot;recursive&quot;</span><span class="p">,</span>
-</span><span id="L-782"><a href="#L-782"><span class="linenos">782</span></a> <span class="s2">&quot;respect&quot;</span><span class="p">,</span>
-</span><span id="L-783"><a href="#L-783"><span class="linenos">783</span></a> <span class="s2">&quot;right&quot;</span><span class="p">,</span>
-</span><span id="L-784"><a href="#L-784"><span class="linenos">784</span></a> <span class="s2">&quot;rollup&quot;</span><span class="p">,</span>
-</span><span id="L-785"><a href="#L-785"><span class="linenos">785</span></a> <span class="s2">&quot;rows&quot;</span><span class="p">,</span>
-</span><span id="L-786"><a href="#L-786"><span class="linenos">786</span></a> <span class="s2">&quot;select&quot;</span><span class="p">,</span>
-</span><span id="L-787"><a href="#L-787"><span class="linenos">787</span></a> <span class="s2">&quot;set&quot;</span><span class="p">,</span>
-</span><span id="L-788"><a href="#L-788"><span class="linenos">788</span></a> <span class="s2">&quot;some&quot;</span><span class="p">,</span>
-</span><span id="L-789"><a href="#L-789"><span class="linenos">789</span></a> <span class="s2">&quot;struct&quot;</span><span class="p">,</span>
-</span><span id="L-790"><a href="#L-790"><span class="linenos">790</span></a> <span class="s2">&quot;tablesample&quot;</span><span class="p">,</span>
-</span><span id="L-791"><a href="#L-791"><span class="linenos">791</span></a> <span class="s2">&quot;then&quot;</span><span class="p">,</span>
-</span><span id="L-792"><a href="#L-792"><span class="linenos">792</span></a> <span class="s2">&quot;to&quot;</span><span class="p">,</span>
-</span><span id="L-793"><a href="#L-793"><span class="linenos">793</span></a> <span class="s2">&quot;treat&quot;</span><span class="p">,</span>
-</span><span id="L-794"><a href="#L-794"><span class="linenos">794</span></a> <span class="s2">&quot;true&quot;</span><span class="p">,</span>
-</span><span id="L-795"><a href="#L-795"><span class="linenos">795</span></a> <span class="s2">&quot;unbounded&quot;</span><span class="p">,</span>
-</span><span id="L-796"><a href="#L-796"><span class="linenos">796</span></a> <span class="s2">&quot;union&quot;</span><span class="p">,</span>
-</span><span id="L-797"><a href="#L-797"><span class="linenos">797</span></a> <span class="s2">&quot;unnest&quot;</span><span class="p">,</span>
-</span><span id="L-798"><a href="#L-798"><span class="linenos">798</span></a> <span class="s2">&quot;using&quot;</span><span class="p">,</span>
-</span><span id="L-799"><a href="#L-799"><span class="linenos">799</span></a> <span class="s2">&quot;when&quot;</span><span class="p">,</span>
-</span><span id="L-800"><a href="#L-800"><span class="linenos">800</span></a> <span class="s2">&quot;where&quot;</span><span class="p">,</span>
-</span><span id="L-801"><a href="#L-801"><span class="linenos">801</span></a> <span class="s2">&quot;window&quot;</span><span class="p">,</span>
-</span><span id="L-802"><a href="#L-802"><span class="linenos">802</span></a> <span class="s2">&quot;with&quot;</span><span class="p">,</span>
-</span><span id="L-803"><a href="#L-803"><span class="linenos">803</span></a> <span class="s2">&quot;within&quot;</span><span class="p">,</span>
-</span><span id="L-804"><a href="#L-804"><span class="linenos">804</span></a> <span class="p">}</span>
-</span><span id="L-805"><a href="#L-805"><span class="linenos">805</span></a>
-</span><span id="L-806"><a href="#L-806"><span class="linenos">806</span></a> <span class="k">def</span> <span class="nf">mod_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Mod</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-807"><a href="#L-807"><span class="linenos">807</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
-</span><span id="L-808"><a href="#L-808"><span class="linenos">808</span></a> <span class="n">expr</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expression</span>
-</span><span id="L-809"><a href="#L-809"><span class="linenos">809</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="L-810"><a href="#L-810"><span class="linenos">810</span></a> <span class="s2">&quot;MOD&quot;</span><span class="p">,</span>
-</span><span id="L-811"><a href="#L-811"><span class="linenos">811</span></a> <span class="n">this</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">this</span><span class="p">,</span>
-</span><span id="L-812"><a href="#L-812"><span class="linenos">812</span></a> <span class="n">expr</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expr</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">expr</span><span class="p">,</span>
-</span><span id="L-813"><a href="#L-813"><span class="linenos">813</span></a> <span class="p">)</span>
-</span><span id="L-814"><a href="#L-814"><span class="linenos">814</span></a>
-</span><span id="L-815"><a href="#L-815"><span class="linenos">815</span></a> <span class="k">def</span> <span class="nf">column_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Column</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-816"><a href="#L-816"><span class="linenos">816</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_column&quot;</span><span class="p">):</span>
-</span><span id="L-817"><a href="#L-817"><span class="linenos">817</span></a> <span class="c1"># If a column reference is of the form `dataset.table`.name, we need</span>
-</span><span id="L-818"><a href="#L-818"><span class="linenos">818</span></a> <span class="c1"># to preserve the quoted table path, otherwise the reference breaks</span>
-</span><span id="L-819"><a href="#L-819"><span class="linenos">819</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">[:</span><span class="o">-</span><span class="mi">1</span><span class="p">])</span>
-</span><span id="L-820"><a href="#L-820"><span class="linenos">820</span></a> <span class="n">table_path</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">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
-</span><span id="L-821"><a href="#L-821"><span class="linenos">821</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="n">table_path</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="L-822"><a href="#L-822"><span class="linenos">822</span></a>
-</span><span id="L-823"><a href="#L-823"><span class="linenos">823</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">column_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="L-824"><a href="#L-824"><span class="linenos">824</span></a>
-</span><span id="L-825"><a href="#L-825"><span class="linenos">825</span></a> <span class="k">def</span> <span class="nf">table_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Table</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-826"><a href="#L-826"><span class="linenos">826</span></a> <span class="c1"># Depending on the context, `x.y` may not resolve to the same data source as `x`.`y`, so</span>
-</span><span id="L-827"><a href="#L-827"><span class="linenos">827</span></a> <span class="c1"># we need to make sure the correct quoting is used in each case.</span>
-</span><span id="L-828"><a href="#L-828"><span class="linenos">828</span></a> <span class="c1">#</span>
-</span><span id="L-829"><a href="#L-829"><span class="linenos">829</span></a> <span class="c1"># For example, if there is a CTE x that clashes with a schema name, then the former will</span>
-</span><span id="L-830"><a href="#L-830"><span class="linenos">830</span></a> <span class="c1"># return the table y in that schema, whereas the latter will return the CTE&#39;s y column:</span>
-</span><span id="L-831"><a href="#L-831"><span class="linenos">831</span></a> <span class="c1">#</span>
-</span><span id="L-832"><a href="#L-832"><span class="linenos">832</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x.y` -&gt; cross join</span>
-</span><span id="L-833"><a href="#L-833"><span class="linenos">833</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x`.`y` -&gt; implicit unnest</span>
-</span><span id="L-834"><a href="#L-834"><span class="linenos">834</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_table&quot;</span><span class="p">):</span>
-</span><span id="L-835"><a href="#L-835"><span class="linenos">835</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">)</span>
-</span><span id="L-836"><a href="#L-836"><span class="linenos">836</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
-</span><span id="L-837"><a href="#L-837"><span class="linenos">837</span></a>
-</span><span id="L-838"><a href="#L-838"><span class="linenos">838</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">table_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="L-839"><a href="#L-839"><span class="linenos">839</span></a>
-</span><span id="L-840"><a href="#L-840"><span class="linenos">840</span></a> <span class="k">def</span> <span class="nf">timetostr_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TimeToStr</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-841"><a href="#L-841"><span class="linenos">841</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToDate</span><span class="p">)</span> <span class="k">else</span> <span class="n">expression</span>
-</span><span id="L-842"><a href="#L-842"><span class="linenos">842</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;FORMAT_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">expression</span><span class="p">),</span> <span class="n">this</span><span class="o">.</span><span class="n">this</span><span class="p">)</span>
-</span><span id="L-843"><a href="#L-843"><span class="linenos">843</span></a>
-</span><span id="L-844"><a href="#L-844"><span class="linenos">844</span></a> <span class="k">def</span> <span class="nf">eq_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">EQ</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-845"><a href="#L-845"><span class="linenos">845</span></a> <span class="c1"># Operands of = cannot be NULL in BigQuery</span>
-</span><span id="L-846"><a href="#L-846"><span class="linenos">846</span></a> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">left</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">)</span> <span class="ow">or</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">right</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">):</span>
-</span><span id="L-847"><a href="#L-847"><span class="linenos">847</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Update</span><span class="p">):</span>
-</span><span id="L-848"><a href="#L-848"><span class="linenos">848</span></a> <span class="k">return</span> <span class="s2">&quot;NULL&quot;</span>
-</span><span id="L-849"><a href="#L-849"><span class="linenos">849</span></a>
-</span><span id="L-850"><a href="#L-850"><span class="linenos">850</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">binary</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="s2">&quot;=&quot;</span><span class="p">)</span>
-</span><span id="L-851"><a href="#L-851"><span class="linenos">851</span></a>
-</span><span id="L-852"><a href="#L-852"><span class="linenos">852</span></a> <span class="k">def</span> <span class="nf">attimezone_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">AtTimeZone</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-853"><a href="#L-853"><span class="linenos">853</span></a> <span class="n">parent</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">parent</span>
-</span><span id="L-854"><a href="#L-854"><span class="linenos">854</span></a>
-</span><span id="L-855"><a href="#L-855"><span class="linenos">855</span></a> <span class="c1"># BigQuery allows CAST(.. AS {STRING|TIMESTAMP} [FORMAT &lt;fmt&gt; [AT TIME ZONE &lt;tz&gt;]]).</span>
-</span><span id="L-856"><a href="#L-856"><span class="linenos">856</span></a> <span class="c1"># Only the TIMESTAMP one should use the below conversion, when AT TIME ZONE is included.</span>
-</span><span id="L-857"><a href="#L-857"><span class="linenos">857</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">)</span> <span class="ow">or</span> <span class="ow">not</span> <span class="n">parent</span><span class="o">.</span><span class="n">to</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="s2">&quot;text&quot;</span><span class="p">):</span>
-</span><span id="L-858"><a href="#L-858"><span class="linenos">858</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="L-859"><a href="#L-859"><span class="linenos">859</span></a> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">))</span>
-</span><span id="L-860"><a href="#L-860"><span class="linenos">860</span></a> <span class="p">)</span>
-</span><span id="L-861"><a href="#L-861"><span class="linenos">861</span></a>
-</span><span id="L-862"><a href="#L-862"><span class="linenos">862</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">attimezone_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="L-863"><a href="#L-863"><span class="linenos">863</span></a>
-</span><span id="L-864"><a href="#L-864"><span class="linenos">864</span></a> <span class="k">def</span> <span class="nf">trycast_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TryCast</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-865"><a href="#L-865"><span class="linenos">865</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">cast_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">safe_prefix</span><span class="o">=</span><span class="s2">&quot;SAFE_&quot;</span><span class="p">)</span>
-</span><span id="L-866"><a href="#L-866"><span class="linenos">866</span></a>
-</span><span id="L-867"><a href="#L-867"><span class="linenos">867</span></a> <span class="k">def</span> <span class="nf">bracket_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Bracket</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-868"><a href="#L-868"><span class="linenos">868</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
-</span><span id="L-869"><a href="#L-869"><span class="linenos">869</span></a> <span class="n">expressions</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expressions</span>
-</span><span id="L-870"><a href="#L-870"><span class="linenos">870</span></a>
-</span><span id="L-871"><a href="#L-871"><span class="linenos">871</span></a> <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">expressions</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> <span class="ow">and</span> <span class="n">this</span> <span class="ow">and</span> <span class="n">this</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">STRUCT</span><span class="p">):</span>
-</span><span id="L-872"><a href="#L-872"><span class="linenos">872</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">expressions</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
-</span><span id="L-873"><a href="#L-873"><span class="linenos">873</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">is</span> <span class="kc">None</span><span class="p">:</span>
-</span><span id="L-874"><a href="#L-874"><span class="linenos">874</span></a> <span class="kn">from</span> <span class="nn">sqlglot.optimizer.annotate_types</span> <span class="kn">import</span> <span class="n">annotate_types</span>
-</span><span id="L-875"><a href="#L-875"><span class="linenos">875</span></a>
-</span><span id="L-876"><a href="#L-876"><span class="linenos">876</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">annotate_types</span><span class="p">(</span><span class="n">arg</span><span class="p">)</span>
-</span><span id="L-877"><a href="#L-877"><span class="linenos">877</span></a>
-</span><span id="L-878"><a href="#L-878"><span class="linenos">878</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">and</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span><span class="o">.</span><span class="n">this</span> <span class="ow">in</span> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">TEXT_TYPES</span><span class="p">:</span>
-</span><span id="L-879"><a href="#L-879"><span class="linenos">879</span></a> <span class="c1"># BQ doesn&#39;t support bracket syntax with string values for structs</span>
-</span><span id="L-880"><a href="#L-880"><span class="linenos">880</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="n">arg</span><span class="o">.</span><span class="n">name</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="L-881"><a href="#L-881"><span class="linenos">881</span></a>
-</span><span id="L-882"><a href="#L-882"><span class="linenos">882</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">expressions</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">flat</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
-</span><span id="L-883"><a href="#L-883"><span class="linenos">883</span></a> <span class="n">offset</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;offset&quot;</span><span class="p">)</span>
-</span><span id="L-884"><a href="#L-884"><span class="linenos">884</span></a>
-</span><span id="L-885"><a href="#L-885"><span class="linenos">885</span></a> <span class="k">if</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
-</span><span id="L-886"><a href="#L-886"><span class="linenos">886</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;OFFSET(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
-</span><span id="L-887"><a href="#L-887"><span class="linenos">887</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
-</span><span id="L-888"><a href="#L-888"><span class="linenos">888</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;ORDINAL(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
-</span><span id="L-889"><a href="#L-889"><span class="linenos">889</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
-</span><span id="L-890"><a href="#L-890"><span class="linenos">890</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Unsupported array offset: </span><span class="si">{</span><span class="n">offset</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">)</span>
-</span><span id="L-891"><a href="#L-891"><span class="linenos">891</span></a>
-</span><span id="L-892"><a href="#L-892"><span class="linenos">892</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;safe&quot;</span><span class="p">):</span>
-</span><span id="L-893"><a href="#L-893"><span class="linenos">893</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SAFE_</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="L-894"><a href="#L-894"><span class="linenos">894</span></a>
-</span><span id="L-895"><a href="#L-895"><span class="linenos">895</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">[</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">]&quot;</span>
-</span><span id="L-896"><a href="#L-896"><span class="linenos">896</span></a>
-</span><span id="L-897"><a href="#L-897"><span class="linenos">897</span></a> <span class="k">def</span> <span class="nf">in_unnest_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Unnest</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-898"><a href="#L-898"><span class="linenos">898</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="L-899"><a href="#L-899"><span class="linenos">899</span></a>
-</span><span id="L-900"><a href="#L-900"><span class="linenos">900</span></a> <span class="k">def</span> <span class="nf">except_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Except</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-901"><a href="#L-901"><span class="linenos">901</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
-</span><span id="L-902"><a href="#L-902"><span class="linenos">902</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;EXCEPT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
-</span><span id="L-903"><a href="#L-903"><span class="linenos">903</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;EXCEPT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="L-904"><a href="#L-904"><span class="linenos">904</span></a>
-</span><span id="L-905"><a href="#L-905"><span class="linenos">905</span></a> <span class="k">def</span> <span class="nf">intersect_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Intersect</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-906"><a href="#L-906"><span class="linenos">906</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
-</span><span id="L-907"><a href="#L-907"><span class="linenos">907</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;INTERSECT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
-</span><span id="L-908"><a href="#L-908"><span class="linenos">908</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;INTERSECT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="L-909"><a href="#L-909"><span class="linenos">909</span></a>
-</span><span id="L-910"><a href="#L-910"><span class="linenos">910</span></a> <span class="k">def</span> <span class="nf">with_properties</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">properties</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-911"><a href="#L-911"><span class="linenos">911</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">properties</span><span class="p">(</span><span class="n">properties</span><span class="p">,</span> <span class="n">prefix</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">seg</span><span class="p">(</span><span class="s2">&quot;OPTIONS&quot;</span><span class="p">))</span>
-</span><span id="L-912"><a href="#L-912"><span class="linenos">912</span></a>
-</span><span id="L-913"><a href="#L-913"><span class="linenos">913</span></a> <span class="k">def</span> <span class="nf">version_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Version</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="L-914"><a href="#L-914"><span class="linenos">914</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">:</span>
-</span><span id="L-915"><a href="#L-915"><span class="linenos">915</span></a> <span class="n">expression</span><span class="o">.</span><span class="n">set</span><span class="p">(</span><span class="s2">&quot;this&quot;</span><span class="p">,</span> <span class="s2">&quot;SYSTEM_TIME&quot;</span><span class="p">)</span>
-</span><span id="L-916"><a href="#L-916"><span class="linenos">916</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">version_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="L-573"><a href="#L-573"><span class="linenos">573</span></a> <span class="n">WITH_PROPERTIES_PREFIX</span> <span class="o">=</span> <span class="s2">&quot;OPTIONS&quot;</span>
+</span><span id="L-574"><a href="#L-574"><span class="linenos">574</span></a>
+</span><span id="L-575"><a href="#L-575"><span class="linenos">575</span></a> <span class="n">TRANSFORMS</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="L-576"><a href="#L-576"><span class="linenos">576</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TRANSFORMS</span><span class="p">,</span>
+</span><span id="L-577"><a href="#L-577"><span class="linenos">577</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ApproxDistinct</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;APPROX_COUNT_DISTINCT&quot;</span><span class="p">),</span>
+</span><span id="L-578"><a href="#L-578"><span class="linenos">578</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMax</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MAX_BY&quot;</span><span class="p">),</span>
+</span><span id="L-579"><a href="#L-579"><span class="linenos">579</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMin</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MIN_BY&quot;</span><span class="p">),</span>
+</span><span id="L-580"><a href="#L-580"><span class="linenos">580</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Array</span><span class="p">:</span> <span class="n">inline_array_unless_query</span><span class="p">,</span>
+</span><span id="L-581"><a href="#L-581"><span class="linenos">581</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayContains</span><span class="p">:</span> <span class="n">_array_contains_sql</span><span class="p">,</span>
+</span><span id="L-582"><a href="#L-582"><span class="linenos">582</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayFilter</span><span class="p">:</span> <span class="n">filter_array_using_unnest</span><span class="p">,</span>
+</span><span id="L-583"><a href="#L-583"><span class="linenos">583</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArraySize</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;ARRAY_LENGTH&quot;</span><span class="p">),</span>
+</span><span id="L-584"><a href="#L-584"><span class="linenos">584</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">transforms</span><span class="o">.</span><span class="n">remove_precision_parameterized_types</span><span class="p">]),</span>
+</span><span id="L-585"><a href="#L-585"><span class="linenos">585</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CollateProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
+</span><span id="L-586"><a href="#L-586"><span class="linenos">586</span></a> <span class="sa">f</span><span class="s2">&quot;DEFAULT COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="L-587"><a href="#L-587"><span class="linenos">587</span></a> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;default&quot;</span><span class="p">)</span>
+</span><span id="L-588"><a href="#L-588"><span class="linenos">588</span></a> <span class="k">else</span> <span class="sa">f</span><span class="s2">&quot;COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="L-589"><a href="#L-589"><span class="linenos">589</span></a> <span class="p">),</span>
+</span><span id="L-590"><a href="#L-590"><span class="linenos">590</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Commit</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;COMMIT TRANSACTION&quot;</span><span class="p">,</span>
+</span><span id="L-591"><a href="#L-591"><span class="linenos">591</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CountIf</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;COUNTIF&quot;</span><span class="p">),</span>
+</span><span id="L-592"><a href="#L-592"><span class="linenos">592</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Create</span><span class="p">:</span> <span class="n">_create_sql</span><span class="p">,</span>
+</span><span id="L-593"><a href="#L-593"><span class="linenos">593</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CTE</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">_pushdown_cte_column_names</span><span class="p">]),</span>
+</span><span id="L-594"><a href="#L-594"><span class="linenos">594</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="L-595"><a href="#L-595"><span class="linenos">595</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateDiff</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="L-596"><a href="#L-596"><span class="linenos">596</span></a> <span class="s2">&quot;DATE_DIFF&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span> <span class="n">unit_to_var</span><span class="p">(</span><span class="n">e</span><span class="p">)</span>
+</span><span id="L-597"><a href="#L-597"><span class="linenos">597</span></a> <span class="p">),</span>
+</span><span id="L-598"><a href="#L-598"><span class="linenos">598</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">),</span>
+</span><span id="L-599"><a href="#L-599"><span class="linenos">599</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateStrToDate</span><span class="p">:</span> <span class="n">datestrtodate_sql</span><span class="p">,</span>
+</span><span id="L-600"><a href="#L-600"><span class="linenos">600</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="L-601"><a href="#L-601"><span class="linenos">601</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="L-602"><a href="#L-602"><span class="linenos">602</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="L-603"><a href="#L-603"><span class="linenos">603</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateTrunc</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATE_TRUNC&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;unit&quot;</span><span class="p">)),</span>
+</span><span id="L-604"><a href="#L-604"><span class="linenos">604</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">FromTimeZone</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="L-605"><a href="#L-605"><span class="linenos">605</span></a> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)),</span> <span class="s2">&quot;&#39;UTC&#39;&quot;</span>
+</span><span id="L-606"><a href="#L-606"><span class="linenos">606</span></a> <span class="p">),</span>
+</span><span id="L-607"><a href="#L-607"><span class="linenos">607</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GenerateSeries</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;GENERATE_ARRAY&quot;</span><span class="p">),</span>
+</span><span id="L-608"><a href="#L-608"><span class="linenos">608</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GroupConcat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;STRING_AGG&quot;</span><span class="p">),</span>
+</span><span id="L-609"><a href="#L-609"><span class="linenos">609</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Hex</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;UPPER&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&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">e</span><span class="p">,</span> <span class="s2">&quot;this&quot;</span><span class="p">))),</span>
+</span><span id="L-610"><a href="#L-610"><span class="linenos">610</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">If</span><span class="p">:</span> <span class="n">if_sql</span><span class="p">(</span><span class="n">false_value</span><span class="o">=</span><span class="s2">&quot;NULL&quot;</span><span class="p">),</span>
+</span><span id="L-611"><a href="#L-611"><span class="linenos">611</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ILike</span><span class="p">:</span> <span class="n">no_ilike_sql</span><span class="p">,</span>
+</span><span id="L-612"><a href="#L-612"><span class="linenos">612</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">IntDiv</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DIV&quot;</span><span class="p">),</span>
+</span><span id="L-613"><a href="#L-613"><span class="linenos">613</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONFormat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TO_JSON_STRING&quot;</span><span class="p">),</span>
+</span><span id="L-614"><a href="#L-614"><span class="linenos">614</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Max</span><span class="p">:</span> <span class="n">max_or_greatest</span><span class="p">,</span>
+</span><span id="L-615"><a href="#L-615"><span class="linenos">615</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">)),</span>
+</span><span id="L-616"><a href="#L-616"><span class="linenos">616</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5Digest</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">),</span>
+</span><span id="L-617"><a href="#L-617"><span class="linenos">617</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Min</span><span class="p">:</span> <span class="n">min_or_least</span><span class="p">,</span>
+</span><span id="L-618"><a href="#L-618"><span class="linenos">618</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="sa">f</span><span class="s2">&quot;PARTITION BY </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">,</span>
+</span><span id="L-619"><a href="#L-619"><span class="linenos">619</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpExtract</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="L-620"><a href="#L-620"><span class="linenos">620</span></a> <span class="s2">&quot;REGEXP_EXTRACT&quot;</span><span class="p">,</span>
+</span><span id="L-621"><a href="#L-621"><span class="linenos">621</span></a> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span>
+</span><span id="L-622"><a href="#L-622"><span class="linenos">622</span></a> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span>
+</span><span id="L-623"><a href="#L-623"><span class="linenos">623</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;position&quot;</span><span class="p">),</span>
+</span><span id="L-624"><a href="#L-624"><span class="linenos">624</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;occurrence&quot;</span><span class="p">),</span>
+</span><span id="L-625"><a href="#L-625"><span class="linenos">625</span></a> <span class="p">),</span>
+</span><span id="L-626"><a href="#L-626"><span class="linenos">626</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpReplace</span><span class="p">:</span> <span class="n">regexp_replace_sql</span><span class="p">,</span>
+</span><span id="L-627"><a href="#L-627"><span class="linenos">627</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpLike</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;REGEXP_CONTAINS&quot;</span><span class="p">),</span>
+</span><span id="L-628"><a href="#L-628"><span class="linenos">628</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ReturnsProperty</span><span class="p">:</span> <span class="n">_returnsproperty_sql</span><span class="p">,</span>
+</span><span id="L-629"><a href="#L-629"><span class="linenos">629</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Rollback</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;ROLLBACK TRANSACTION&quot;</span><span class="p">,</span>
+</span><span id="L-630"><a href="#L-630"><span class="linenos">630</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Select</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">(</span>
+</span><span id="L-631"><a href="#L-631"><span class="linenos">631</span></a> <span class="p">[</span>
+</span><span id="L-632"><a href="#L-632"><span class="linenos">632</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">explode_to_unnest</span><span class="p">(),</span>
+</span><span id="L-633"><a href="#L-633"><span class="linenos">633</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">unqualify_unnest</span><span class="p">,</span>
+</span><span id="L-634"><a href="#L-634"><span class="linenos">634</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_distinct_on</span><span class="p">,</span>
+</span><span id="L-635"><a href="#L-635"><span class="linenos">635</span></a> <span class="n">_alias_ordered_group</span><span class="p">,</span>
+</span><span id="L-636"><a href="#L-636"><span class="linenos">636</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_semi_and_anti_joins</span><span class="p">,</span>
+</span><span id="L-637"><a href="#L-637"><span class="linenos">637</span></a> <span class="p">]</span>
+</span><span id="L-638"><a href="#L-638"><span class="linenos">638</span></a> <span class="p">),</span>
+</span><span id="L-639"><a href="#L-639"><span class="linenos">639</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;SHA1&quot;</span><span class="p">),</span>
+</span><span id="L-640"><a href="#L-640"><span class="linenos">640</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA2</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="L-641"><a href="#L-641"><span class="linenos">641</span></a> <span class="s2">&quot;SHA256&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;length&quot;</span><span class="p">)</span> <span class="o">==</span> <span class="s2">&quot;256&quot;</span> <span class="k">else</span> <span class="s2">&quot;SHA512&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span>
+</span><span id="L-642"><a href="#L-642"><span class="linenos">642</span></a> <span class="p">),</span>
+</span><span id="L-643"><a href="#L-643"><span class="linenos">643</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StabilityProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
+</span><span id="L-644"><a href="#L-644"><span class="linenos">644</span></a> <span class="s2">&quot;DETERMINISTIC&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;IMMUTABLE&quot;</span> <span class="k">else</span> <span class="s2">&quot;NOT DETERMINISTIC&quot;</span>
+</span><span id="L-645"><a href="#L-645"><span class="linenos">645</span></a> <span class="p">),</span>
+</span><span id="L-646"><a href="#L-646"><span class="linenos">646</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToDate</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;PARSE_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">),</span>
+</span><span id="L-647"><a href="#L-647"><span class="linenos">647</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToTime</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="L-648"><a href="#L-648"><span class="linenos">648</span></a> <span class="s2">&quot;PARSE_TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)</span>
+</span><span id="L-649"><a href="#L-649"><span class="linenos">649</span></a> <span class="p">),</span>
+</span><span id="L-650"><a href="#L-650"><span class="linenos">650</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="L-651"><a href="#L-651"><span class="linenos">651</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
+</span><span id="L-652"><a href="#L-652"><span class="linenos">652</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="L-653"><a href="#L-653"><span class="linenos">653</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="L-654"><a href="#L-654"><span class="linenos">654</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampDiff</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP_DIFF&quot;</span><span class="p">),</span>
+</span><span id="L-655"><a href="#L-655"><span class="linenos">655</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="L-656"><a href="#L-656"><span class="linenos">656</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeStrToTime</span><span class="p">:</span> <span class="n">timestrtotime_sql</span><span class="p">,</span>
+</span><span id="L-657"><a href="#L-657"><span class="linenos">657</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Transaction</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;BEGIN TRANSACTION&quot;</span><span class="p">,</span>
+</span><span id="L-658"><a href="#L-658"><span class="linenos">658</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Trim</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TRIM&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">),</span>
+</span><span id="L-659"><a href="#L-659"><span class="linenos">659</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsAdd</span><span class="p">:</span> <span class="n">_ts_or_ds_add_sql</span><span class="p">,</span>
+</span><span id="L-660"><a href="#L-660"><span class="linenos">660</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsDiff</span><span class="p">:</span> <span class="n">_ts_or_ds_diff_sql</span><span class="p">,</span>
+</span><span id="L-661"><a href="#L-661"><span class="linenos">661</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToTime</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
+</span><span id="L-662"><a href="#L-662"><span class="linenos">662</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Unhex</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;FROM_HEX&quot;</span><span class="p">),</span>
+</span><span id="L-663"><a href="#L-663"><span class="linenos">663</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixDate</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;UNIX_DATE&quot;</span><span class="p">),</span>
+</span><span id="L-664"><a href="#L-664"><span class="linenos">664</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixToTime</span><span class="p">:</span> <span class="n">_unix_to_time_sql</span><span class="p">,</span>
+</span><span id="L-665"><a href="#L-665"><span class="linenos">665</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Values</span><span class="p">:</span> <span class="n">_derived_table_values_to_unnest</span><span class="p">,</span>
+</span><span id="L-666"><a href="#L-666"><span class="linenos">666</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VariancePop</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;VAR_POP&quot;</span><span class="p">),</span>
+</span><span id="L-667"><a href="#L-667"><span class="linenos">667</span></a> <span class="p">}</span>
+</span><span id="L-668"><a href="#L-668"><span class="linenos">668</span></a>
+</span><span id="L-669"><a href="#L-669"><span class="linenos">669</span></a> <span class="n">SUPPORTED_JSON_PATH_PARTS</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="L-670"><a href="#L-670"><span class="linenos">670</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathKey</span><span class="p">,</span>
+</span><span id="L-671"><a href="#L-671"><span class="linenos">671</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathRoot</span><span class="p">,</span>
+</span><span id="L-672"><a href="#L-672"><span class="linenos">672</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathSubscript</span><span class="p">,</span>
+</span><span id="L-673"><a href="#L-673"><span class="linenos">673</span></a> <span class="p">}</span>
+</span><span id="L-674"><a href="#L-674"><span class="linenos">674</span></a>
+</span><span id="L-675"><a href="#L-675"><span class="linenos">675</span></a> <span class="n">TYPE_MAPPING</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="L-676"><a href="#L-676"><span class="linenos">676</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TYPE_MAPPING</span><span class="p">,</span>
+</span><span id="L-677"><a href="#L-677"><span class="linenos">677</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGDECIMAL</span><span class="p">:</span> <span class="s2">&quot;BIGNUMERIC&quot;</span><span class="p">,</span>
+</span><span id="L-678"><a href="#L-678"><span class="linenos">678</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="L-679"><a href="#L-679"><span class="linenos">679</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
+</span><span id="L-680"><a href="#L-680"><span class="linenos">680</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BOOLEAN</span><span class="p">:</span> <span class="s2">&quot;BOOL&quot;</span><span class="p">,</span>
+</span><span id="L-681"><a href="#L-681"><span class="linenos">681</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">CHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="L-682"><a href="#L-682"><span class="linenos">682</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DECIMAL</span><span class="p">:</span> <span class="s2">&quot;NUMERIC&quot;</span><span class="p">,</span>
+</span><span id="L-683"><a href="#L-683"><span class="linenos">683</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DOUBLE</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
+</span><span id="L-684"><a href="#L-684"><span class="linenos">684</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">FLOAT</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
+</span><span id="L-685"><a href="#L-685"><span class="linenos">685</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">INT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="L-686"><a href="#L-686"><span class="linenos">686</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="L-687"><a href="#L-687"><span class="linenos">687</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NVARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="L-688"><a href="#L-688"><span class="linenos">688</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">SMALLINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="L-689"><a href="#L-689"><span class="linenos">689</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TEXT</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="L-690"><a href="#L-690"><span class="linenos">690</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMP</span><span class="p">:</span> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span>
+</span><span id="L-691"><a href="#L-691"><span class="linenos">691</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
+</span><span id="L-692"><a href="#L-692"><span class="linenos">692</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPLTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
+</span><span id="L-693"><a href="#L-693"><span class="linenos">693</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TINYINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="L-694"><a href="#L-694"><span class="linenos">694</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARBINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
+</span><span id="L-695"><a href="#L-695"><span class="linenos">695</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">ROWVERSION</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
+</span><span id="L-696"><a href="#L-696"><span class="linenos">696</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="L-697"><a href="#L-697"><span class="linenos">697</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARIANT</span><span class="p">:</span> <span class="s2">&quot;ANY TYPE&quot;</span><span class="p">,</span>
+</span><span id="L-698"><a href="#L-698"><span class="linenos">698</span></a> <span class="p">}</span>
+</span><span id="L-699"><a href="#L-699"><span class="linenos">699</span></a>
+</span><span id="L-700"><a href="#L-700"><span class="linenos">700</span></a> <span class="n">PROPERTIES_LOCATION</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="L-701"><a href="#L-701"><span class="linenos">701</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">PROPERTIES_LOCATION</span><span class="p">,</span>
+</span><span id="L-702"><a href="#L-702"><span class="linenos">702</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">POST_SCHEMA</span><span class="p">,</span>
+</span><span id="L-703"><a href="#L-703"><span class="linenos">703</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VolatileProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">UNSUPPORTED</span><span class="p">,</span>
+</span><span id="L-704"><a href="#L-704"><span class="linenos">704</span></a> <span class="p">}</span>
+</span><span id="L-705"><a href="#L-705"><span class="linenos">705</span></a>
+</span><span id="L-706"><a href="#L-706"><span class="linenos">706</span></a> <span class="c1"># from: https://cloud.google.com/bigquery/docs/reference/standard-sql/lexical#reserved_keywords</span>
+</span><span id="L-707"><a href="#L-707"><span class="linenos">707</span></a> <span class="n">RESERVED_KEYWORDS</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="L-708"><a href="#L-708"><span class="linenos">708</span></a> <span class="o">*</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">RESERVED_KEYWORDS</span><span class="p">,</span>
+</span><span id="L-709"><a href="#L-709"><span class="linenos">709</span></a> <span class="s2">&quot;all&quot;</span><span class="p">,</span>
+</span><span id="L-710"><a href="#L-710"><span class="linenos">710</span></a> <span class="s2">&quot;and&quot;</span><span class="p">,</span>
+</span><span id="L-711"><a href="#L-711"><span class="linenos">711</span></a> <span class="s2">&quot;any&quot;</span><span class="p">,</span>
+</span><span id="L-712"><a href="#L-712"><span class="linenos">712</span></a> <span class="s2">&quot;array&quot;</span><span class="p">,</span>
+</span><span id="L-713"><a href="#L-713"><span class="linenos">713</span></a> <span class="s2">&quot;as&quot;</span><span class="p">,</span>
+</span><span id="L-714"><a href="#L-714"><span class="linenos">714</span></a> <span class="s2">&quot;asc&quot;</span><span class="p">,</span>
+</span><span id="L-715"><a href="#L-715"><span class="linenos">715</span></a> <span class="s2">&quot;assert_rows_modified&quot;</span><span class="p">,</span>
+</span><span id="L-716"><a href="#L-716"><span class="linenos">716</span></a> <span class="s2">&quot;at&quot;</span><span class="p">,</span>
+</span><span id="L-717"><a href="#L-717"><span class="linenos">717</span></a> <span class="s2">&quot;between&quot;</span><span class="p">,</span>
+</span><span id="L-718"><a href="#L-718"><span class="linenos">718</span></a> <span class="s2">&quot;by&quot;</span><span class="p">,</span>
+</span><span id="L-719"><a href="#L-719"><span class="linenos">719</span></a> <span class="s2">&quot;case&quot;</span><span class="p">,</span>
+</span><span id="L-720"><a href="#L-720"><span class="linenos">720</span></a> <span class="s2">&quot;cast&quot;</span><span class="p">,</span>
+</span><span id="L-721"><a href="#L-721"><span class="linenos">721</span></a> <span class="s2">&quot;collate&quot;</span><span class="p">,</span>
+</span><span id="L-722"><a href="#L-722"><span class="linenos">722</span></a> <span class="s2">&quot;contains&quot;</span><span class="p">,</span>
+</span><span id="L-723"><a href="#L-723"><span class="linenos">723</span></a> <span class="s2">&quot;create&quot;</span><span class="p">,</span>
+</span><span id="L-724"><a href="#L-724"><span class="linenos">724</span></a> <span class="s2">&quot;cross&quot;</span><span class="p">,</span>
+</span><span id="L-725"><a href="#L-725"><span class="linenos">725</span></a> <span class="s2">&quot;cube&quot;</span><span class="p">,</span>
+</span><span id="L-726"><a href="#L-726"><span class="linenos">726</span></a> <span class="s2">&quot;current&quot;</span><span class="p">,</span>
+</span><span id="L-727"><a href="#L-727"><span class="linenos">727</span></a> <span class="s2">&quot;default&quot;</span><span class="p">,</span>
+</span><span id="L-728"><a href="#L-728"><span class="linenos">728</span></a> <span class="s2">&quot;define&quot;</span><span class="p">,</span>
+</span><span id="L-729"><a href="#L-729"><span class="linenos">729</span></a> <span class="s2">&quot;desc&quot;</span><span class="p">,</span>
+</span><span id="L-730"><a href="#L-730"><span class="linenos">730</span></a> <span class="s2">&quot;distinct&quot;</span><span class="p">,</span>
+</span><span id="L-731"><a href="#L-731"><span class="linenos">731</span></a> <span class="s2">&quot;else&quot;</span><span class="p">,</span>
+</span><span id="L-732"><a href="#L-732"><span class="linenos">732</span></a> <span class="s2">&quot;end&quot;</span><span class="p">,</span>
+</span><span id="L-733"><a href="#L-733"><span class="linenos">733</span></a> <span class="s2">&quot;enum&quot;</span><span class="p">,</span>
+</span><span id="L-734"><a href="#L-734"><span class="linenos">734</span></a> <span class="s2">&quot;escape&quot;</span><span class="p">,</span>
+</span><span id="L-735"><a href="#L-735"><span class="linenos">735</span></a> <span class="s2">&quot;except&quot;</span><span class="p">,</span>
+</span><span id="L-736"><a href="#L-736"><span class="linenos">736</span></a> <span class="s2">&quot;exclude&quot;</span><span class="p">,</span>
+</span><span id="L-737"><a href="#L-737"><span class="linenos">737</span></a> <span class="s2">&quot;exists&quot;</span><span class="p">,</span>
+</span><span id="L-738"><a href="#L-738"><span class="linenos">738</span></a> <span class="s2">&quot;extract&quot;</span><span class="p">,</span>
+</span><span id="L-739"><a href="#L-739"><span class="linenos">739</span></a> <span class="s2">&quot;false&quot;</span><span class="p">,</span>
+</span><span id="L-740"><a href="#L-740"><span class="linenos">740</span></a> <span class="s2">&quot;fetch&quot;</span><span class="p">,</span>
+</span><span id="L-741"><a href="#L-741"><span class="linenos">741</span></a> <span class="s2">&quot;following&quot;</span><span class="p">,</span>
+</span><span id="L-742"><a href="#L-742"><span class="linenos">742</span></a> <span class="s2">&quot;for&quot;</span><span class="p">,</span>
+</span><span id="L-743"><a href="#L-743"><span class="linenos">743</span></a> <span class="s2">&quot;from&quot;</span><span class="p">,</span>
+</span><span id="L-744"><a href="#L-744"><span class="linenos">744</span></a> <span class="s2">&quot;full&quot;</span><span class="p">,</span>
+</span><span id="L-745"><a href="#L-745"><span class="linenos">745</span></a> <span class="s2">&quot;group&quot;</span><span class="p">,</span>
+</span><span id="L-746"><a href="#L-746"><span class="linenos">746</span></a> <span class="s2">&quot;grouping&quot;</span><span class="p">,</span>
+</span><span id="L-747"><a href="#L-747"><span class="linenos">747</span></a> <span class="s2">&quot;groups&quot;</span><span class="p">,</span>
+</span><span id="L-748"><a href="#L-748"><span class="linenos">748</span></a> <span class="s2">&quot;hash&quot;</span><span class="p">,</span>
+</span><span id="L-749"><a href="#L-749"><span class="linenos">749</span></a> <span class="s2">&quot;having&quot;</span><span class="p">,</span>
+</span><span id="L-750"><a href="#L-750"><span class="linenos">750</span></a> <span class="s2">&quot;if&quot;</span><span class="p">,</span>
+</span><span id="L-751"><a href="#L-751"><span class="linenos">751</span></a> <span class="s2">&quot;ignore&quot;</span><span class="p">,</span>
+</span><span id="L-752"><a href="#L-752"><span class="linenos">752</span></a> <span class="s2">&quot;in&quot;</span><span class="p">,</span>
+</span><span id="L-753"><a href="#L-753"><span class="linenos">753</span></a> <span class="s2">&quot;inner&quot;</span><span class="p">,</span>
+</span><span id="L-754"><a href="#L-754"><span class="linenos">754</span></a> <span class="s2">&quot;intersect&quot;</span><span class="p">,</span>
+</span><span id="L-755"><a href="#L-755"><span class="linenos">755</span></a> <span class="s2">&quot;interval&quot;</span><span class="p">,</span>
+</span><span id="L-756"><a href="#L-756"><span class="linenos">756</span></a> <span class="s2">&quot;into&quot;</span><span class="p">,</span>
+</span><span id="L-757"><a href="#L-757"><span class="linenos">757</span></a> <span class="s2">&quot;is&quot;</span><span class="p">,</span>
+</span><span id="L-758"><a href="#L-758"><span class="linenos">758</span></a> <span class="s2">&quot;join&quot;</span><span class="p">,</span>
+</span><span id="L-759"><a href="#L-759"><span class="linenos">759</span></a> <span class="s2">&quot;lateral&quot;</span><span class="p">,</span>
+</span><span id="L-760"><a href="#L-760"><span class="linenos">760</span></a> <span class="s2">&quot;left&quot;</span><span class="p">,</span>
+</span><span id="L-761"><a href="#L-761"><span class="linenos">761</span></a> <span class="s2">&quot;like&quot;</span><span class="p">,</span>
+</span><span id="L-762"><a href="#L-762"><span class="linenos">762</span></a> <span class="s2">&quot;limit&quot;</span><span class="p">,</span>
+</span><span id="L-763"><a href="#L-763"><span class="linenos">763</span></a> <span class="s2">&quot;lookup&quot;</span><span class="p">,</span>
+</span><span id="L-764"><a href="#L-764"><span class="linenos">764</span></a> <span class="s2">&quot;merge&quot;</span><span class="p">,</span>
+</span><span id="L-765"><a href="#L-765"><span class="linenos">765</span></a> <span class="s2">&quot;natural&quot;</span><span class="p">,</span>
+</span><span id="L-766"><a href="#L-766"><span class="linenos">766</span></a> <span class="s2">&quot;new&quot;</span><span class="p">,</span>
+</span><span id="L-767"><a href="#L-767"><span class="linenos">767</span></a> <span class="s2">&quot;no&quot;</span><span class="p">,</span>
+</span><span id="L-768"><a href="#L-768"><span class="linenos">768</span></a> <span class="s2">&quot;not&quot;</span><span class="p">,</span>
+</span><span id="L-769"><a href="#L-769"><span class="linenos">769</span></a> <span class="s2">&quot;null&quot;</span><span class="p">,</span>
+</span><span id="L-770"><a href="#L-770"><span class="linenos">770</span></a> <span class="s2">&quot;nulls&quot;</span><span class="p">,</span>
+</span><span id="L-771"><a href="#L-771"><span class="linenos">771</span></a> <span class="s2">&quot;of&quot;</span><span class="p">,</span>
+</span><span id="L-772"><a href="#L-772"><span class="linenos">772</span></a> <span class="s2">&quot;on&quot;</span><span class="p">,</span>
+</span><span id="L-773"><a href="#L-773"><span class="linenos">773</span></a> <span class="s2">&quot;or&quot;</span><span class="p">,</span>
+</span><span id="L-774"><a href="#L-774"><span class="linenos">774</span></a> <span class="s2">&quot;order&quot;</span><span class="p">,</span>
+</span><span id="L-775"><a href="#L-775"><span class="linenos">775</span></a> <span class="s2">&quot;outer&quot;</span><span class="p">,</span>
+</span><span id="L-776"><a href="#L-776"><span class="linenos">776</span></a> <span class="s2">&quot;over&quot;</span><span class="p">,</span>
+</span><span id="L-777"><a href="#L-777"><span class="linenos">777</span></a> <span class="s2">&quot;partition&quot;</span><span class="p">,</span>
+</span><span id="L-778"><a href="#L-778"><span class="linenos">778</span></a> <span class="s2">&quot;preceding&quot;</span><span class="p">,</span>
+</span><span id="L-779"><a href="#L-779"><span class="linenos">779</span></a> <span class="s2">&quot;proto&quot;</span><span class="p">,</span>
+</span><span id="L-780"><a href="#L-780"><span class="linenos">780</span></a> <span class="s2">&quot;qualify&quot;</span><span class="p">,</span>
+</span><span id="L-781"><a href="#L-781"><span class="linenos">781</span></a> <span class="s2">&quot;range&quot;</span><span class="p">,</span>
+</span><span id="L-782"><a href="#L-782"><span class="linenos">782</span></a> <span class="s2">&quot;recursive&quot;</span><span class="p">,</span>
+</span><span id="L-783"><a href="#L-783"><span class="linenos">783</span></a> <span class="s2">&quot;respect&quot;</span><span class="p">,</span>
+</span><span id="L-784"><a href="#L-784"><span class="linenos">784</span></a> <span class="s2">&quot;right&quot;</span><span class="p">,</span>
+</span><span id="L-785"><a href="#L-785"><span class="linenos">785</span></a> <span class="s2">&quot;rollup&quot;</span><span class="p">,</span>
+</span><span id="L-786"><a href="#L-786"><span class="linenos">786</span></a> <span class="s2">&quot;rows&quot;</span><span class="p">,</span>
+</span><span id="L-787"><a href="#L-787"><span class="linenos">787</span></a> <span class="s2">&quot;select&quot;</span><span class="p">,</span>
+</span><span id="L-788"><a href="#L-788"><span class="linenos">788</span></a> <span class="s2">&quot;set&quot;</span><span class="p">,</span>
+</span><span id="L-789"><a href="#L-789"><span class="linenos">789</span></a> <span class="s2">&quot;some&quot;</span><span class="p">,</span>
+</span><span id="L-790"><a href="#L-790"><span class="linenos">790</span></a> <span class="s2">&quot;struct&quot;</span><span class="p">,</span>
+</span><span id="L-791"><a href="#L-791"><span class="linenos">791</span></a> <span class="s2">&quot;tablesample&quot;</span><span class="p">,</span>
+</span><span id="L-792"><a href="#L-792"><span class="linenos">792</span></a> <span class="s2">&quot;then&quot;</span><span class="p">,</span>
+</span><span id="L-793"><a href="#L-793"><span class="linenos">793</span></a> <span class="s2">&quot;to&quot;</span><span class="p">,</span>
+</span><span id="L-794"><a href="#L-794"><span class="linenos">794</span></a> <span class="s2">&quot;treat&quot;</span><span class="p">,</span>
+</span><span id="L-795"><a href="#L-795"><span class="linenos">795</span></a> <span class="s2">&quot;true&quot;</span><span class="p">,</span>
+</span><span id="L-796"><a href="#L-796"><span class="linenos">796</span></a> <span class="s2">&quot;unbounded&quot;</span><span class="p">,</span>
+</span><span id="L-797"><a href="#L-797"><span class="linenos">797</span></a> <span class="s2">&quot;union&quot;</span><span class="p">,</span>
+</span><span id="L-798"><a href="#L-798"><span class="linenos">798</span></a> <span class="s2">&quot;unnest&quot;</span><span class="p">,</span>
+</span><span id="L-799"><a href="#L-799"><span class="linenos">799</span></a> <span class="s2">&quot;using&quot;</span><span class="p">,</span>
+</span><span id="L-800"><a href="#L-800"><span class="linenos">800</span></a> <span class="s2">&quot;when&quot;</span><span class="p">,</span>
+</span><span id="L-801"><a href="#L-801"><span class="linenos">801</span></a> <span class="s2">&quot;where&quot;</span><span class="p">,</span>
+</span><span id="L-802"><a href="#L-802"><span class="linenos">802</span></a> <span class="s2">&quot;window&quot;</span><span class="p">,</span>
+</span><span id="L-803"><a href="#L-803"><span class="linenos">803</span></a> <span class="s2">&quot;with&quot;</span><span class="p">,</span>
+</span><span id="L-804"><a href="#L-804"><span class="linenos">804</span></a> <span class="s2">&quot;within&quot;</span><span class="p">,</span>
+</span><span id="L-805"><a href="#L-805"><span class="linenos">805</span></a> <span class="p">}</span>
+</span><span id="L-806"><a href="#L-806"><span class="linenos">806</span></a>
+</span><span id="L-807"><a href="#L-807"><span class="linenos">807</span></a> <span class="k">def</span> <span class="nf">mod_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Mod</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-808"><a href="#L-808"><span class="linenos">808</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
+</span><span id="L-809"><a href="#L-809"><span class="linenos">809</span></a> <span class="n">expr</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expression</span>
+</span><span id="L-810"><a href="#L-810"><span class="linenos">810</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="L-811"><a href="#L-811"><span class="linenos">811</span></a> <span class="s2">&quot;MOD&quot;</span><span class="p">,</span>
+</span><span id="L-812"><a href="#L-812"><span class="linenos">812</span></a> <span class="n">this</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">this</span><span class="p">,</span>
+</span><span id="L-813"><a href="#L-813"><span class="linenos">813</span></a> <span class="n">expr</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expr</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">expr</span><span class="p">,</span>
+</span><span id="L-814"><a href="#L-814"><span class="linenos">814</span></a> <span class="p">)</span>
+</span><span id="L-815"><a href="#L-815"><span class="linenos">815</span></a>
+</span><span id="L-816"><a href="#L-816"><span class="linenos">816</span></a> <span class="k">def</span> <span class="nf">column_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Column</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-817"><a href="#L-817"><span class="linenos">817</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_column&quot;</span><span class="p">):</span>
+</span><span id="L-818"><a href="#L-818"><span class="linenos">818</span></a> <span class="c1"># If a column reference is of the form `dataset.table`.name, we need</span>
+</span><span id="L-819"><a href="#L-819"><span class="linenos">819</span></a> <span class="c1"># to preserve the quoted table path, otherwise the reference breaks</span>
+</span><span id="L-820"><a href="#L-820"><span class="linenos">820</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">[:</span><span class="o">-</span><span class="mi">1</span><span class="p">])</span>
+</span><span id="L-821"><a href="#L-821"><span class="linenos">821</span></a> <span class="n">table_path</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">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+</span><span id="L-822"><a href="#L-822"><span class="linenos">822</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="n">table_path</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="L-823"><a href="#L-823"><span class="linenos">823</span></a>
+</span><span id="L-824"><a href="#L-824"><span class="linenos">824</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">column_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="L-825"><a href="#L-825"><span class="linenos">825</span></a>
+</span><span id="L-826"><a href="#L-826"><span class="linenos">826</span></a> <span class="k">def</span> <span class="nf">table_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Table</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-827"><a href="#L-827"><span class="linenos">827</span></a> <span class="c1"># Depending on the context, `x.y` may not resolve to the same data source as `x`.`y`, so</span>
+</span><span id="L-828"><a href="#L-828"><span class="linenos">828</span></a> <span class="c1"># we need to make sure the correct quoting is used in each case.</span>
+</span><span id="L-829"><a href="#L-829"><span class="linenos">829</span></a> <span class="c1">#</span>
+</span><span id="L-830"><a href="#L-830"><span class="linenos">830</span></a> <span class="c1"># For example, if there is a CTE x that clashes with a schema name, then the former will</span>
+</span><span id="L-831"><a href="#L-831"><span class="linenos">831</span></a> <span class="c1"># return the table y in that schema, whereas the latter will return the CTE&#39;s y column:</span>
+</span><span id="L-832"><a href="#L-832"><span class="linenos">832</span></a> <span class="c1">#</span>
+</span><span id="L-833"><a href="#L-833"><span class="linenos">833</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x.y` -&gt; cross join</span>
+</span><span id="L-834"><a href="#L-834"><span class="linenos">834</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x`.`y` -&gt; implicit unnest</span>
+</span><span id="L-835"><a href="#L-835"><span class="linenos">835</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_table&quot;</span><span class="p">):</span>
+</span><span id="L-836"><a href="#L-836"><span class="linenos">836</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">)</span>
+</span><span id="L-837"><a href="#L-837"><span class="linenos">837</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+</span><span id="L-838"><a href="#L-838"><span class="linenos">838</span></a>
+</span><span id="L-839"><a href="#L-839"><span class="linenos">839</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">table_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="L-840"><a href="#L-840"><span class="linenos">840</span></a>
+</span><span id="L-841"><a href="#L-841"><span class="linenos">841</span></a> <span class="k">def</span> <span class="nf">timetostr_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TimeToStr</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-842"><a href="#L-842"><span class="linenos">842</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToDate</span><span class="p">)</span> <span class="k">else</span> <span class="n">expression</span>
+</span><span id="L-843"><a href="#L-843"><span class="linenos">843</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;FORMAT_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">expression</span><span class="p">),</span> <span class="n">this</span><span class="o">.</span><span class="n">this</span><span class="p">)</span>
+</span><span id="L-844"><a href="#L-844"><span class="linenos">844</span></a>
+</span><span id="L-845"><a href="#L-845"><span class="linenos">845</span></a> <span class="k">def</span> <span class="nf">eq_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">EQ</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-846"><a href="#L-846"><span class="linenos">846</span></a> <span class="c1"># Operands of = cannot be NULL in BigQuery</span>
+</span><span id="L-847"><a href="#L-847"><span class="linenos">847</span></a> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">left</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">)</span> <span class="ow">or</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">right</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">):</span>
+</span><span id="L-848"><a href="#L-848"><span class="linenos">848</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Update</span><span class="p">):</span>
+</span><span id="L-849"><a href="#L-849"><span class="linenos">849</span></a> <span class="k">return</span> <span class="s2">&quot;NULL&quot;</span>
+</span><span id="L-850"><a href="#L-850"><span class="linenos">850</span></a>
+</span><span id="L-851"><a href="#L-851"><span class="linenos">851</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">binary</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="s2">&quot;=&quot;</span><span class="p">)</span>
+</span><span id="L-852"><a href="#L-852"><span class="linenos">852</span></a>
+</span><span id="L-853"><a href="#L-853"><span class="linenos">853</span></a> <span class="k">def</span> <span class="nf">attimezone_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">AtTimeZone</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-854"><a href="#L-854"><span class="linenos">854</span></a> <span class="n">parent</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">parent</span>
+</span><span id="L-855"><a href="#L-855"><span class="linenos">855</span></a>
+</span><span id="L-856"><a href="#L-856"><span class="linenos">856</span></a> <span class="c1"># BigQuery allows CAST(.. AS {STRING|TIMESTAMP} [FORMAT &lt;fmt&gt; [AT TIME ZONE &lt;tz&gt;]]).</span>
+</span><span id="L-857"><a href="#L-857"><span class="linenos">857</span></a> <span class="c1"># Only the TIMESTAMP one should use the below conversion, when AT TIME ZONE is included.</span>
+</span><span id="L-858"><a href="#L-858"><span class="linenos">858</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">)</span> <span class="ow">or</span> <span class="ow">not</span> <span class="n">parent</span><span class="o">.</span><span class="n">to</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="s2">&quot;text&quot;</span><span class="p">):</span>
+</span><span id="L-859"><a href="#L-859"><span class="linenos">859</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="L-860"><a href="#L-860"><span class="linenos">860</span></a> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">))</span>
+</span><span id="L-861"><a href="#L-861"><span class="linenos">861</span></a> <span class="p">)</span>
+</span><span id="L-862"><a href="#L-862"><span class="linenos">862</span></a>
+</span><span id="L-863"><a href="#L-863"><span class="linenos">863</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">attimezone_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="L-864"><a href="#L-864"><span class="linenos">864</span></a>
+</span><span id="L-865"><a href="#L-865"><span class="linenos">865</span></a> <span class="k">def</span> <span class="nf">trycast_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TryCast</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-866"><a href="#L-866"><span class="linenos">866</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">cast_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">safe_prefix</span><span class="o">=</span><span class="s2">&quot;SAFE_&quot;</span><span class="p">)</span>
+</span><span id="L-867"><a href="#L-867"><span class="linenos">867</span></a>
+</span><span id="L-868"><a href="#L-868"><span class="linenos">868</span></a> <span class="k">def</span> <span class="nf">bracket_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Bracket</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-869"><a href="#L-869"><span class="linenos">869</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
+</span><span id="L-870"><a href="#L-870"><span class="linenos">870</span></a> <span class="n">expressions</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expressions</span>
+</span><span id="L-871"><a href="#L-871"><span class="linenos">871</span></a>
+</span><span id="L-872"><a href="#L-872"><span class="linenos">872</span></a> <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">expressions</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> <span class="ow">and</span> <span class="n">this</span> <span class="ow">and</span> <span class="n">this</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">STRUCT</span><span class="p">):</span>
+</span><span id="L-873"><a href="#L-873"><span class="linenos">873</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">expressions</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
+</span><span id="L-874"><a href="#L-874"><span class="linenos">874</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">is</span> <span class="kc">None</span><span class="p">:</span>
+</span><span id="L-875"><a href="#L-875"><span class="linenos">875</span></a> <span class="kn">from</span> <span class="nn">sqlglot.optimizer.annotate_types</span> <span class="kn">import</span> <span class="n">annotate_types</span>
+</span><span id="L-876"><a href="#L-876"><span class="linenos">876</span></a>
+</span><span id="L-877"><a href="#L-877"><span class="linenos">877</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">annotate_types</span><span class="p">(</span><span class="n">arg</span><span class="p">)</span>
+</span><span id="L-878"><a href="#L-878"><span class="linenos">878</span></a>
+</span><span id="L-879"><a href="#L-879"><span class="linenos">879</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">and</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span><span class="o">.</span><span class="n">this</span> <span class="ow">in</span> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">TEXT_TYPES</span><span class="p">:</span>
+</span><span id="L-880"><a href="#L-880"><span class="linenos">880</span></a> <span class="c1"># BQ doesn&#39;t support bracket syntax with string values for structs</span>
+</span><span id="L-881"><a href="#L-881"><span class="linenos">881</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="n">arg</span><span class="o">.</span><span class="n">name</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="L-882"><a href="#L-882"><span class="linenos">882</span></a>
+</span><span id="L-883"><a href="#L-883"><span class="linenos">883</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">expressions</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">flat</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
+</span><span id="L-884"><a href="#L-884"><span class="linenos">884</span></a> <span class="n">offset</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;offset&quot;</span><span class="p">)</span>
+</span><span id="L-885"><a href="#L-885"><span class="linenos">885</span></a>
+</span><span id="L-886"><a href="#L-886"><span class="linenos">886</span></a> <span class="k">if</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
+</span><span id="L-887"><a href="#L-887"><span class="linenos">887</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;OFFSET(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
+</span><span id="L-888"><a href="#L-888"><span class="linenos">888</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
+</span><span id="L-889"><a href="#L-889"><span class="linenos">889</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;ORDINAL(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
+</span><span id="L-890"><a href="#L-890"><span class="linenos">890</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
+</span><span id="L-891"><a href="#L-891"><span class="linenos">891</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Unsupported array offset: </span><span class="si">{</span><span class="n">offset</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">)</span>
+</span><span id="L-892"><a href="#L-892"><span class="linenos">892</span></a>
+</span><span id="L-893"><a href="#L-893"><span class="linenos">893</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;safe&quot;</span><span class="p">):</span>
+</span><span id="L-894"><a href="#L-894"><span class="linenos">894</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SAFE_</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="L-895"><a href="#L-895"><span class="linenos">895</span></a>
+</span><span id="L-896"><a href="#L-896"><span class="linenos">896</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">[</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">]&quot;</span>
+</span><span id="L-897"><a href="#L-897"><span class="linenos">897</span></a>
+</span><span id="L-898"><a href="#L-898"><span class="linenos">898</span></a> <span class="k">def</span> <span class="nf">in_unnest_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Unnest</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-899"><a href="#L-899"><span class="linenos">899</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="L-900"><a href="#L-900"><span class="linenos">900</span></a>
+</span><span id="L-901"><a href="#L-901"><span class="linenos">901</span></a> <span class="k">def</span> <span class="nf">except_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Except</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-902"><a href="#L-902"><span class="linenos">902</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
+</span><span id="L-903"><a href="#L-903"><span class="linenos">903</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;EXCEPT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
+</span><span id="L-904"><a href="#L-904"><span class="linenos">904</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;EXCEPT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="L-905"><a href="#L-905"><span class="linenos">905</span></a>
+</span><span id="L-906"><a href="#L-906"><span class="linenos">906</span></a> <span class="k">def</span> <span class="nf">intersect_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Intersect</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-907"><a href="#L-907"><span class="linenos">907</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
+</span><span id="L-908"><a href="#L-908"><span class="linenos">908</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;INTERSECT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
+</span><span id="L-909"><a href="#L-909"><span class="linenos">909</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;INTERSECT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="L-910"><a href="#L-910"><span class="linenos">910</span></a>
+</span><span id="L-911"><a href="#L-911"><span class="linenos">911</span></a> <span class="k">def</span> <span class="nf">version_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Version</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="L-912"><a href="#L-912"><span class="linenos">912</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">:</span>
+</span><span id="L-913"><a href="#L-913"><span class="linenos">913</span></a> <span class="n">expression</span><span class="o">.</span><span class="n">set</span><span class="p">(</span><span class="s2">&quot;this&quot;</span><span class="p">,</span> <span class="s2">&quot;SYSTEM_TIME&quot;</span><span class="p">)</span>
+</span><span id="L-914"><a href="#L-914"><span class="linenos">914</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">version_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
</span></pre></div>
@@ -1681,350 +1679,348 @@
</span><span id="BigQuery-571"><a href="#BigQuery-571"><span class="linenos">571</span></a> <span class="n">SUPPORTS_TO_NUMBER</span> <span class="o">=</span> <span class="kc">False</span>
</span><span id="BigQuery-572"><a href="#BigQuery-572"><span class="linenos">572</span></a> <span class="n">NAMED_PLACEHOLDER_TOKEN</span> <span class="o">=</span> <span class="s2">&quot;@&quot;</span>
</span><span id="BigQuery-573"><a href="#BigQuery-573"><span class="linenos">573</span></a> <span class="n">HEX_FUNC</span> <span class="o">=</span> <span class="s2">&quot;TO_HEX&quot;</span>
-</span><span id="BigQuery-574"><a href="#BigQuery-574"><span class="linenos">574</span></a>
-</span><span id="BigQuery-575"><a href="#BigQuery-575"><span class="linenos">575</span></a> <span class="n">TRANSFORMS</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="BigQuery-576"><a href="#BigQuery-576"><span class="linenos">576</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TRANSFORMS</span><span class="p">,</span>
-</span><span id="BigQuery-577"><a href="#BigQuery-577"><span class="linenos">577</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ApproxDistinct</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;APPROX_COUNT_DISTINCT&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-578"><a href="#BigQuery-578"><span class="linenos">578</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMax</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MAX_BY&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-579"><a href="#BigQuery-579"><span class="linenos">579</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMin</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MIN_BY&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-580"><a href="#BigQuery-580"><span class="linenos">580</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Array</span><span class="p">:</span> <span class="n">inline_array_unless_query</span><span class="p">,</span>
-</span><span id="BigQuery-581"><a href="#BigQuery-581"><span class="linenos">581</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayContains</span><span class="p">:</span> <span class="n">_array_contains_sql</span><span class="p">,</span>
-</span><span id="BigQuery-582"><a href="#BigQuery-582"><span class="linenos">582</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayFilter</span><span class="p">:</span> <span class="n">filter_array_using_unnest</span><span class="p">,</span>
-</span><span id="BigQuery-583"><a href="#BigQuery-583"><span class="linenos">583</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArraySize</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;ARRAY_LENGTH&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-584"><a href="#BigQuery-584"><span class="linenos">584</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">transforms</span><span class="o">.</span><span class="n">remove_precision_parameterized_types</span><span class="p">]),</span>
-</span><span id="BigQuery-585"><a href="#BigQuery-585"><span class="linenos">585</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CollateProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
-</span><span id="BigQuery-586"><a href="#BigQuery-586"><span class="linenos">586</span></a> <span class="sa">f</span><span class="s2">&quot;DEFAULT COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery-587"><a href="#BigQuery-587"><span class="linenos">587</span></a> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;default&quot;</span><span class="p">)</span>
-</span><span id="BigQuery-588"><a href="#BigQuery-588"><span class="linenos">588</span></a> <span class="k">else</span> <span class="sa">f</span><span class="s2">&quot;COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery-589"><a href="#BigQuery-589"><span class="linenos">589</span></a> <span class="p">),</span>
-</span><span id="BigQuery-590"><a href="#BigQuery-590"><span class="linenos">590</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Commit</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;COMMIT TRANSACTION&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-591"><a href="#BigQuery-591"><span class="linenos">591</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CountIf</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;COUNTIF&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-592"><a href="#BigQuery-592"><span class="linenos">592</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Create</span><span class="p">:</span> <span class="n">_create_sql</span><span class="p">,</span>
-</span><span id="BigQuery-593"><a href="#BigQuery-593"><span class="linenos">593</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CTE</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">_pushdown_cte_column_names</span><span class="p">]),</span>
-</span><span id="BigQuery-594"><a href="#BigQuery-594"><span class="linenos">594</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-595"><a href="#BigQuery-595"><span class="linenos">595</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateDiff</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery-596"><a href="#BigQuery-596"><span class="linenos">596</span></a> <span class="s2">&quot;DATE_DIFF&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span> <span class="n">unit_to_var</span><span class="p">(</span><span class="n">e</span><span class="p">)</span>
-</span><span id="BigQuery-597"><a href="#BigQuery-597"><span class="linenos">597</span></a> <span class="p">),</span>
-</span><span id="BigQuery-598"><a href="#BigQuery-598"><span class="linenos">598</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-599"><a href="#BigQuery-599"><span class="linenos">599</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateStrToDate</span><span class="p">:</span> <span class="n">datestrtodate_sql</span><span class="p">,</span>
-</span><span id="BigQuery-600"><a href="#BigQuery-600"><span class="linenos">600</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-601"><a href="#BigQuery-601"><span class="linenos">601</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-602"><a href="#BigQuery-602"><span class="linenos">602</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-603"><a href="#BigQuery-603"><span class="linenos">603</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateTrunc</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATE_TRUNC&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;unit&quot;</span><span class="p">)),</span>
-</span><span id="BigQuery-604"><a href="#BigQuery-604"><span class="linenos">604</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">FromTimeZone</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery-605"><a href="#BigQuery-605"><span class="linenos">605</span></a> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)),</span> <span class="s2">&quot;&#39;UTC&#39;&quot;</span>
-</span><span id="BigQuery-606"><a href="#BigQuery-606"><span class="linenos">606</span></a> <span class="p">),</span>
-</span><span id="BigQuery-607"><a href="#BigQuery-607"><span class="linenos">607</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GenerateSeries</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;GENERATE_ARRAY&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-608"><a href="#BigQuery-608"><span class="linenos">608</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GroupConcat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;STRING_AGG&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-609"><a href="#BigQuery-609"><span class="linenos">609</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Hex</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;UPPER&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&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">e</span><span class="p">,</span> <span class="s2">&quot;this&quot;</span><span class="p">))),</span>
-</span><span id="BigQuery-610"><a href="#BigQuery-610"><span class="linenos">610</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">If</span><span class="p">:</span> <span class="n">if_sql</span><span class="p">(</span><span class="n">false_value</span><span class="o">=</span><span class="s2">&quot;NULL&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-611"><a href="#BigQuery-611"><span class="linenos">611</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ILike</span><span class="p">:</span> <span class="n">no_ilike_sql</span><span class="p">,</span>
-</span><span id="BigQuery-612"><a href="#BigQuery-612"><span class="linenos">612</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">IntDiv</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DIV&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-613"><a href="#BigQuery-613"><span class="linenos">613</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONFormat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TO_JSON_STRING&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-614"><a href="#BigQuery-614"><span class="linenos">614</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Max</span><span class="p">:</span> <span class="n">max_or_greatest</span><span class="p">,</span>
-</span><span id="BigQuery-615"><a href="#BigQuery-615"><span class="linenos">615</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">)),</span>
-</span><span id="BigQuery-616"><a href="#BigQuery-616"><span class="linenos">616</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5Digest</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-617"><a href="#BigQuery-617"><span class="linenos">617</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Min</span><span class="p">:</span> <span class="n">min_or_least</span><span class="p">,</span>
-</span><span id="BigQuery-618"><a href="#BigQuery-618"><span class="linenos">618</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="sa">f</span><span class="s2">&quot;PARTITION BY </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-619"><a href="#BigQuery-619"><span class="linenos">619</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpExtract</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery-620"><a href="#BigQuery-620"><span class="linenos">620</span></a> <span class="s2">&quot;REGEXP_EXTRACT&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-621"><a href="#BigQuery-621"><span class="linenos">621</span></a> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span>
-</span><span id="BigQuery-622"><a href="#BigQuery-622"><span class="linenos">622</span></a> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span>
-</span><span id="BigQuery-623"><a href="#BigQuery-623"><span class="linenos">623</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;position&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-624"><a href="#BigQuery-624"><span class="linenos">624</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;occurrence&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-625"><a href="#BigQuery-625"><span class="linenos">625</span></a> <span class="p">),</span>
-</span><span id="BigQuery-626"><a href="#BigQuery-626"><span class="linenos">626</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpReplace</span><span class="p">:</span> <span class="n">regexp_replace_sql</span><span class="p">,</span>
-</span><span id="BigQuery-627"><a href="#BigQuery-627"><span class="linenos">627</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpLike</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;REGEXP_CONTAINS&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-628"><a href="#BigQuery-628"><span class="linenos">628</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ReturnsProperty</span><span class="p">:</span> <span class="n">_returnsproperty_sql</span><span class="p">,</span>
-</span><span id="BigQuery-629"><a href="#BigQuery-629"><span class="linenos">629</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Rollback</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;ROLLBACK TRANSACTION&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-630"><a href="#BigQuery-630"><span class="linenos">630</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Select</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">(</span>
-</span><span id="BigQuery-631"><a href="#BigQuery-631"><span class="linenos">631</span></a> <span class="p">[</span>
-</span><span id="BigQuery-632"><a href="#BigQuery-632"><span class="linenos">632</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">explode_to_unnest</span><span class="p">(),</span>
-</span><span id="BigQuery-633"><a href="#BigQuery-633"><span class="linenos">633</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">unqualify_unnest</span><span class="p">,</span>
-</span><span id="BigQuery-634"><a href="#BigQuery-634"><span class="linenos">634</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_distinct_on</span><span class="p">,</span>
-</span><span id="BigQuery-635"><a href="#BigQuery-635"><span class="linenos">635</span></a> <span class="n">_alias_ordered_group</span><span class="p">,</span>
-</span><span id="BigQuery-636"><a href="#BigQuery-636"><span class="linenos">636</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_semi_and_anti_joins</span><span class="p">,</span>
-</span><span id="BigQuery-637"><a href="#BigQuery-637"><span class="linenos">637</span></a> <span class="p">]</span>
-</span><span id="BigQuery-638"><a href="#BigQuery-638"><span class="linenos">638</span></a> <span class="p">),</span>
-</span><span id="BigQuery-639"><a href="#BigQuery-639"><span class="linenos">639</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;SHA1&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-640"><a href="#BigQuery-640"><span class="linenos">640</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA2</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery-641"><a href="#BigQuery-641"><span class="linenos">641</span></a> <span class="s2">&quot;SHA256&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;length&quot;</span><span class="p">)</span> <span class="o">==</span> <span class="s2">&quot;256&quot;</span> <span class="k">else</span> <span class="s2">&quot;SHA512&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span>
-</span><span id="BigQuery-642"><a href="#BigQuery-642"><span class="linenos">642</span></a> <span class="p">),</span>
-</span><span id="BigQuery-643"><a href="#BigQuery-643"><span class="linenos">643</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StabilityProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
-</span><span id="BigQuery-644"><a href="#BigQuery-644"><span class="linenos">644</span></a> <span class="s2">&quot;DETERMINISTIC&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;IMMUTABLE&quot;</span> <span class="k">else</span> <span class="s2">&quot;NOT DETERMINISTIC&quot;</span>
-</span><span id="BigQuery-645"><a href="#BigQuery-645"><span class="linenos">645</span></a> <span class="p">),</span>
-</span><span id="BigQuery-646"><a href="#BigQuery-646"><span class="linenos">646</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToDate</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;PARSE_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">),</span>
-</span><span id="BigQuery-647"><a href="#BigQuery-647"><span class="linenos">647</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToTime</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery-648"><a href="#BigQuery-648"><span class="linenos">648</span></a> <span class="s2">&quot;PARSE_TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)</span>
-</span><span id="BigQuery-649"><a href="#BigQuery-649"><span class="linenos">649</span></a> <span class="p">),</span>
-</span><span id="BigQuery-650"><a href="#BigQuery-650"><span class="linenos">650</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-651"><a href="#BigQuery-651"><span class="linenos">651</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-652"><a href="#BigQuery-652"><span class="linenos">652</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-653"><a href="#BigQuery-653"><span class="linenos">653</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-654"><a href="#BigQuery-654"><span class="linenos">654</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampDiff</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP_DIFF&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-655"><a href="#BigQuery-655"><span class="linenos">655</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-656"><a href="#BigQuery-656"><span class="linenos">656</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeStrToTime</span><span class="p">:</span> <span class="n">timestrtotime_sql</span><span class="p">,</span>
-</span><span id="BigQuery-657"><a href="#BigQuery-657"><span class="linenos">657</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Transaction</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;BEGIN TRANSACTION&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-658"><a href="#BigQuery-658"><span class="linenos">658</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Trim</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TRIM&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">),</span>
-</span><span id="BigQuery-659"><a href="#BigQuery-659"><span class="linenos">659</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsAdd</span><span class="p">:</span> <span class="n">_ts_or_ds_add_sql</span><span class="p">,</span>
-</span><span id="BigQuery-660"><a href="#BigQuery-660"><span class="linenos">660</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsDiff</span><span class="p">:</span> <span class="n">_ts_or_ds_diff_sql</span><span class="p">,</span>
-</span><span id="BigQuery-661"><a href="#BigQuery-661"><span class="linenos">661</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToTime</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-662"><a href="#BigQuery-662"><span class="linenos">662</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Unhex</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;FROM_HEX&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-663"><a href="#BigQuery-663"><span class="linenos">663</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixDate</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;UNIX_DATE&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-664"><a href="#BigQuery-664"><span class="linenos">664</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixToTime</span><span class="p">:</span> <span class="n">_unix_to_time_sql</span><span class="p">,</span>
-</span><span id="BigQuery-665"><a href="#BigQuery-665"><span class="linenos">665</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Values</span><span class="p">:</span> <span class="n">_derived_table_values_to_unnest</span><span class="p">,</span>
-</span><span id="BigQuery-666"><a href="#BigQuery-666"><span class="linenos">666</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VariancePop</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;VAR_POP&quot;</span><span class="p">),</span>
-</span><span id="BigQuery-667"><a href="#BigQuery-667"><span class="linenos">667</span></a> <span class="p">}</span>
-</span><span id="BigQuery-668"><a href="#BigQuery-668"><span class="linenos">668</span></a>
-</span><span id="BigQuery-669"><a href="#BigQuery-669"><span class="linenos">669</span></a> <span class="n">SUPPORTED_JSON_PATH_PARTS</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="BigQuery-670"><a href="#BigQuery-670"><span class="linenos">670</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathKey</span><span class="p">,</span>
-</span><span id="BigQuery-671"><a href="#BigQuery-671"><span class="linenos">671</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathRoot</span><span class="p">,</span>
-</span><span id="BigQuery-672"><a href="#BigQuery-672"><span class="linenos">672</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathSubscript</span><span class="p">,</span>
-</span><span id="BigQuery-673"><a href="#BigQuery-673"><span class="linenos">673</span></a> <span class="p">}</span>
-</span><span id="BigQuery-674"><a href="#BigQuery-674"><span class="linenos">674</span></a>
-</span><span id="BigQuery-675"><a href="#BigQuery-675"><span class="linenos">675</span></a> <span class="n">TYPE_MAPPING</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="BigQuery-676"><a href="#BigQuery-676"><span class="linenos">676</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TYPE_MAPPING</span><span class="p">,</span>
-</span><span id="BigQuery-677"><a href="#BigQuery-677"><span class="linenos">677</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGDECIMAL</span><span class="p">:</span> <span class="s2">&quot;BIGNUMERIC&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-678"><a href="#BigQuery-678"><span class="linenos">678</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-679"><a href="#BigQuery-679"><span class="linenos">679</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-680"><a href="#BigQuery-680"><span class="linenos">680</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BOOLEAN</span><span class="p">:</span> <span class="s2">&quot;BOOL&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-681"><a href="#BigQuery-681"><span class="linenos">681</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">CHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-682"><a href="#BigQuery-682"><span class="linenos">682</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DECIMAL</span><span class="p">:</span> <span class="s2">&quot;NUMERIC&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-683"><a href="#BigQuery-683"><span class="linenos">683</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DOUBLE</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-684"><a href="#BigQuery-684"><span class="linenos">684</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">FLOAT</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-685"><a href="#BigQuery-685"><span class="linenos">685</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">INT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-686"><a href="#BigQuery-686"><span class="linenos">686</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-687"><a href="#BigQuery-687"><span class="linenos">687</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NVARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-688"><a href="#BigQuery-688"><span class="linenos">688</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">SMALLINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-689"><a href="#BigQuery-689"><span class="linenos">689</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TEXT</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-690"><a href="#BigQuery-690"><span class="linenos">690</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMP</span><span class="p">:</span> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-691"><a href="#BigQuery-691"><span class="linenos">691</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-692"><a href="#BigQuery-692"><span class="linenos">692</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPLTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-693"><a href="#BigQuery-693"><span class="linenos">693</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TINYINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-694"><a href="#BigQuery-694"><span class="linenos">694</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARBINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-695"><a href="#BigQuery-695"><span class="linenos">695</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">ROWVERSION</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-696"><a href="#BigQuery-696"><span class="linenos">696</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-697"><a href="#BigQuery-697"><span class="linenos">697</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARIANT</span><span class="p">:</span> <span class="s2">&quot;ANY TYPE&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-698"><a href="#BigQuery-698"><span class="linenos">698</span></a> <span class="p">}</span>
-</span><span id="BigQuery-699"><a href="#BigQuery-699"><span class="linenos">699</span></a>
-</span><span id="BigQuery-700"><a href="#BigQuery-700"><span class="linenos">700</span></a> <span class="n">PROPERTIES_LOCATION</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="BigQuery-701"><a href="#BigQuery-701"><span class="linenos">701</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">PROPERTIES_LOCATION</span><span class="p">,</span>
-</span><span id="BigQuery-702"><a href="#BigQuery-702"><span class="linenos">702</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">POST_SCHEMA</span><span class="p">,</span>
-</span><span id="BigQuery-703"><a href="#BigQuery-703"><span class="linenos">703</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VolatileProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">UNSUPPORTED</span><span class="p">,</span>
-</span><span id="BigQuery-704"><a href="#BigQuery-704"><span class="linenos">704</span></a> <span class="p">}</span>
-</span><span id="BigQuery-705"><a href="#BigQuery-705"><span class="linenos">705</span></a>
-</span><span id="BigQuery-706"><a href="#BigQuery-706"><span class="linenos">706</span></a> <span class="c1"># from: https://cloud.google.com/bigquery/docs/reference/standard-sql/lexical#reserved_keywords</span>
-</span><span id="BigQuery-707"><a href="#BigQuery-707"><span class="linenos">707</span></a> <span class="n">RESERVED_KEYWORDS</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="BigQuery-708"><a href="#BigQuery-708"><span class="linenos">708</span></a> <span class="o">*</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">RESERVED_KEYWORDS</span><span class="p">,</span>
-</span><span id="BigQuery-709"><a href="#BigQuery-709"><span class="linenos">709</span></a> <span class="s2">&quot;all&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-710"><a href="#BigQuery-710"><span class="linenos">710</span></a> <span class="s2">&quot;and&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-711"><a href="#BigQuery-711"><span class="linenos">711</span></a> <span class="s2">&quot;any&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-712"><a href="#BigQuery-712"><span class="linenos">712</span></a> <span class="s2">&quot;array&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-713"><a href="#BigQuery-713"><span class="linenos">713</span></a> <span class="s2">&quot;as&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-714"><a href="#BigQuery-714"><span class="linenos">714</span></a> <span class="s2">&quot;asc&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-715"><a href="#BigQuery-715"><span class="linenos">715</span></a> <span class="s2">&quot;assert_rows_modified&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-716"><a href="#BigQuery-716"><span class="linenos">716</span></a> <span class="s2">&quot;at&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-717"><a href="#BigQuery-717"><span class="linenos">717</span></a> <span class="s2">&quot;between&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-718"><a href="#BigQuery-718"><span class="linenos">718</span></a> <span class="s2">&quot;by&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-719"><a href="#BigQuery-719"><span class="linenos">719</span></a> <span class="s2">&quot;case&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-720"><a href="#BigQuery-720"><span class="linenos">720</span></a> <span class="s2">&quot;cast&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-721"><a href="#BigQuery-721"><span class="linenos">721</span></a> <span class="s2">&quot;collate&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-722"><a href="#BigQuery-722"><span class="linenos">722</span></a> <span class="s2">&quot;contains&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-723"><a href="#BigQuery-723"><span class="linenos">723</span></a> <span class="s2">&quot;create&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-724"><a href="#BigQuery-724"><span class="linenos">724</span></a> <span class="s2">&quot;cross&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-725"><a href="#BigQuery-725"><span class="linenos">725</span></a> <span class="s2">&quot;cube&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-726"><a href="#BigQuery-726"><span class="linenos">726</span></a> <span class="s2">&quot;current&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-727"><a href="#BigQuery-727"><span class="linenos">727</span></a> <span class="s2">&quot;default&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-728"><a href="#BigQuery-728"><span class="linenos">728</span></a> <span class="s2">&quot;define&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-729"><a href="#BigQuery-729"><span class="linenos">729</span></a> <span class="s2">&quot;desc&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-730"><a href="#BigQuery-730"><span class="linenos">730</span></a> <span class="s2">&quot;distinct&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-731"><a href="#BigQuery-731"><span class="linenos">731</span></a> <span class="s2">&quot;else&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-732"><a href="#BigQuery-732"><span class="linenos">732</span></a> <span class="s2">&quot;end&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-733"><a href="#BigQuery-733"><span class="linenos">733</span></a> <span class="s2">&quot;enum&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-734"><a href="#BigQuery-734"><span class="linenos">734</span></a> <span class="s2">&quot;escape&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-735"><a href="#BigQuery-735"><span class="linenos">735</span></a> <span class="s2">&quot;except&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-736"><a href="#BigQuery-736"><span class="linenos">736</span></a> <span class="s2">&quot;exclude&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-737"><a href="#BigQuery-737"><span class="linenos">737</span></a> <span class="s2">&quot;exists&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-738"><a href="#BigQuery-738"><span class="linenos">738</span></a> <span class="s2">&quot;extract&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-739"><a href="#BigQuery-739"><span class="linenos">739</span></a> <span class="s2">&quot;false&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-740"><a href="#BigQuery-740"><span class="linenos">740</span></a> <span class="s2">&quot;fetch&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-741"><a href="#BigQuery-741"><span class="linenos">741</span></a> <span class="s2">&quot;following&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-742"><a href="#BigQuery-742"><span class="linenos">742</span></a> <span class="s2">&quot;for&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-743"><a href="#BigQuery-743"><span class="linenos">743</span></a> <span class="s2">&quot;from&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-744"><a href="#BigQuery-744"><span class="linenos">744</span></a> <span class="s2">&quot;full&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-745"><a href="#BigQuery-745"><span class="linenos">745</span></a> <span class="s2">&quot;group&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-746"><a href="#BigQuery-746"><span class="linenos">746</span></a> <span class="s2">&quot;grouping&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-747"><a href="#BigQuery-747"><span class="linenos">747</span></a> <span class="s2">&quot;groups&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-748"><a href="#BigQuery-748"><span class="linenos">748</span></a> <span class="s2">&quot;hash&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-749"><a href="#BigQuery-749"><span class="linenos">749</span></a> <span class="s2">&quot;having&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-750"><a href="#BigQuery-750"><span class="linenos">750</span></a> <span class="s2">&quot;if&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-751"><a href="#BigQuery-751"><span class="linenos">751</span></a> <span class="s2">&quot;ignore&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-752"><a href="#BigQuery-752"><span class="linenos">752</span></a> <span class="s2">&quot;in&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-753"><a href="#BigQuery-753"><span class="linenos">753</span></a> <span class="s2">&quot;inner&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-754"><a href="#BigQuery-754"><span class="linenos">754</span></a> <span class="s2">&quot;intersect&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-755"><a href="#BigQuery-755"><span class="linenos">755</span></a> <span class="s2">&quot;interval&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-756"><a href="#BigQuery-756"><span class="linenos">756</span></a> <span class="s2">&quot;into&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-757"><a href="#BigQuery-757"><span class="linenos">757</span></a> <span class="s2">&quot;is&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-758"><a href="#BigQuery-758"><span class="linenos">758</span></a> <span class="s2">&quot;join&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-759"><a href="#BigQuery-759"><span class="linenos">759</span></a> <span class="s2">&quot;lateral&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-760"><a href="#BigQuery-760"><span class="linenos">760</span></a> <span class="s2">&quot;left&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-761"><a href="#BigQuery-761"><span class="linenos">761</span></a> <span class="s2">&quot;like&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-762"><a href="#BigQuery-762"><span class="linenos">762</span></a> <span class="s2">&quot;limit&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-763"><a href="#BigQuery-763"><span class="linenos">763</span></a> <span class="s2">&quot;lookup&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-764"><a href="#BigQuery-764"><span class="linenos">764</span></a> <span class="s2">&quot;merge&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-765"><a href="#BigQuery-765"><span class="linenos">765</span></a> <span class="s2">&quot;natural&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-766"><a href="#BigQuery-766"><span class="linenos">766</span></a> <span class="s2">&quot;new&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-767"><a href="#BigQuery-767"><span class="linenos">767</span></a> <span class="s2">&quot;no&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-768"><a href="#BigQuery-768"><span class="linenos">768</span></a> <span class="s2">&quot;not&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-769"><a href="#BigQuery-769"><span class="linenos">769</span></a> <span class="s2">&quot;null&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-770"><a href="#BigQuery-770"><span class="linenos">770</span></a> <span class="s2">&quot;nulls&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-771"><a href="#BigQuery-771"><span class="linenos">771</span></a> <span class="s2">&quot;of&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-772"><a href="#BigQuery-772"><span class="linenos">772</span></a> <span class="s2">&quot;on&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-773"><a href="#BigQuery-773"><span class="linenos">773</span></a> <span class="s2">&quot;or&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-774"><a href="#BigQuery-774"><span class="linenos">774</span></a> <span class="s2">&quot;order&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-775"><a href="#BigQuery-775"><span class="linenos">775</span></a> <span class="s2">&quot;outer&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-776"><a href="#BigQuery-776"><span class="linenos">776</span></a> <span class="s2">&quot;over&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-777"><a href="#BigQuery-777"><span class="linenos">777</span></a> <span class="s2">&quot;partition&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-778"><a href="#BigQuery-778"><span class="linenos">778</span></a> <span class="s2">&quot;preceding&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-779"><a href="#BigQuery-779"><span class="linenos">779</span></a> <span class="s2">&quot;proto&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-780"><a href="#BigQuery-780"><span class="linenos">780</span></a> <span class="s2">&quot;qualify&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-781"><a href="#BigQuery-781"><span class="linenos">781</span></a> <span class="s2">&quot;range&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-782"><a href="#BigQuery-782"><span class="linenos">782</span></a> <span class="s2">&quot;recursive&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-783"><a href="#BigQuery-783"><span class="linenos">783</span></a> <span class="s2">&quot;respect&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-784"><a href="#BigQuery-784"><span class="linenos">784</span></a> <span class="s2">&quot;right&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-785"><a href="#BigQuery-785"><span class="linenos">785</span></a> <span class="s2">&quot;rollup&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-786"><a href="#BigQuery-786"><span class="linenos">786</span></a> <span class="s2">&quot;rows&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-787"><a href="#BigQuery-787"><span class="linenos">787</span></a> <span class="s2">&quot;select&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-788"><a href="#BigQuery-788"><span class="linenos">788</span></a> <span class="s2">&quot;set&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-789"><a href="#BigQuery-789"><span class="linenos">789</span></a> <span class="s2">&quot;some&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-790"><a href="#BigQuery-790"><span class="linenos">790</span></a> <span class="s2">&quot;struct&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-791"><a href="#BigQuery-791"><span class="linenos">791</span></a> <span class="s2">&quot;tablesample&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-792"><a href="#BigQuery-792"><span class="linenos">792</span></a> <span class="s2">&quot;then&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-793"><a href="#BigQuery-793"><span class="linenos">793</span></a> <span class="s2">&quot;to&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-794"><a href="#BigQuery-794"><span class="linenos">794</span></a> <span class="s2">&quot;treat&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-795"><a href="#BigQuery-795"><span class="linenos">795</span></a> <span class="s2">&quot;true&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-796"><a href="#BigQuery-796"><span class="linenos">796</span></a> <span class="s2">&quot;unbounded&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-797"><a href="#BigQuery-797"><span class="linenos">797</span></a> <span class="s2">&quot;union&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-798"><a href="#BigQuery-798"><span class="linenos">798</span></a> <span class="s2">&quot;unnest&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-799"><a href="#BigQuery-799"><span class="linenos">799</span></a> <span class="s2">&quot;using&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-800"><a href="#BigQuery-800"><span class="linenos">800</span></a> <span class="s2">&quot;when&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-801"><a href="#BigQuery-801"><span class="linenos">801</span></a> <span class="s2">&quot;where&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-802"><a href="#BigQuery-802"><span class="linenos">802</span></a> <span class="s2">&quot;window&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-803"><a href="#BigQuery-803"><span class="linenos">803</span></a> <span class="s2">&quot;with&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-804"><a href="#BigQuery-804"><span class="linenos">804</span></a> <span class="s2">&quot;within&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-805"><a href="#BigQuery-805"><span class="linenos">805</span></a> <span class="p">}</span>
-</span><span id="BigQuery-806"><a href="#BigQuery-806"><span class="linenos">806</span></a>
-</span><span id="BigQuery-807"><a href="#BigQuery-807"><span class="linenos">807</span></a> <span class="k">def</span> <span class="nf">mod_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Mod</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-808"><a href="#BigQuery-808"><span class="linenos">808</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
-</span><span id="BigQuery-809"><a href="#BigQuery-809"><span class="linenos">809</span></a> <span class="n">expr</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expression</span>
-</span><span id="BigQuery-810"><a href="#BigQuery-810"><span class="linenos">810</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery-811"><a href="#BigQuery-811"><span class="linenos">811</span></a> <span class="s2">&quot;MOD&quot;</span><span class="p">,</span>
-</span><span id="BigQuery-812"><a href="#BigQuery-812"><span class="linenos">812</span></a> <span class="n">this</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">this</span><span class="p">,</span>
-</span><span id="BigQuery-813"><a href="#BigQuery-813"><span class="linenos">813</span></a> <span class="n">expr</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expr</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">expr</span><span class="p">,</span>
-</span><span id="BigQuery-814"><a href="#BigQuery-814"><span class="linenos">814</span></a> <span class="p">)</span>
-</span><span id="BigQuery-815"><a href="#BigQuery-815"><span class="linenos">815</span></a>
-</span><span id="BigQuery-816"><a href="#BigQuery-816"><span class="linenos">816</span></a> <span class="k">def</span> <span class="nf">column_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Column</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-817"><a href="#BigQuery-817"><span class="linenos">817</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_column&quot;</span><span class="p">):</span>
-</span><span id="BigQuery-818"><a href="#BigQuery-818"><span class="linenos">818</span></a> <span class="c1"># If a column reference is of the form `dataset.table`.name, we need</span>
-</span><span id="BigQuery-819"><a href="#BigQuery-819"><span class="linenos">819</span></a> <span class="c1"># to preserve the quoted table path, otherwise the reference breaks</span>
-</span><span id="BigQuery-820"><a href="#BigQuery-820"><span class="linenos">820</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">[:</span><span class="o">-</span><span class="mi">1</span><span class="p">])</span>
-</span><span id="BigQuery-821"><a href="#BigQuery-821"><span class="linenos">821</span></a> <span class="n">table_path</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">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
-</span><span id="BigQuery-822"><a href="#BigQuery-822"><span class="linenos">822</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="n">table_path</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery-823"><a href="#BigQuery-823"><span class="linenos">823</span></a>
-</span><span id="BigQuery-824"><a href="#BigQuery-824"><span class="linenos">824</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">column_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="BigQuery-825"><a href="#BigQuery-825"><span class="linenos">825</span></a>
-</span><span id="BigQuery-826"><a href="#BigQuery-826"><span class="linenos">826</span></a> <span class="k">def</span> <span class="nf">table_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Table</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-827"><a href="#BigQuery-827"><span class="linenos">827</span></a> <span class="c1"># Depending on the context, `x.y` may not resolve to the same data source as `x`.`y`, so</span>
-</span><span id="BigQuery-828"><a href="#BigQuery-828"><span class="linenos">828</span></a> <span class="c1"># we need to make sure the correct quoting is used in each case.</span>
-</span><span id="BigQuery-829"><a href="#BigQuery-829"><span class="linenos">829</span></a> <span class="c1">#</span>
-</span><span id="BigQuery-830"><a href="#BigQuery-830"><span class="linenos">830</span></a> <span class="c1"># For example, if there is a CTE x that clashes with a schema name, then the former will</span>
-</span><span id="BigQuery-831"><a href="#BigQuery-831"><span class="linenos">831</span></a> <span class="c1"># return the table y in that schema, whereas the latter will return the CTE&#39;s y column:</span>
-</span><span id="BigQuery-832"><a href="#BigQuery-832"><span class="linenos">832</span></a> <span class="c1">#</span>
-</span><span id="BigQuery-833"><a href="#BigQuery-833"><span class="linenos">833</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x.y` -&gt; cross join</span>
-</span><span id="BigQuery-834"><a href="#BigQuery-834"><span class="linenos">834</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x`.`y` -&gt; implicit unnest</span>
-</span><span id="BigQuery-835"><a href="#BigQuery-835"><span class="linenos">835</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_table&quot;</span><span class="p">):</span>
-</span><span id="BigQuery-836"><a href="#BigQuery-836"><span class="linenos">836</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">)</span>
-</span><span id="BigQuery-837"><a href="#BigQuery-837"><span class="linenos">837</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
-</span><span id="BigQuery-838"><a href="#BigQuery-838"><span class="linenos">838</span></a>
-</span><span id="BigQuery-839"><a href="#BigQuery-839"><span class="linenos">839</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">table_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="BigQuery-840"><a href="#BigQuery-840"><span class="linenos">840</span></a>
-</span><span id="BigQuery-841"><a href="#BigQuery-841"><span class="linenos">841</span></a> <span class="k">def</span> <span class="nf">timetostr_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TimeToStr</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-842"><a href="#BigQuery-842"><span class="linenos">842</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToDate</span><span class="p">)</span> <span class="k">else</span> <span class="n">expression</span>
-</span><span id="BigQuery-843"><a href="#BigQuery-843"><span class="linenos">843</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;FORMAT_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">expression</span><span class="p">),</span> <span class="n">this</span><span class="o">.</span><span class="n">this</span><span class="p">)</span>
-</span><span id="BigQuery-844"><a href="#BigQuery-844"><span class="linenos">844</span></a>
-</span><span id="BigQuery-845"><a href="#BigQuery-845"><span class="linenos">845</span></a> <span class="k">def</span> <span class="nf">eq_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">EQ</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-846"><a href="#BigQuery-846"><span class="linenos">846</span></a> <span class="c1"># Operands of = cannot be NULL in BigQuery</span>
-</span><span id="BigQuery-847"><a href="#BigQuery-847"><span class="linenos">847</span></a> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">left</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">)</span> <span class="ow">or</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">right</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">):</span>
-</span><span id="BigQuery-848"><a href="#BigQuery-848"><span class="linenos">848</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Update</span><span class="p">):</span>
-</span><span id="BigQuery-849"><a href="#BigQuery-849"><span class="linenos">849</span></a> <span class="k">return</span> <span class="s2">&quot;NULL&quot;</span>
-</span><span id="BigQuery-850"><a href="#BigQuery-850"><span class="linenos">850</span></a>
-</span><span id="BigQuery-851"><a href="#BigQuery-851"><span class="linenos">851</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">binary</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="s2">&quot;=&quot;</span><span class="p">)</span>
-</span><span id="BigQuery-852"><a href="#BigQuery-852"><span class="linenos">852</span></a>
-</span><span id="BigQuery-853"><a href="#BigQuery-853"><span class="linenos">853</span></a> <span class="k">def</span> <span class="nf">attimezone_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">AtTimeZone</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-854"><a href="#BigQuery-854"><span class="linenos">854</span></a> <span class="n">parent</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">parent</span>
-</span><span id="BigQuery-855"><a href="#BigQuery-855"><span class="linenos">855</span></a>
-</span><span id="BigQuery-856"><a href="#BigQuery-856"><span class="linenos">856</span></a> <span class="c1"># BigQuery allows CAST(.. AS {STRING|TIMESTAMP} [FORMAT &lt;fmt&gt; [AT TIME ZONE &lt;tz&gt;]]).</span>
-</span><span id="BigQuery-857"><a href="#BigQuery-857"><span class="linenos">857</span></a> <span class="c1"># Only the TIMESTAMP one should use the below conversion, when AT TIME ZONE is included.</span>
-</span><span id="BigQuery-858"><a href="#BigQuery-858"><span class="linenos">858</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">)</span> <span class="ow">or</span> <span class="ow">not</span> <span class="n">parent</span><span class="o">.</span><span class="n">to</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="s2">&quot;text&quot;</span><span class="p">):</span>
-</span><span id="BigQuery-859"><a href="#BigQuery-859"><span class="linenos">859</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery-860"><a href="#BigQuery-860"><span class="linenos">860</span></a> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">))</span>
-</span><span id="BigQuery-861"><a href="#BigQuery-861"><span class="linenos">861</span></a> <span class="p">)</span>
-</span><span id="BigQuery-862"><a href="#BigQuery-862"><span class="linenos">862</span></a>
-</span><span id="BigQuery-863"><a href="#BigQuery-863"><span class="linenos">863</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">attimezone_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="BigQuery-864"><a href="#BigQuery-864"><span class="linenos">864</span></a>
-</span><span id="BigQuery-865"><a href="#BigQuery-865"><span class="linenos">865</span></a> <span class="k">def</span> <span class="nf">trycast_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TryCast</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-866"><a href="#BigQuery-866"><span class="linenos">866</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">cast_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">safe_prefix</span><span class="o">=</span><span class="s2">&quot;SAFE_&quot;</span><span class="p">)</span>
-</span><span id="BigQuery-867"><a href="#BigQuery-867"><span class="linenos">867</span></a>
-</span><span id="BigQuery-868"><a href="#BigQuery-868"><span class="linenos">868</span></a> <span class="k">def</span> <span class="nf">bracket_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Bracket</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-869"><a href="#BigQuery-869"><span class="linenos">869</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
-</span><span id="BigQuery-870"><a href="#BigQuery-870"><span class="linenos">870</span></a> <span class="n">expressions</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expressions</span>
-</span><span id="BigQuery-871"><a href="#BigQuery-871"><span class="linenos">871</span></a>
-</span><span id="BigQuery-872"><a href="#BigQuery-872"><span class="linenos">872</span></a> <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">expressions</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> <span class="ow">and</span> <span class="n">this</span> <span class="ow">and</span> <span class="n">this</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">STRUCT</span><span class="p">):</span>
-</span><span id="BigQuery-873"><a href="#BigQuery-873"><span class="linenos">873</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">expressions</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
-</span><span id="BigQuery-874"><a href="#BigQuery-874"><span class="linenos">874</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">is</span> <span class="kc">None</span><span class="p">:</span>
-</span><span id="BigQuery-875"><a href="#BigQuery-875"><span class="linenos">875</span></a> <span class="kn">from</span> <span class="nn">sqlglot.optimizer.annotate_types</span> <span class="kn">import</span> <span class="n">annotate_types</span>
-</span><span id="BigQuery-876"><a href="#BigQuery-876"><span class="linenos">876</span></a>
-</span><span id="BigQuery-877"><a href="#BigQuery-877"><span class="linenos">877</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">annotate_types</span><span class="p">(</span><span class="n">arg</span><span class="p">)</span>
-</span><span id="BigQuery-878"><a href="#BigQuery-878"><span class="linenos">878</span></a>
-</span><span id="BigQuery-879"><a href="#BigQuery-879"><span class="linenos">879</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">and</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span><span class="o">.</span><span class="n">this</span> <span class="ow">in</span> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">TEXT_TYPES</span><span class="p">:</span>
-</span><span id="BigQuery-880"><a href="#BigQuery-880"><span class="linenos">880</span></a> <span class="c1"># BQ doesn&#39;t support bracket syntax with string values for structs</span>
-</span><span id="BigQuery-881"><a href="#BigQuery-881"><span class="linenos">881</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="n">arg</span><span class="o">.</span><span class="n">name</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery-882"><a href="#BigQuery-882"><span class="linenos">882</span></a>
-</span><span id="BigQuery-883"><a href="#BigQuery-883"><span class="linenos">883</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">expressions</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">flat</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
-</span><span id="BigQuery-884"><a href="#BigQuery-884"><span class="linenos">884</span></a> <span class="n">offset</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;offset&quot;</span><span class="p">)</span>
-</span><span id="BigQuery-885"><a href="#BigQuery-885"><span class="linenos">885</span></a>
-</span><span id="BigQuery-886"><a href="#BigQuery-886"><span class="linenos">886</span></a> <span class="k">if</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
-</span><span id="BigQuery-887"><a href="#BigQuery-887"><span class="linenos">887</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;OFFSET(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
-</span><span id="BigQuery-888"><a href="#BigQuery-888"><span class="linenos">888</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
-</span><span id="BigQuery-889"><a href="#BigQuery-889"><span class="linenos">889</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;ORDINAL(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
-</span><span id="BigQuery-890"><a href="#BigQuery-890"><span class="linenos">890</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
-</span><span id="BigQuery-891"><a href="#BigQuery-891"><span class="linenos">891</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Unsupported array offset: </span><span class="si">{</span><span class="n">offset</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">)</span>
-</span><span id="BigQuery-892"><a href="#BigQuery-892"><span class="linenos">892</span></a>
-</span><span id="BigQuery-893"><a href="#BigQuery-893"><span class="linenos">893</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;safe&quot;</span><span class="p">):</span>
-</span><span id="BigQuery-894"><a href="#BigQuery-894"><span class="linenos">894</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SAFE_</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery-895"><a href="#BigQuery-895"><span class="linenos">895</span></a>
-</span><span id="BigQuery-896"><a href="#BigQuery-896"><span class="linenos">896</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">[</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">]&quot;</span>
-</span><span id="BigQuery-897"><a href="#BigQuery-897"><span class="linenos">897</span></a>
-</span><span id="BigQuery-898"><a href="#BigQuery-898"><span class="linenos">898</span></a> <span class="k">def</span> <span class="nf">in_unnest_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Unnest</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-899"><a href="#BigQuery-899"><span class="linenos">899</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="BigQuery-900"><a href="#BigQuery-900"><span class="linenos">900</span></a>
-</span><span id="BigQuery-901"><a href="#BigQuery-901"><span class="linenos">901</span></a> <span class="k">def</span> <span class="nf">except_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Except</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-902"><a href="#BigQuery-902"><span class="linenos">902</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
-</span><span id="BigQuery-903"><a href="#BigQuery-903"><span class="linenos">903</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;EXCEPT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
-</span><span id="BigQuery-904"><a href="#BigQuery-904"><span class="linenos">904</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;EXCEPT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery-905"><a href="#BigQuery-905"><span class="linenos">905</span></a>
-</span><span id="BigQuery-906"><a href="#BigQuery-906"><span class="linenos">906</span></a> <span class="k">def</span> <span class="nf">intersect_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Intersect</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-907"><a href="#BigQuery-907"><span class="linenos">907</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
-</span><span id="BigQuery-908"><a href="#BigQuery-908"><span class="linenos">908</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;INTERSECT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
-</span><span id="BigQuery-909"><a href="#BigQuery-909"><span class="linenos">909</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;INTERSECT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery-910"><a href="#BigQuery-910"><span class="linenos">910</span></a>
-</span><span id="BigQuery-911"><a href="#BigQuery-911"><span class="linenos">911</span></a> <span class="k">def</span> <span class="nf">with_properties</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">properties</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-912"><a href="#BigQuery-912"><span class="linenos">912</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">properties</span><span class="p">(</span><span class="n">properties</span><span class="p">,</span> <span class="n">prefix</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">seg</span><span class="p">(</span><span class="s2">&quot;OPTIONS&quot;</span><span class="p">))</span>
-</span><span id="BigQuery-913"><a href="#BigQuery-913"><span class="linenos">913</span></a>
-</span><span id="BigQuery-914"><a href="#BigQuery-914"><span class="linenos">914</span></a> <span class="k">def</span> <span class="nf">version_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Version</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery-915"><a href="#BigQuery-915"><span class="linenos">915</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">:</span>
-</span><span id="BigQuery-916"><a href="#BigQuery-916"><span class="linenos">916</span></a> <span class="n">expression</span><span class="o">.</span><span class="n">set</span><span class="p">(</span><span class="s2">&quot;this&quot;</span><span class="p">,</span> <span class="s2">&quot;SYSTEM_TIME&quot;</span><span class="p">)</span>
-</span><span id="BigQuery-917"><a href="#BigQuery-917"><span class="linenos">917</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">version_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="BigQuery-574"><a href="#BigQuery-574"><span class="linenos">574</span></a> <span class="n">WITH_PROPERTIES_PREFIX</span> <span class="o">=</span> <span class="s2">&quot;OPTIONS&quot;</span>
+</span><span id="BigQuery-575"><a href="#BigQuery-575"><span class="linenos">575</span></a>
+</span><span id="BigQuery-576"><a href="#BigQuery-576"><span class="linenos">576</span></a> <span class="n">TRANSFORMS</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="BigQuery-577"><a href="#BigQuery-577"><span class="linenos">577</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TRANSFORMS</span><span class="p">,</span>
+</span><span id="BigQuery-578"><a href="#BigQuery-578"><span class="linenos">578</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ApproxDistinct</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;APPROX_COUNT_DISTINCT&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-579"><a href="#BigQuery-579"><span class="linenos">579</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMax</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MAX_BY&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-580"><a href="#BigQuery-580"><span class="linenos">580</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMin</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MIN_BY&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-581"><a href="#BigQuery-581"><span class="linenos">581</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Array</span><span class="p">:</span> <span class="n">inline_array_unless_query</span><span class="p">,</span>
+</span><span id="BigQuery-582"><a href="#BigQuery-582"><span class="linenos">582</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayContains</span><span class="p">:</span> <span class="n">_array_contains_sql</span><span class="p">,</span>
+</span><span id="BigQuery-583"><a href="#BigQuery-583"><span class="linenos">583</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayFilter</span><span class="p">:</span> <span class="n">filter_array_using_unnest</span><span class="p">,</span>
+</span><span id="BigQuery-584"><a href="#BigQuery-584"><span class="linenos">584</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArraySize</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;ARRAY_LENGTH&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-585"><a href="#BigQuery-585"><span class="linenos">585</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">transforms</span><span class="o">.</span><span class="n">remove_precision_parameterized_types</span><span class="p">]),</span>
+</span><span id="BigQuery-586"><a href="#BigQuery-586"><span class="linenos">586</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CollateProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
+</span><span id="BigQuery-587"><a href="#BigQuery-587"><span class="linenos">587</span></a> <span class="sa">f</span><span class="s2">&quot;DEFAULT COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery-588"><a href="#BigQuery-588"><span class="linenos">588</span></a> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;default&quot;</span><span class="p">)</span>
+</span><span id="BigQuery-589"><a href="#BigQuery-589"><span class="linenos">589</span></a> <span class="k">else</span> <span class="sa">f</span><span class="s2">&quot;COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery-590"><a href="#BigQuery-590"><span class="linenos">590</span></a> <span class="p">),</span>
+</span><span id="BigQuery-591"><a href="#BigQuery-591"><span class="linenos">591</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Commit</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;COMMIT TRANSACTION&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-592"><a href="#BigQuery-592"><span class="linenos">592</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CountIf</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;COUNTIF&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-593"><a href="#BigQuery-593"><span class="linenos">593</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Create</span><span class="p">:</span> <span class="n">_create_sql</span><span class="p">,</span>
+</span><span id="BigQuery-594"><a href="#BigQuery-594"><span class="linenos">594</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CTE</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">_pushdown_cte_column_names</span><span class="p">]),</span>
+</span><span id="BigQuery-595"><a href="#BigQuery-595"><span class="linenos">595</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-596"><a href="#BigQuery-596"><span class="linenos">596</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateDiff</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery-597"><a href="#BigQuery-597"><span class="linenos">597</span></a> <span class="s2">&quot;DATE_DIFF&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span> <span class="n">unit_to_var</span><span class="p">(</span><span class="n">e</span><span class="p">)</span>
+</span><span id="BigQuery-598"><a href="#BigQuery-598"><span class="linenos">598</span></a> <span class="p">),</span>
+</span><span id="BigQuery-599"><a href="#BigQuery-599"><span class="linenos">599</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-600"><a href="#BigQuery-600"><span class="linenos">600</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateStrToDate</span><span class="p">:</span> <span class="n">datestrtodate_sql</span><span class="p">,</span>
+</span><span id="BigQuery-601"><a href="#BigQuery-601"><span class="linenos">601</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-602"><a href="#BigQuery-602"><span class="linenos">602</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-603"><a href="#BigQuery-603"><span class="linenos">603</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-604"><a href="#BigQuery-604"><span class="linenos">604</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateTrunc</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATE_TRUNC&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;unit&quot;</span><span class="p">)),</span>
+</span><span id="BigQuery-605"><a href="#BigQuery-605"><span class="linenos">605</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">FromTimeZone</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery-606"><a href="#BigQuery-606"><span class="linenos">606</span></a> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)),</span> <span class="s2">&quot;&#39;UTC&#39;&quot;</span>
+</span><span id="BigQuery-607"><a href="#BigQuery-607"><span class="linenos">607</span></a> <span class="p">),</span>
+</span><span id="BigQuery-608"><a href="#BigQuery-608"><span class="linenos">608</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GenerateSeries</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;GENERATE_ARRAY&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-609"><a href="#BigQuery-609"><span class="linenos">609</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GroupConcat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;STRING_AGG&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-610"><a href="#BigQuery-610"><span class="linenos">610</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Hex</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;UPPER&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&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">e</span><span class="p">,</span> <span class="s2">&quot;this&quot;</span><span class="p">))),</span>
+</span><span id="BigQuery-611"><a href="#BigQuery-611"><span class="linenos">611</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">If</span><span class="p">:</span> <span class="n">if_sql</span><span class="p">(</span><span class="n">false_value</span><span class="o">=</span><span class="s2">&quot;NULL&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-612"><a href="#BigQuery-612"><span class="linenos">612</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ILike</span><span class="p">:</span> <span class="n">no_ilike_sql</span><span class="p">,</span>
+</span><span id="BigQuery-613"><a href="#BigQuery-613"><span class="linenos">613</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">IntDiv</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DIV&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-614"><a href="#BigQuery-614"><span class="linenos">614</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONFormat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TO_JSON_STRING&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-615"><a href="#BigQuery-615"><span class="linenos">615</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Max</span><span class="p">:</span> <span class="n">max_or_greatest</span><span class="p">,</span>
+</span><span id="BigQuery-616"><a href="#BigQuery-616"><span class="linenos">616</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">)),</span>
+</span><span id="BigQuery-617"><a href="#BigQuery-617"><span class="linenos">617</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5Digest</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-618"><a href="#BigQuery-618"><span class="linenos">618</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Min</span><span class="p">:</span> <span class="n">min_or_least</span><span class="p">,</span>
+</span><span id="BigQuery-619"><a href="#BigQuery-619"><span class="linenos">619</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="sa">f</span><span class="s2">&quot;PARTITION BY </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-620"><a href="#BigQuery-620"><span class="linenos">620</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpExtract</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery-621"><a href="#BigQuery-621"><span class="linenos">621</span></a> <span class="s2">&quot;REGEXP_EXTRACT&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-622"><a href="#BigQuery-622"><span class="linenos">622</span></a> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span>
+</span><span id="BigQuery-623"><a href="#BigQuery-623"><span class="linenos">623</span></a> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span>
+</span><span id="BigQuery-624"><a href="#BigQuery-624"><span class="linenos">624</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;position&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-625"><a href="#BigQuery-625"><span class="linenos">625</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;occurrence&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-626"><a href="#BigQuery-626"><span class="linenos">626</span></a> <span class="p">),</span>
+</span><span id="BigQuery-627"><a href="#BigQuery-627"><span class="linenos">627</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpReplace</span><span class="p">:</span> <span class="n">regexp_replace_sql</span><span class="p">,</span>
+</span><span id="BigQuery-628"><a href="#BigQuery-628"><span class="linenos">628</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpLike</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;REGEXP_CONTAINS&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-629"><a href="#BigQuery-629"><span class="linenos">629</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ReturnsProperty</span><span class="p">:</span> <span class="n">_returnsproperty_sql</span><span class="p">,</span>
+</span><span id="BigQuery-630"><a href="#BigQuery-630"><span class="linenos">630</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Rollback</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;ROLLBACK TRANSACTION&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-631"><a href="#BigQuery-631"><span class="linenos">631</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Select</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">(</span>
+</span><span id="BigQuery-632"><a href="#BigQuery-632"><span class="linenos">632</span></a> <span class="p">[</span>
+</span><span id="BigQuery-633"><a href="#BigQuery-633"><span class="linenos">633</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">explode_to_unnest</span><span class="p">(),</span>
+</span><span id="BigQuery-634"><a href="#BigQuery-634"><span class="linenos">634</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">unqualify_unnest</span><span class="p">,</span>
+</span><span id="BigQuery-635"><a href="#BigQuery-635"><span class="linenos">635</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_distinct_on</span><span class="p">,</span>
+</span><span id="BigQuery-636"><a href="#BigQuery-636"><span class="linenos">636</span></a> <span class="n">_alias_ordered_group</span><span class="p">,</span>
+</span><span id="BigQuery-637"><a href="#BigQuery-637"><span class="linenos">637</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_semi_and_anti_joins</span><span class="p">,</span>
+</span><span id="BigQuery-638"><a href="#BigQuery-638"><span class="linenos">638</span></a> <span class="p">]</span>
+</span><span id="BigQuery-639"><a href="#BigQuery-639"><span class="linenos">639</span></a> <span class="p">),</span>
+</span><span id="BigQuery-640"><a href="#BigQuery-640"><span class="linenos">640</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;SHA1&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-641"><a href="#BigQuery-641"><span class="linenos">641</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA2</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery-642"><a href="#BigQuery-642"><span class="linenos">642</span></a> <span class="s2">&quot;SHA256&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;length&quot;</span><span class="p">)</span> <span class="o">==</span> <span class="s2">&quot;256&quot;</span> <span class="k">else</span> <span class="s2">&quot;SHA512&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span>
+</span><span id="BigQuery-643"><a href="#BigQuery-643"><span class="linenos">643</span></a> <span class="p">),</span>
+</span><span id="BigQuery-644"><a href="#BigQuery-644"><span class="linenos">644</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StabilityProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
+</span><span id="BigQuery-645"><a href="#BigQuery-645"><span class="linenos">645</span></a> <span class="s2">&quot;DETERMINISTIC&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;IMMUTABLE&quot;</span> <span class="k">else</span> <span class="s2">&quot;NOT DETERMINISTIC&quot;</span>
+</span><span id="BigQuery-646"><a href="#BigQuery-646"><span class="linenos">646</span></a> <span class="p">),</span>
+</span><span id="BigQuery-647"><a href="#BigQuery-647"><span class="linenos">647</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToDate</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;PARSE_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">),</span>
+</span><span id="BigQuery-648"><a href="#BigQuery-648"><span class="linenos">648</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToTime</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery-649"><a href="#BigQuery-649"><span class="linenos">649</span></a> <span class="s2">&quot;PARSE_TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)</span>
+</span><span id="BigQuery-650"><a href="#BigQuery-650"><span class="linenos">650</span></a> <span class="p">),</span>
+</span><span id="BigQuery-651"><a href="#BigQuery-651"><span class="linenos">651</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-652"><a href="#BigQuery-652"><span class="linenos">652</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-653"><a href="#BigQuery-653"><span class="linenos">653</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-654"><a href="#BigQuery-654"><span class="linenos">654</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-655"><a href="#BigQuery-655"><span class="linenos">655</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampDiff</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP_DIFF&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-656"><a href="#BigQuery-656"><span class="linenos">656</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-657"><a href="#BigQuery-657"><span class="linenos">657</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeStrToTime</span><span class="p">:</span> <span class="n">timestrtotime_sql</span><span class="p">,</span>
+</span><span id="BigQuery-658"><a href="#BigQuery-658"><span class="linenos">658</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Transaction</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;BEGIN TRANSACTION&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-659"><a href="#BigQuery-659"><span class="linenos">659</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Trim</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TRIM&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">),</span>
+</span><span id="BigQuery-660"><a href="#BigQuery-660"><span class="linenos">660</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsAdd</span><span class="p">:</span> <span class="n">_ts_or_ds_add_sql</span><span class="p">,</span>
+</span><span id="BigQuery-661"><a href="#BigQuery-661"><span class="linenos">661</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsDiff</span><span class="p">:</span> <span class="n">_ts_or_ds_diff_sql</span><span class="p">,</span>
+</span><span id="BigQuery-662"><a href="#BigQuery-662"><span class="linenos">662</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToTime</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-663"><a href="#BigQuery-663"><span class="linenos">663</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Unhex</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;FROM_HEX&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-664"><a href="#BigQuery-664"><span class="linenos">664</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixDate</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;UNIX_DATE&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-665"><a href="#BigQuery-665"><span class="linenos">665</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixToTime</span><span class="p">:</span> <span class="n">_unix_to_time_sql</span><span class="p">,</span>
+</span><span id="BigQuery-666"><a href="#BigQuery-666"><span class="linenos">666</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Values</span><span class="p">:</span> <span class="n">_derived_table_values_to_unnest</span><span class="p">,</span>
+</span><span id="BigQuery-667"><a href="#BigQuery-667"><span class="linenos">667</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VariancePop</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;VAR_POP&quot;</span><span class="p">),</span>
+</span><span id="BigQuery-668"><a href="#BigQuery-668"><span class="linenos">668</span></a> <span class="p">}</span>
+</span><span id="BigQuery-669"><a href="#BigQuery-669"><span class="linenos">669</span></a>
+</span><span id="BigQuery-670"><a href="#BigQuery-670"><span class="linenos">670</span></a> <span class="n">SUPPORTED_JSON_PATH_PARTS</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="BigQuery-671"><a href="#BigQuery-671"><span class="linenos">671</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathKey</span><span class="p">,</span>
+</span><span id="BigQuery-672"><a href="#BigQuery-672"><span class="linenos">672</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathRoot</span><span class="p">,</span>
+</span><span id="BigQuery-673"><a href="#BigQuery-673"><span class="linenos">673</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathSubscript</span><span class="p">,</span>
+</span><span id="BigQuery-674"><a href="#BigQuery-674"><span class="linenos">674</span></a> <span class="p">}</span>
+</span><span id="BigQuery-675"><a href="#BigQuery-675"><span class="linenos">675</span></a>
+</span><span id="BigQuery-676"><a href="#BigQuery-676"><span class="linenos">676</span></a> <span class="n">TYPE_MAPPING</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="BigQuery-677"><a href="#BigQuery-677"><span class="linenos">677</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TYPE_MAPPING</span><span class="p">,</span>
+</span><span id="BigQuery-678"><a href="#BigQuery-678"><span class="linenos">678</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGDECIMAL</span><span class="p">:</span> <span class="s2">&quot;BIGNUMERIC&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-679"><a href="#BigQuery-679"><span class="linenos">679</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-680"><a href="#BigQuery-680"><span class="linenos">680</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-681"><a href="#BigQuery-681"><span class="linenos">681</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BOOLEAN</span><span class="p">:</span> <span class="s2">&quot;BOOL&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-682"><a href="#BigQuery-682"><span class="linenos">682</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">CHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-683"><a href="#BigQuery-683"><span class="linenos">683</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DECIMAL</span><span class="p">:</span> <span class="s2">&quot;NUMERIC&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-684"><a href="#BigQuery-684"><span class="linenos">684</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DOUBLE</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-685"><a href="#BigQuery-685"><span class="linenos">685</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">FLOAT</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-686"><a href="#BigQuery-686"><span class="linenos">686</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">INT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-687"><a href="#BigQuery-687"><span class="linenos">687</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-688"><a href="#BigQuery-688"><span class="linenos">688</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NVARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-689"><a href="#BigQuery-689"><span class="linenos">689</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">SMALLINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-690"><a href="#BigQuery-690"><span class="linenos">690</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TEXT</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-691"><a href="#BigQuery-691"><span class="linenos">691</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMP</span><span class="p">:</span> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-692"><a href="#BigQuery-692"><span class="linenos">692</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-693"><a href="#BigQuery-693"><span class="linenos">693</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPLTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-694"><a href="#BigQuery-694"><span class="linenos">694</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TINYINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-695"><a href="#BigQuery-695"><span class="linenos">695</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARBINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-696"><a href="#BigQuery-696"><span class="linenos">696</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">ROWVERSION</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-697"><a href="#BigQuery-697"><span class="linenos">697</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-698"><a href="#BigQuery-698"><span class="linenos">698</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARIANT</span><span class="p">:</span> <span class="s2">&quot;ANY TYPE&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-699"><a href="#BigQuery-699"><span class="linenos">699</span></a> <span class="p">}</span>
+</span><span id="BigQuery-700"><a href="#BigQuery-700"><span class="linenos">700</span></a>
+</span><span id="BigQuery-701"><a href="#BigQuery-701"><span class="linenos">701</span></a> <span class="n">PROPERTIES_LOCATION</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="BigQuery-702"><a href="#BigQuery-702"><span class="linenos">702</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">PROPERTIES_LOCATION</span><span class="p">,</span>
+</span><span id="BigQuery-703"><a href="#BigQuery-703"><span class="linenos">703</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">POST_SCHEMA</span><span class="p">,</span>
+</span><span id="BigQuery-704"><a href="#BigQuery-704"><span class="linenos">704</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VolatileProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">UNSUPPORTED</span><span class="p">,</span>
+</span><span id="BigQuery-705"><a href="#BigQuery-705"><span class="linenos">705</span></a> <span class="p">}</span>
+</span><span id="BigQuery-706"><a href="#BigQuery-706"><span class="linenos">706</span></a>
+</span><span id="BigQuery-707"><a href="#BigQuery-707"><span class="linenos">707</span></a> <span class="c1"># from: https://cloud.google.com/bigquery/docs/reference/standard-sql/lexical#reserved_keywords</span>
+</span><span id="BigQuery-708"><a href="#BigQuery-708"><span class="linenos">708</span></a> <span class="n">RESERVED_KEYWORDS</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="BigQuery-709"><a href="#BigQuery-709"><span class="linenos">709</span></a> <span class="o">*</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">RESERVED_KEYWORDS</span><span class="p">,</span>
+</span><span id="BigQuery-710"><a href="#BigQuery-710"><span class="linenos">710</span></a> <span class="s2">&quot;all&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-711"><a href="#BigQuery-711"><span class="linenos">711</span></a> <span class="s2">&quot;and&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-712"><a href="#BigQuery-712"><span class="linenos">712</span></a> <span class="s2">&quot;any&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-713"><a href="#BigQuery-713"><span class="linenos">713</span></a> <span class="s2">&quot;array&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-714"><a href="#BigQuery-714"><span class="linenos">714</span></a> <span class="s2">&quot;as&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-715"><a href="#BigQuery-715"><span class="linenos">715</span></a> <span class="s2">&quot;asc&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-716"><a href="#BigQuery-716"><span class="linenos">716</span></a> <span class="s2">&quot;assert_rows_modified&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-717"><a href="#BigQuery-717"><span class="linenos">717</span></a> <span class="s2">&quot;at&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-718"><a href="#BigQuery-718"><span class="linenos">718</span></a> <span class="s2">&quot;between&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-719"><a href="#BigQuery-719"><span class="linenos">719</span></a> <span class="s2">&quot;by&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-720"><a href="#BigQuery-720"><span class="linenos">720</span></a> <span class="s2">&quot;case&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-721"><a href="#BigQuery-721"><span class="linenos">721</span></a> <span class="s2">&quot;cast&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-722"><a href="#BigQuery-722"><span class="linenos">722</span></a> <span class="s2">&quot;collate&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-723"><a href="#BigQuery-723"><span class="linenos">723</span></a> <span class="s2">&quot;contains&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-724"><a href="#BigQuery-724"><span class="linenos">724</span></a> <span class="s2">&quot;create&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-725"><a href="#BigQuery-725"><span class="linenos">725</span></a> <span class="s2">&quot;cross&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-726"><a href="#BigQuery-726"><span class="linenos">726</span></a> <span class="s2">&quot;cube&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-727"><a href="#BigQuery-727"><span class="linenos">727</span></a> <span class="s2">&quot;current&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-728"><a href="#BigQuery-728"><span class="linenos">728</span></a> <span class="s2">&quot;default&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-729"><a href="#BigQuery-729"><span class="linenos">729</span></a> <span class="s2">&quot;define&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-730"><a href="#BigQuery-730"><span class="linenos">730</span></a> <span class="s2">&quot;desc&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-731"><a href="#BigQuery-731"><span class="linenos">731</span></a> <span class="s2">&quot;distinct&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-732"><a href="#BigQuery-732"><span class="linenos">732</span></a> <span class="s2">&quot;else&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-733"><a href="#BigQuery-733"><span class="linenos">733</span></a> <span class="s2">&quot;end&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-734"><a href="#BigQuery-734"><span class="linenos">734</span></a> <span class="s2">&quot;enum&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-735"><a href="#BigQuery-735"><span class="linenos">735</span></a> <span class="s2">&quot;escape&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-736"><a href="#BigQuery-736"><span class="linenos">736</span></a> <span class="s2">&quot;except&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-737"><a href="#BigQuery-737"><span class="linenos">737</span></a> <span class="s2">&quot;exclude&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-738"><a href="#BigQuery-738"><span class="linenos">738</span></a> <span class="s2">&quot;exists&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-739"><a href="#BigQuery-739"><span class="linenos">739</span></a> <span class="s2">&quot;extract&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-740"><a href="#BigQuery-740"><span class="linenos">740</span></a> <span class="s2">&quot;false&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-741"><a href="#BigQuery-741"><span class="linenos">741</span></a> <span class="s2">&quot;fetch&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-742"><a href="#BigQuery-742"><span class="linenos">742</span></a> <span class="s2">&quot;following&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-743"><a href="#BigQuery-743"><span class="linenos">743</span></a> <span class="s2">&quot;for&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-744"><a href="#BigQuery-744"><span class="linenos">744</span></a> <span class="s2">&quot;from&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-745"><a href="#BigQuery-745"><span class="linenos">745</span></a> <span class="s2">&quot;full&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-746"><a href="#BigQuery-746"><span class="linenos">746</span></a> <span class="s2">&quot;group&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-747"><a href="#BigQuery-747"><span class="linenos">747</span></a> <span class="s2">&quot;grouping&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-748"><a href="#BigQuery-748"><span class="linenos">748</span></a> <span class="s2">&quot;groups&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-749"><a href="#BigQuery-749"><span class="linenos">749</span></a> <span class="s2">&quot;hash&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-750"><a href="#BigQuery-750"><span class="linenos">750</span></a> <span class="s2">&quot;having&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-751"><a href="#BigQuery-751"><span class="linenos">751</span></a> <span class="s2">&quot;if&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-752"><a href="#BigQuery-752"><span class="linenos">752</span></a> <span class="s2">&quot;ignore&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-753"><a href="#BigQuery-753"><span class="linenos">753</span></a> <span class="s2">&quot;in&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-754"><a href="#BigQuery-754"><span class="linenos">754</span></a> <span class="s2">&quot;inner&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-755"><a href="#BigQuery-755"><span class="linenos">755</span></a> <span class="s2">&quot;intersect&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-756"><a href="#BigQuery-756"><span class="linenos">756</span></a> <span class="s2">&quot;interval&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-757"><a href="#BigQuery-757"><span class="linenos">757</span></a> <span class="s2">&quot;into&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-758"><a href="#BigQuery-758"><span class="linenos">758</span></a> <span class="s2">&quot;is&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-759"><a href="#BigQuery-759"><span class="linenos">759</span></a> <span class="s2">&quot;join&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-760"><a href="#BigQuery-760"><span class="linenos">760</span></a> <span class="s2">&quot;lateral&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-761"><a href="#BigQuery-761"><span class="linenos">761</span></a> <span class="s2">&quot;left&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-762"><a href="#BigQuery-762"><span class="linenos">762</span></a> <span class="s2">&quot;like&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-763"><a href="#BigQuery-763"><span class="linenos">763</span></a> <span class="s2">&quot;limit&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-764"><a href="#BigQuery-764"><span class="linenos">764</span></a> <span class="s2">&quot;lookup&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-765"><a href="#BigQuery-765"><span class="linenos">765</span></a> <span class="s2">&quot;merge&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-766"><a href="#BigQuery-766"><span class="linenos">766</span></a> <span class="s2">&quot;natural&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-767"><a href="#BigQuery-767"><span class="linenos">767</span></a> <span class="s2">&quot;new&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-768"><a href="#BigQuery-768"><span class="linenos">768</span></a> <span class="s2">&quot;no&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-769"><a href="#BigQuery-769"><span class="linenos">769</span></a> <span class="s2">&quot;not&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-770"><a href="#BigQuery-770"><span class="linenos">770</span></a> <span class="s2">&quot;null&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-771"><a href="#BigQuery-771"><span class="linenos">771</span></a> <span class="s2">&quot;nulls&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-772"><a href="#BigQuery-772"><span class="linenos">772</span></a> <span class="s2">&quot;of&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-773"><a href="#BigQuery-773"><span class="linenos">773</span></a> <span class="s2">&quot;on&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-774"><a href="#BigQuery-774"><span class="linenos">774</span></a> <span class="s2">&quot;or&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-775"><a href="#BigQuery-775"><span class="linenos">775</span></a> <span class="s2">&quot;order&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-776"><a href="#BigQuery-776"><span class="linenos">776</span></a> <span class="s2">&quot;outer&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-777"><a href="#BigQuery-777"><span class="linenos">777</span></a> <span class="s2">&quot;over&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-778"><a href="#BigQuery-778"><span class="linenos">778</span></a> <span class="s2">&quot;partition&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-779"><a href="#BigQuery-779"><span class="linenos">779</span></a> <span class="s2">&quot;preceding&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-780"><a href="#BigQuery-780"><span class="linenos">780</span></a> <span class="s2">&quot;proto&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-781"><a href="#BigQuery-781"><span class="linenos">781</span></a> <span class="s2">&quot;qualify&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-782"><a href="#BigQuery-782"><span class="linenos">782</span></a> <span class="s2">&quot;range&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-783"><a href="#BigQuery-783"><span class="linenos">783</span></a> <span class="s2">&quot;recursive&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-784"><a href="#BigQuery-784"><span class="linenos">784</span></a> <span class="s2">&quot;respect&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-785"><a href="#BigQuery-785"><span class="linenos">785</span></a> <span class="s2">&quot;right&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-786"><a href="#BigQuery-786"><span class="linenos">786</span></a> <span class="s2">&quot;rollup&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-787"><a href="#BigQuery-787"><span class="linenos">787</span></a> <span class="s2">&quot;rows&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-788"><a href="#BigQuery-788"><span class="linenos">788</span></a> <span class="s2">&quot;select&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-789"><a href="#BigQuery-789"><span class="linenos">789</span></a> <span class="s2">&quot;set&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-790"><a href="#BigQuery-790"><span class="linenos">790</span></a> <span class="s2">&quot;some&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-791"><a href="#BigQuery-791"><span class="linenos">791</span></a> <span class="s2">&quot;struct&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-792"><a href="#BigQuery-792"><span class="linenos">792</span></a> <span class="s2">&quot;tablesample&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-793"><a href="#BigQuery-793"><span class="linenos">793</span></a> <span class="s2">&quot;then&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-794"><a href="#BigQuery-794"><span class="linenos">794</span></a> <span class="s2">&quot;to&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-795"><a href="#BigQuery-795"><span class="linenos">795</span></a> <span class="s2">&quot;treat&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-796"><a href="#BigQuery-796"><span class="linenos">796</span></a> <span class="s2">&quot;true&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-797"><a href="#BigQuery-797"><span class="linenos">797</span></a> <span class="s2">&quot;unbounded&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-798"><a href="#BigQuery-798"><span class="linenos">798</span></a> <span class="s2">&quot;union&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-799"><a href="#BigQuery-799"><span class="linenos">799</span></a> <span class="s2">&quot;unnest&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-800"><a href="#BigQuery-800"><span class="linenos">800</span></a> <span class="s2">&quot;using&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-801"><a href="#BigQuery-801"><span class="linenos">801</span></a> <span class="s2">&quot;when&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-802"><a href="#BigQuery-802"><span class="linenos">802</span></a> <span class="s2">&quot;where&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-803"><a href="#BigQuery-803"><span class="linenos">803</span></a> <span class="s2">&quot;window&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-804"><a href="#BigQuery-804"><span class="linenos">804</span></a> <span class="s2">&quot;with&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-805"><a href="#BigQuery-805"><span class="linenos">805</span></a> <span class="s2">&quot;within&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-806"><a href="#BigQuery-806"><span class="linenos">806</span></a> <span class="p">}</span>
+</span><span id="BigQuery-807"><a href="#BigQuery-807"><span class="linenos">807</span></a>
+</span><span id="BigQuery-808"><a href="#BigQuery-808"><span class="linenos">808</span></a> <span class="k">def</span> <span class="nf">mod_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Mod</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-809"><a href="#BigQuery-809"><span class="linenos">809</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
+</span><span id="BigQuery-810"><a href="#BigQuery-810"><span class="linenos">810</span></a> <span class="n">expr</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expression</span>
+</span><span id="BigQuery-811"><a href="#BigQuery-811"><span class="linenos">811</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery-812"><a href="#BigQuery-812"><span class="linenos">812</span></a> <span class="s2">&quot;MOD&quot;</span><span class="p">,</span>
+</span><span id="BigQuery-813"><a href="#BigQuery-813"><span class="linenos">813</span></a> <span class="n">this</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">this</span><span class="p">,</span>
+</span><span id="BigQuery-814"><a href="#BigQuery-814"><span class="linenos">814</span></a> <span class="n">expr</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expr</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">expr</span><span class="p">,</span>
+</span><span id="BigQuery-815"><a href="#BigQuery-815"><span class="linenos">815</span></a> <span class="p">)</span>
+</span><span id="BigQuery-816"><a href="#BigQuery-816"><span class="linenos">816</span></a>
+</span><span id="BigQuery-817"><a href="#BigQuery-817"><span class="linenos">817</span></a> <span class="k">def</span> <span class="nf">column_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Column</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-818"><a href="#BigQuery-818"><span class="linenos">818</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_column&quot;</span><span class="p">):</span>
+</span><span id="BigQuery-819"><a href="#BigQuery-819"><span class="linenos">819</span></a> <span class="c1"># If a column reference is of the form `dataset.table`.name, we need</span>
+</span><span id="BigQuery-820"><a href="#BigQuery-820"><span class="linenos">820</span></a> <span class="c1"># to preserve the quoted table path, otherwise the reference breaks</span>
+</span><span id="BigQuery-821"><a href="#BigQuery-821"><span class="linenos">821</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">[:</span><span class="o">-</span><span class="mi">1</span><span class="p">])</span>
+</span><span id="BigQuery-822"><a href="#BigQuery-822"><span class="linenos">822</span></a> <span class="n">table_path</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">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+</span><span id="BigQuery-823"><a href="#BigQuery-823"><span class="linenos">823</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="n">table_path</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery-824"><a href="#BigQuery-824"><span class="linenos">824</span></a>
+</span><span id="BigQuery-825"><a href="#BigQuery-825"><span class="linenos">825</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">column_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="BigQuery-826"><a href="#BigQuery-826"><span class="linenos">826</span></a>
+</span><span id="BigQuery-827"><a href="#BigQuery-827"><span class="linenos">827</span></a> <span class="k">def</span> <span class="nf">table_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Table</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-828"><a href="#BigQuery-828"><span class="linenos">828</span></a> <span class="c1"># Depending on the context, `x.y` may not resolve to the same data source as `x`.`y`, so</span>
+</span><span id="BigQuery-829"><a href="#BigQuery-829"><span class="linenos">829</span></a> <span class="c1"># we need to make sure the correct quoting is used in each case.</span>
+</span><span id="BigQuery-830"><a href="#BigQuery-830"><span class="linenos">830</span></a> <span class="c1">#</span>
+</span><span id="BigQuery-831"><a href="#BigQuery-831"><span class="linenos">831</span></a> <span class="c1"># For example, if there is a CTE x that clashes with a schema name, then the former will</span>
+</span><span id="BigQuery-832"><a href="#BigQuery-832"><span class="linenos">832</span></a> <span class="c1"># return the table y in that schema, whereas the latter will return the CTE&#39;s y column:</span>
+</span><span id="BigQuery-833"><a href="#BigQuery-833"><span class="linenos">833</span></a> <span class="c1">#</span>
+</span><span id="BigQuery-834"><a href="#BigQuery-834"><span class="linenos">834</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x.y` -&gt; cross join</span>
+</span><span id="BigQuery-835"><a href="#BigQuery-835"><span class="linenos">835</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x`.`y` -&gt; implicit unnest</span>
+</span><span id="BigQuery-836"><a href="#BigQuery-836"><span class="linenos">836</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_table&quot;</span><span class="p">):</span>
+</span><span id="BigQuery-837"><a href="#BigQuery-837"><span class="linenos">837</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">)</span>
+</span><span id="BigQuery-838"><a href="#BigQuery-838"><span class="linenos">838</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+</span><span id="BigQuery-839"><a href="#BigQuery-839"><span class="linenos">839</span></a>
+</span><span id="BigQuery-840"><a href="#BigQuery-840"><span class="linenos">840</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">table_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="BigQuery-841"><a href="#BigQuery-841"><span class="linenos">841</span></a>
+</span><span id="BigQuery-842"><a href="#BigQuery-842"><span class="linenos">842</span></a> <span class="k">def</span> <span class="nf">timetostr_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TimeToStr</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-843"><a href="#BigQuery-843"><span class="linenos">843</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToDate</span><span class="p">)</span> <span class="k">else</span> <span class="n">expression</span>
+</span><span id="BigQuery-844"><a href="#BigQuery-844"><span class="linenos">844</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;FORMAT_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">expression</span><span class="p">),</span> <span class="n">this</span><span class="o">.</span><span class="n">this</span><span class="p">)</span>
+</span><span id="BigQuery-845"><a href="#BigQuery-845"><span class="linenos">845</span></a>
+</span><span id="BigQuery-846"><a href="#BigQuery-846"><span class="linenos">846</span></a> <span class="k">def</span> <span class="nf">eq_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">EQ</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-847"><a href="#BigQuery-847"><span class="linenos">847</span></a> <span class="c1"># Operands of = cannot be NULL in BigQuery</span>
+</span><span id="BigQuery-848"><a href="#BigQuery-848"><span class="linenos">848</span></a> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">left</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">)</span> <span class="ow">or</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">right</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">):</span>
+</span><span id="BigQuery-849"><a href="#BigQuery-849"><span class="linenos">849</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Update</span><span class="p">):</span>
+</span><span id="BigQuery-850"><a href="#BigQuery-850"><span class="linenos">850</span></a> <span class="k">return</span> <span class="s2">&quot;NULL&quot;</span>
+</span><span id="BigQuery-851"><a href="#BigQuery-851"><span class="linenos">851</span></a>
+</span><span id="BigQuery-852"><a href="#BigQuery-852"><span class="linenos">852</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">binary</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="s2">&quot;=&quot;</span><span class="p">)</span>
+</span><span id="BigQuery-853"><a href="#BigQuery-853"><span class="linenos">853</span></a>
+</span><span id="BigQuery-854"><a href="#BigQuery-854"><span class="linenos">854</span></a> <span class="k">def</span> <span class="nf">attimezone_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">AtTimeZone</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-855"><a href="#BigQuery-855"><span class="linenos">855</span></a> <span class="n">parent</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">parent</span>
+</span><span id="BigQuery-856"><a href="#BigQuery-856"><span class="linenos">856</span></a>
+</span><span id="BigQuery-857"><a href="#BigQuery-857"><span class="linenos">857</span></a> <span class="c1"># BigQuery allows CAST(.. AS {STRING|TIMESTAMP} [FORMAT &lt;fmt&gt; [AT TIME ZONE &lt;tz&gt;]]).</span>
+</span><span id="BigQuery-858"><a href="#BigQuery-858"><span class="linenos">858</span></a> <span class="c1"># Only the TIMESTAMP one should use the below conversion, when AT TIME ZONE is included.</span>
+</span><span id="BigQuery-859"><a href="#BigQuery-859"><span class="linenos">859</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">)</span> <span class="ow">or</span> <span class="ow">not</span> <span class="n">parent</span><span class="o">.</span><span class="n">to</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="s2">&quot;text&quot;</span><span class="p">):</span>
+</span><span id="BigQuery-860"><a href="#BigQuery-860"><span class="linenos">860</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery-861"><a href="#BigQuery-861"><span class="linenos">861</span></a> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">))</span>
+</span><span id="BigQuery-862"><a href="#BigQuery-862"><span class="linenos">862</span></a> <span class="p">)</span>
+</span><span id="BigQuery-863"><a href="#BigQuery-863"><span class="linenos">863</span></a>
+</span><span id="BigQuery-864"><a href="#BigQuery-864"><span class="linenos">864</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">attimezone_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="BigQuery-865"><a href="#BigQuery-865"><span class="linenos">865</span></a>
+</span><span id="BigQuery-866"><a href="#BigQuery-866"><span class="linenos">866</span></a> <span class="k">def</span> <span class="nf">trycast_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TryCast</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-867"><a href="#BigQuery-867"><span class="linenos">867</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">cast_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">safe_prefix</span><span class="o">=</span><span class="s2">&quot;SAFE_&quot;</span><span class="p">)</span>
+</span><span id="BigQuery-868"><a href="#BigQuery-868"><span class="linenos">868</span></a>
+</span><span id="BigQuery-869"><a href="#BigQuery-869"><span class="linenos">869</span></a> <span class="k">def</span> <span class="nf">bracket_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Bracket</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-870"><a href="#BigQuery-870"><span class="linenos">870</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
+</span><span id="BigQuery-871"><a href="#BigQuery-871"><span class="linenos">871</span></a> <span class="n">expressions</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expressions</span>
+</span><span id="BigQuery-872"><a href="#BigQuery-872"><span class="linenos">872</span></a>
+</span><span id="BigQuery-873"><a href="#BigQuery-873"><span class="linenos">873</span></a> <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">expressions</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> <span class="ow">and</span> <span class="n">this</span> <span class="ow">and</span> <span class="n">this</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">STRUCT</span><span class="p">):</span>
+</span><span id="BigQuery-874"><a href="#BigQuery-874"><span class="linenos">874</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">expressions</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
+</span><span id="BigQuery-875"><a href="#BigQuery-875"><span class="linenos">875</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">is</span> <span class="kc">None</span><span class="p">:</span>
+</span><span id="BigQuery-876"><a href="#BigQuery-876"><span class="linenos">876</span></a> <span class="kn">from</span> <span class="nn">sqlglot.optimizer.annotate_types</span> <span class="kn">import</span> <span class="n">annotate_types</span>
+</span><span id="BigQuery-877"><a href="#BigQuery-877"><span class="linenos">877</span></a>
+</span><span id="BigQuery-878"><a href="#BigQuery-878"><span class="linenos">878</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">annotate_types</span><span class="p">(</span><span class="n">arg</span><span class="p">)</span>
+</span><span id="BigQuery-879"><a href="#BigQuery-879"><span class="linenos">879</span></a>
+</span><span id="BigQuery-880"><a href="#BigQuery-880"><span class="linenos">880</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">and</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span><span class="o">.</span><span class="n">this</span> <span class="ow">in</span> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">TEXT_TYPES</span><span class="p">:</span>
+</span><span id="BigQuery-881"><a href="#BigQuery-881"><span class="linenos">881</span></a> <span class="c1"># BQ doesn&#39;t support bracket syntax with string values for structs</span>
+</span><span id="BigQuery-882"><a href="#BigQuery-882"><span class="linenos">882</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="n">arg</span><span class="o">.</span><span class="n">name</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery-883"><a href="#BigQuery-883"><span class="linenos">883</span></a>
+</span><span id="BigQuery-884"><a href="#BigQuery-884"><span class="linenos">884</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">expressions</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">flat</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
+</span><span id="BigQuery-885"><a href="#BigQuery-885"><span class="linenos">885</span></a> <span class="n">offset</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;offset&quot;</span><span class="p">)</span>
+</span><span id="BigQuery-886"><a href="#BigQuery-886"><span class="linenos">886</span></a>
+</span><span id="BigQuery-887"><a href="#BigQuery-887"><span class="linenos">887</span></a> <span class="k">if</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
+</span><span id="BigQuery-888"><a href="#BigQuery-888"><span class="linenos">888</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;OFFSET(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
+</span><span id="BigQuery-889"><a href="#BigQuery-889"><span class="linenos">889</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
+</span><span id="BigQuery-890"><a href="#BigQuery-890"><span class="linenos">890</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;ORDINAL(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
+</span><span id="BigQuery-891"><a href="#BigQuery-891"><span class="linenos">891</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
+</span><span id="BigQuery-892"><a href="#BigQuery-892"><span class="linenos">892</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Unsupported array offset: </span><span class="si">{</span><span class="n">offset</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">)</span>
+</span><span id="BigQuery-893"><a href="#BigQuery-893"><span class="linenos">893</span></a>
+</span><span id="BigQuery-894"><a href="#BigQuery-894"><span class="linenos">894</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;safe&quot;</span><span class="p">):</span>
+</span><span id="BigQuery-895"><a href="#BigQuery-895"><span class="linenos">895</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SAFE_</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery-896"><a href="#BigQuery-896"><span class="linenos">896</span></a>
+</span><span id="BigQuery-897"><a href="#BigQuery-897"><span class="linenos">897</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">[</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">]&quot;</span>
+</span><span id="BigQuery-898"><a href="#BigQuery-898"><span class="linenos">898</span></a>
+</span><span id="BigQuery-899"><a href="#BigQuery-899"><span class="linenos">899</span></a> <span class="k">def</span> <span class="nf">in_unnest_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Unnest</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-900"><a href="#BigQuery-900"><span class="linenos">900</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="BigQuery-901"><a href="#BigQuery-901"><span class="linenos">901</span></a>
+</span><span id="BigQuery-902"><a href="#BigQuery-902"><span class="linenos">902</span></a> <span class="k">def</span> <span class="nf">except_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Except</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-903"><a href="#BigQuery-903"><span class="linenos">903</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
+</span><span id="BigQuery-904"><a href="#BigQuery-904"><span class="linenos">904</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;EXCEPT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
+</span><span id="BigQuery-905"><a href="#BigQuery-905"><span class="linenos">905</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;EXCEPT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery-906"><a href="#BigQuery-906"><span class="linenos">906</span></a>
+</span><span id="BigQuery-907"><a href="#BigQuery-907"><span class="linenos">907</span></a> <span class="k">def</span> <span class="nf">intersect_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Intersect</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-908"><a href="#BigQuery-908"><span class="linenos">908</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
+</span><span id="BigQuery-909"><a href="#BigQuery-909"><span class="linenos">909</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;INTERSECT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
+</span><span id="BigQuery-910"><a href="#BigQuery-910"><span class="linenos">910</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;INTERSECT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery-911"><a href="#BigQuery-911"><span class="linenos">911</span></a>
+</span><span id="BigQuery-912"><a href="#BigQuery-912"><span class="linenos">912</span></a> <span class="k">def</span> <span class="nf">version_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Version</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery-913"><a href="#BigQuery-913"><span class="linenos">913</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">:</span>
+</span><span id="BigQuery-914"><a href="#BigQuery-914"><span class="linenos">914</span></a> <span class="n">expression</span><span class="o">.</span><span class="n">set</span><span class="p">(</span><span class="s2">&quot;this&quot;</span><span class="p">,</span> <span class="s2">&quot;SYSTEM_TIME&quot;</span><span class="p">)</span>
+</span><span id="BigQuery-915"><a href="#BigQuery-915"><span class="linenos">915</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">version_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
</span></pre></div>
@@ -2184,7 +2180,7 @@ If empty, the corresponding trie will be constructed off of <code><a href="#BigQ
<div id="BigQuery.PSEUDOCOLUMNS" class="classattr">
<div class="attr variable">
<span class="name">PSEUDOCOLUMNS</span><span class="annotation">: Set[str]</span> =
-<span class="default_value">{&#39;_PARTITIONTIME&#39;, &#39;_PARTITIONDATE&#39;}</span>
+<span class="default_value">{&#39;_PARTITIONDATE&#39;, &#39;_PARTITIONTIME&#39;}</span>
</div>
@@ -3081,7 +3077,7 @@ Default: 3</li>
<div class="attr variable">
<span class="name">NESTED_TYPE_TOKENS</span> =
<input id="BigQuery.Parser.NESTED_TYPE_TOKENS-view-value" class="view-value-toggle-state" type="checkbox" aria-hidden="true" tabindex="-1">
- <label class="view-value-button pdoc-button" for="BigQuery.Parser.NESTED_TYPE_TOKENS-view-value"></label><span class="default_value">{&lt;TokenType.TABLE: &#39;TABLE&#39;&gt;, &lt;TokenType.NULLABLE: &#39;NULLABLE&#39;&gt;, &lt;TokenType.MAP: &#39;MAP&#39;&gt;, &lt;TokenType.NESTED: &#39;NESTED&#39;&gt;, &lt;TokenType.OBJECT: &#39;OBJECT&#39;&gt;, &lt;TokenType.LOWCARDINALITY: &#39;LOWCARDINALITY&#39;&gt;, &lt;TokenType.ARRAY: &#39;ARRAY&#39;&gt;, &lt;TokenType.STRUCT: &#39;STRUCT&#39;&gt;}</span>
+ <label class="view-value-button pdoc-button" for="BigQuery.Parser.NESTED_TYPE_TOKENS-view-value"></label><span class="default_value">{&lt;TokenType.NESTED: &#39;NESTED&#39;&gt;, &lt;TokenType.ARRAY: &#39;ARRAY&#39;&gt;, &lt;TokenType.OBJECT: &#39;OBJECT&#39;&gt;, &lt;TokenType.LOWCARDINALITY: &#39;LOWCARDINALITY&#39;&gt;, &lt;TokenType.NULLABLE: &#39;NULLABLE&#39;&gt;, &lt;TokenType.STRUCT: &#39;STRUCT&#39;&gt;, &lt;TokenType.MAP: &#39;MAP&#39;&gt;, &lt;TokenType.TABLE: &#39;TABLE&#39;&gt;}</span>
</div>
@@ -3094,7 +3090,7 @@ Default: 3</li>
<div class="attr variable">
<span class="name">PROPERTY_PARSERS</span> =
<input id="BigQuery.Parser.PROPERTY_PARSERS-view-value" class="view-value-toggle-state" type="checkbox" aria-hidden="true" tabindex="-1">
- <label class="view-value-button pdoc-button" for="BigQuery.Parser.PROPERTY_PARSERS-view-value"></label><span class="default_value">{&#39;ALLOWED_VALUES&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ALGORITHM&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;AUTO&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;AUTO_INCREMENT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;BACKUP&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;BLOCKCOMPRESSION&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CHARSET&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CHARACTER SET&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CHECKSUM&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CLUSTER BY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CLUSTERED&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;COLLATE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;COMMENT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CONTAINS&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;COPY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DATABLOCKSIZE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DEFINER&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DETERMINISTIC&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DISTKEY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DISTSTYLE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ENGINE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;EXECUTE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;EXTERNAL&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;FALLBACK&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;FORMAT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;FREESPACE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;GLOBAL&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;HEAP&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ICEBERG&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;IMMUTABLE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;INHERITS&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;INPUT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;JOURNAL&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LANGUAGE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LAYOUT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LIFETIME&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LIKE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LOCATION&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LOCK&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LOCKING&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LOG&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;MATERIALIZED&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;MERGEBLOCKRATIO&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;MODIFIES&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;MULTISET&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;NO&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ON&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ORDER BY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;OUTPUT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;PARTITION&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;PARTITION BY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;PARTITIONED BY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;PARTITIONED_BY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;PRIMARY KEY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;RANGE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;READS&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;REMOTE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;RETURNS&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ROW&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ROW_FORMAT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SAMPLE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SET&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SETTINGS&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SHARING&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SORTKEY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SOURCE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;STABLE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;STORED&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SYSTEM_VERSIONING&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TBLPROPERTIES&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TEMP&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TEMPORARY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TO&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TRANSIENT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TRANSFORM&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TTL&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;USING&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;UNLOGGED&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;VOLATILE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;WITH&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;NOT DETERMINISTIC&#39;: &lt;function <a href="#BigQuery.Parser">BigQuery.Parser</a>.&lt;lambda&gt;&gt;, &#39;OPTIONS&#39;: &lt;function <a href="#BigQuery.Parser">BigQuery.Parser</a>.&lt;lambda&gt;&gt;}</span>
+ <label class="view-value-button pdoc-button" for="BigQuery.Parser.PROPERTY_PARSERS-view-value"></label><span class="default_value">{&#39;ALLOWED_VALUES&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ALGORITHM&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;AUTO&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;AUTO_INCREMENT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;BACKUP&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;BLOCKCOMPRESSION&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CHARSET&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CHARACTER SET&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CHECKSUM&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CLUSTER BY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CLUSTERED&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;COLLATE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;COMMENT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;CONTAINS&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;COPY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DATABLOCKSIZE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DATA_DELETION&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DEFINER&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DETERMINISTIC&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DISTKEY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;DISTSTYLE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ENGINE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;EXECUTE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;EXTERNAL&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;FALLBACK&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;FORMAT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;FREESPACE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;GLOBAL&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;HEAP&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ICEBERG&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;IMMUTABLE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;INHERITS&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;INPUT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;JOURNAL&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LANGUAGE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LAYOUT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LIFETIME&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LIKE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LOCATION&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LOCK&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LOCKING&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;LOG&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;MATERIALIZED&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;MERGEBLOCKRATIO&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;MODIFIES&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;MULTISET&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;NO&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ON&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ORDER BY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;OUTPUT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;PARTITION&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;PARTITION BY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;PARTITIONED BY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;PARTITIONED_BY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;PRIMARY KEY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;RANGE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;READS&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;REMOTE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;RETURNS&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;STRICT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ROW&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;ROW_FORMAT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SAMPLE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SET&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SETTINGS&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SHARING&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SORTKEY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SOURCE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;STABLE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;STORED&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;SYSTEM_VERSIONING&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TBLPROPERTIES&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TEMP&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TEMPORARY&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TO&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TRANSIENT&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TRANSFORM&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;TTL&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;USING&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;UNLOGGED&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;VOLATILE&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;WITH&#39;: &lt;function Parser.&lt;lambda&gt;&gt;, &#39;NOT DETERMINISTIC&#39;: &lt;function <a href="#BigQuery.Parser">BigQuery.Parser</a>.&lt;lambda&gt;&gt;, &#39;OPTIONS&#39;: &lt;function <a href="#BigQuery.Parser">BigQuery.Parser</a>.&lt;lambda&gt;&gt;}</span>
</div>
@@ -3132,7 +3128,7 @@ Default: 3</li>
<div id="BigQuery.Parser.NULL_TOKENS" class="classattr">
<div class="attr variable">
<span class="name">NULL_TOKENS</span> =
-<span class="default_value">{&lt;TokenType.NULL: &#39;NULL&#39;&gt;, &lt;TokenType.UNKNOWN: &#39;UNKNOWN&#39;&gt;}</span>
+<span class="default_value">{&lt;TokenType.UNKNOWN: &#39;UNKNOWN&#39;&gt;, &lt;TokenType.NULL: &#39;NULL&#39;&gt;}</span>
</div>
@@ -3170,7 +3166,7 @@ Default: 3</li>
<div class="attr variable">
<span class="name">TABLE_ALIAS_TOKENS</span> =
<input id="BigQuery.Parser.TABLE_ALIAS_TOKENS-view-value" class="view-value-toggle-state" type="checkbox" aria-hidden="true" tabindex="-1">
- <label class="view-value-button pdoc-button" for="BigQuery.Parser.TABLE_ALIAS_TOKENS-view-value"></label><span class="default_value">{&lt;TokenType.DICTIONARY: &#39;DICTIONARY&#39;&gt;, &lt;TokenType.AUTO_INCREMENT: &#39;AUTO_INCREMENT&#39;&gt;, &lt;TokenType.KEEP: &#39;KEEP&#39;&gt;, &lt;TokenType.INT8RANGE: &#39;INT8RANGE&#39;&gt;, &lt;TokenType.INET: &#39;INET&#39;&gt;, &lt;TokenType.MODEL: &#39;MODEL&#39;&gt;, &lt;TokenType.CURRENT_TIMESTAMP: &#39;CURRENT_TIMESTAMP&#39;&gt;, &lt;TokenType.JSONB: &#39;JSONB&#39;&gt;, &lt;TokenType.BIGDECIMAL: &#39;BIGDECIMAL&#39;&gt;, &lt;TokenType.ENUM8: &#39;ENUM8&#39;&gt;, &lt;TokenType.TIMESTAMP_NS: &#39;TIMESTAMP_NS&#39;&gt;, &lt;TokenType.LONGBLOB: &#39;LONGBLOB&#39;&gt;, &lt;TokenType.NCHAR: &#39;NCHAR&#39;&gt;, &lt;TokenType.NULLABLE: &#39;NULLABLE&#39;&gt;, &lt;TokenType.FILTER: &#39;FILTER&#39;&gt;, &lt;TokenType.SEQUENCE: &#39;SEQUENCE&#39;&gt;, &lt;TokenType.DECIMAL: &#39;DECIMAL&#39;&gt;, &lt;TokenType.SETTINGS: &#39;SETTINGS&#39;&gt;, &lt;TokenType.SOME: &#39;SOME&#39;&gt;, &lt;TokenType.ORDINALITY: &#39;ORDINALITY&#39;&gt;, &lt;TokenType.BIT: &#39;BIT&#39;&gt;, &lt;TokenType.TSRANGE: &#39;TSRANGE&#39;&gt;, &lt;TokenType.DATERANGE: &#39;DATERANGE&#39;&gt;, &lt;TokenType.SMALLMONEY: &#39;SMALLMONEY&#39;&gt;, &lt;TokenType.ARRAY: &#39;ARRAY&#39;&gt;, &lt;TokenType.OBJECT: &#39;OBJECT&#39;&gt;, &lt;TokenType.STORAGE_INTEGRATION: &#39;STORAGE_INTEGRATION&#39;&gt;, &lt;TokenType.COLLATE: &#39;COLLATE&#39;&gt;, &lt;TokenType.UNPIVOT: &#39;UNPIVOT&#39;&gt;, &lt;TokenType.SEMI: &#39;SEMI&#39;&gt;, &lt;TokenType.GEOMETRY: &#39;GEOMETRY&#39;&gt;, &lt;TokenType.GEOGRAPHY: &#39;GEOGRAPHY&#39;&gt;, &lt;TokenType.INT256: &#39;INT256&#39;&gt;, &lt;TokenType.CURRENT_DATETIME: &#39;CURRENT_DATETIME&#39;&gt;, &lt;TokenType.ENUM16: &#39;ENUM16&#39;&gt;, &lt;TokenType.PIVOT: &#39;PIVOT&#39;&gt;, &lt;TokenType.INT: &#39;INT&#39;&gt;, &lt;TokenType.DATABASE: &#39;DATABASE&#39;&gt;, &lt;TokenType.PERCENT: &#39;PERCENT&#39;&gt;, &lt;TokenType.FUNCTION: &#39;FUNCTION&#39;&gt;, &lt;TokenType.XML: &#39;XML&#39;&gt;, &lt;TokenType.BIGSERIAL: &#39;BIGSERIAL&#39;&gt;, &lt;TokenType.INT8MULTIRANGE: &#39;INT8MULTIRANGE&#39;&gt;, &lt;TokenType.SMALLSERIAL: &#39;SMALLSERIAL&#39;&gt;, &lt;TokenType.MERGE: &#39;MERGE&#39;&gt;, &lt;TokenType.NUMRANGE: &#39;NUMRANGE&#39;&gt;, &lt;TokenType.DATE: &#39;DATE&#39;&gt;, &lt;TokenType.TIMESTAMPLTZ: &#39;TIMESTAMPLTZ&#39;&gt;, &lt;TokenType.SMALLINT: &#39;SMALLINT&#39;&gt;, &lt;TokenType.RECURSIVE: &#39;RECURSIVE&#39;&gt;, &lt;TokenType.TINYBLOB: &#39;TINYBLOB&#39;&gt;, &lt;TokenType.FORMAT: &#39;FORMAT&#39;&gt;, &lt;TokenType.OBJECT_IDENTIFIER: &#39;OBJECT_IDENTIFIER&#39;&gt;, &lt;TokenType.USMALLINT: &#39;USMALLINT&#39;&gt;, &lt;TokenType.AGGREGATEFUNCTION: &#39;AGGREGATEFUNCTION&#39;&gt;, &lt;TokenType.COMMAND: &#39;COMMAND&#39;&gt;, &lt;TokenType.FIRST: &#39;FIRST&#39;&gt;, &lt;TokenType.FIXEDSTRING: &#39;FIXEDSTRING&#39;&gt;, &lt;TokenType.INT4MULTIRANGE: &#39;INT4MULTIRANGE&#39;&gt;, &lt;TokenType.DEFAULT: &#39;DEFAULT&#39;&gt;, &lt;TokenType.BINARY: &#39;BINARY&#39;&gt;, &lt;TokenType.PARTITION: &#39;PARTITION&#39;&gt;, &lt;TokenType.TAG: &#39;TAG&#39;&gt;, &lt;TokenType.USERDEFINED: &#39;USERDEFINED&#39;&gt;, &lt;TokenType.FLOAT: &#39;FLOAT&#39;&gt;, &lt;TokenType.TIMESTAMPTZ: &#39;TIMESTAMPTZ&#39;&gt;, &lt;TokenType.SHOW: &#39;SHOW&#39;&gt;, &lt;TokenType.SUPER: &#39;SUPER&#39;&gt;, &lt;TokenType.COLUMN: &#39;COLUMN&#39;&gt;, &lt;TokenType.BPCHAR: &#39;BPCHAR&#39;&gt;, &lt;TokenType.PROCEDURE: &#39;PROCEDURE&#39;&gt;, &lt;TokenType.VOLATILE: &#39;VOLATILE&#39;&gt;, &lt;TokenType.BIGINT: &#39;BIGINT&#39;&gt;, &lt;TokenType.DATETIME64: &#39;DATETIME64&#39;&gt;, &lt;TokenType.UINT: &#39;UINT&#39;&gt;, &lt;TokenType.VARBINARY: &#39;VARBINARY&#39;&gt;, &lt;TokenType.TIMESTAMP: &#39;TIMESTAMP&#39;&gt;, &lt;TokenType.TIMESTAMP_S: &#39;TIMESTAMP_S&#39;&gt;, &lt;TokenType.COMMENT: &#39;COMMENT&#39;&gt;, &lt;TokenType.DESC: &#39;DESC&#39;&gt;, &lt;TokenType.BOOLEAN: &#39;BOOLEAN&#39;&gt;, &lt;TokenType.TINYTEXT: &#39;TINYTEXT&#39;&gt;, &lt;TokenType.ROWVERSION: &#39;ROWVERSION&#39;&gt;, &lt;TokenType.REFERENCES: &#39;REFERENCES&#39;&gt;, &lt;TokenType.EXISTS: &#39;EXISTS&#39;&gt;, &lt;TokenType.STRUCT: &#39;STRUCT&#39;&gt;, &lt;TokenType.DESCRIBE: &#39;DESCRIBE&#39;&gt;, &lt;TokenType.PRAGMA: &#39;PRAGMA&#39;&gt;, &lt;TokenType.VIEW: &#39;VIEW&#39;&gt;, &lt;TokenType.DATEMULTIRANGE: &#39;DATEMULTIRANGE&#39;&gt;, &lt;TokenType.JSON: &#39;JSON&#39;&gt;, &lt;TokenType.LONGTEXT: &#39;LONGTEXT&#39;&gt;, &lt;TokenType.ESCAPE: &#39;ESCAPE&#39;&gt;, &lt;TokenType.INT4RANGE: &#39;INT4RANGE&#39;&gt;, &lt;TokenType.INTERVAL: &#39;INTERVAL&#39;&gt;, &lt;TokenType.SERIAL: &#39;SERIAL&#39;&gt;, &lt;TokenType.UPDATE: &#39;UPDATE&#39;&gt;, &lt;TokenType.DATETIME: &#39;DATETIME&#39;&gt;, &lt;TokenType.IPPREFIX: &#39;IPPREFIX&#39;&gt;, &lt;TokenType.ROWS: &#39;ROWS&#39;&gt;, &lt;TokenType.FALSE: &#39;FALSE&#39;&gt;, &lt;TokenType.VARCHAR: &#39;VARCHAR&#39;&gt;, &lt;TokenType.TIMETZ: &#39;TIMETZ&#39;&gt;, &lt;TokenType.ENUM: &#39;ENUM&#39;&gt;, &lt;TokenType.TSTZRANGE: &#39;TSTZRANGE&#39;&gt;, &lt;TokenType.CASE: &#39;CASE&#39;&gt;, &lt;TokenType.NESTED: &#39;NESTED&#39;&gt;, &lt;TokenType.ALL: &#39;ALL&#39;&gt;, &lt;TokenType.SIMPLEAGGREGATEFUNCTION: &#39;SIMPLEAGGREGATEFUNCTION&#39;&gt;, &lt;TokenType.USE: &#39;USE&#39;&gt;, &lt;TokenType.TINYINT: &#39;TINYINT&#39;&gt;, &lt;TokenType.SCHEMA: &#39;SCHEMA&#39;&gt;, &lt;TokenType.DELETE: &#39;DELETE&#39;&gt;, &lt;TokenType.OVERLAPS: &#39;OVERLAPS&#39;&gt;, &lt;TokenType.CONSTRAINT: &#39;CONSTRAINT&#39;&gt;, &lt;TokenType.IS: &#39;IS&#39;&gt;, &lt;TokenType.TDIGEST: &#39;TDIGEST&#39;&gt;, &lt;TokenType.UNIQUE: &#39;UNIQUE&#39;&gt;, &lt;TokenType.TABLE: &#39;TABLE&#39;&gt;, &lt;TokenType.MEDIUMINT: &#39;MEDIUMINT&#39;&gt;, &lt;TokenType.MEDIUMBLOB: &#39;MEDIUMBLOB&#39;&gt;, &lt;TokenType.TSMULTIRANGE: &#39;TSMULTIRANGE&#39;&gt;, &lt;TokenType.INT128: &#39;INT128&#39;&gt;, &lt;TokenType.UDECIMAL: &#39;UDECIMAL&#39;&gt;, &lt;TokenType.CURRENT_DATE: &#39;CURRENT_DATE&#39;&gt;, &lt;TokenType.YEAR: &#39;YEAR&#39;&gt;, &lt;TokenType.KILL: &#39;KILL&#39;&gt;, &lt;TokenType.TSTZMULTIRANGE: &#39;TSTZMULTIRANGE&#39;&gt;, &lt;TokenType.TIMESTAMP_MS: &#39;TIMESTAMP_MS&#39;&gt;, &lt;TokenType.EXECUTE: &#39;EXECUTE&#39;&gt;, &lt;TokenType.CURRENT_TIME: &#39;CURRENT_TIME&#39;&gt;, &lt;TokenType.SET: &#39;SET&#39;&gt;, &lt;TokenType.REPLACE: &#39;REPLACE&#39;&gt;, &lt;TokenType.FINAL: &#39;FINAL&#39;&gt;, &lt;TokenType.DIV: &#39;DIV&#39;&gt;, &lt;TokenType.ROLLUP: &#39;ROLLUP&#39;&gt;, &lt;TokenType.HLLSKETCH: &#39;HLLSKETCH&#39;&gt;, &lt;TokenType.UMEDIUMINT: &#39;UMEDIUMINT&#39;&gt;, &lt;TokenType.VARIANT: &#39;VARIANT&#39;&gt;, &lt;TokenType.LOWCARDINALITY: &#39;LOWCARDINALITY&#39;&gt;, &lt;TokenType.TIME: &#39;TIME&#39;&gt;, &lt;TokenType.DOUBLE: &#39;DOUBLE&#39;&gt;, &lt;TokenType.ISNULL: &#39;ISNULL&#39;&gt;, &lt;TokenType.CACHE: &#39;CACHE&#39;&gt;, &lt;TokenType.OPERATOR: &#39;OPERATOR&#39;&gt;, &lt;TokenType.IPV6: &#39;IPV6&#39;&gt;, &lt;TokenType.COPY: &#39;COPY&#39;&gt;, &lt;TokenType.NAME: &#39;NAME&#39;&gt;, &lt;TokenType.UBIGINT: &#39;UBIGINT&#39;&gt;, &lt;TokenType.BEGIN: &#39;BEGIN&#39;&gt;, &lt;TokenType.TOP: &#39;TOP&#39;&gt;, &lt;TokenType.NVARCHAR: &#39;NVARCHAR&#39;&gt;, &lt;TokenType.LOAD: &#39;LOAD&#39;&gt;, &lt;TokenType.FOREIGN_KEY: &#39;FOREIGN_KEY&#39;&gt;, &lt;TokenType.ANY: &#39;ANY&#39;&gt;, &lt;TokenType.PSEUDO_TYPE: &#39;PSEUDO_TYPE&#39;&gt;, &lt;TokenType.UINT256: &#39;UINT256&#39;&gt;, &lt;TokenType.MAP: &#39;MAP&#39;&gt;, &lt;TokenType.RANGE: &#39;RANGE&#39;&gt;, &lt;TokenType.UINT128: &#39;UINT128&#39;&gt;, &lt;TokenType.IPV4: &#39;IPV4&#39;&gt;, &lt;TokenType.TEXT: &#39;TEXT&#39;&gt;, &lt;TokenType.MEDIUMTEXT: &#39;MEDIUMTEXT&#39;&gt;, &lt;TokenType.IMAGE: &#39;IMAGE&#39;&gt;, &lt;TokenType.INDEX: &#39;INDEX&#39;&gt;, &lt;TokenType.MONEY: &#39;MONEY&#39;&gt;, &lt;TokenType.IPADDRESS: &#39;IPADDRESS&#39;&gt;, &lt;TokenType.NUMMULTIRANGE: &#39;NUMMULTIRANGE&#39;&gt;, &lt;TokenType.UNIQUEIDENTIFIER: &#39;UNIQUEIDENTIFIER&#39;&gt;, &lt;TokenType.VAR: &#39;VAR&#39;&gt;, &lt;TokenType.UNKNOWN: &#39;UNKNOWN&#39;&gt;, &lt;TokenType.TRUE: &#39;TRUE&#39;&gt;, &lt;TokenType.TIMESTAMPNTZ: &#39;TIMESTAMPNTZ&#39;&gt;, &lt;TokenType.UUID: &#39;UUID&#39;&gt;, &lt;TokenType.ROW: &#39;ROW&#39;&gt;, &lt;TokenType.TEMPORARY: &#39;TEMPORARY&#39;&gt;, &lt;TokenType.IDENTIFIER: &#39;IDENTIFIER&#39;&gt;, &lt;TokenType.CURRENT_USER: &#39;CURRENT_USER&#39;&gt;, &lt;TokenType.OVERWRITE: &#39;OVERWRITE&#39;&gt;, &lt;TokenType.CHAR: &#39;CHAR&#39;&gt;, &lt;TokenType.ASC: &#39;ASC&#39;&gt;, &lt;TokenType.NULL: &#39;NULL&#39;&gt;, &lt;TokenType.ANTI: &#39;ANTI&#39;&gt;, &lt;TokenType.HSTORE: &#39;HSTORE&#39;&gt;, &lt;TokenType.COMMIT: &#39;COMMIT&#39;&gt;, &lt;TokenType.REFRESH: &#39;REFRESH&#39;&gt;, &lt;TokenType.TRUNCATE: &#39;TRUNCATE&#39;&gt;, &lt;TokenType.END: &#39;END&#39;&gt;, &lt;TokenType.DATE32: &#39;DATE32&#39;&gt;, &lt;TokenType.NEXT: &#39;NEXT&#39;&gt;, &lt;TokenType.UTINYINT: &#39;UTINYINT&#39;&gt;}</span>
+ <label class="view-value-button pdoc-button" for="BigQuery.Parser.TABLE_ALIAS_TOKENS-view-value"></label><span class="default_value">{&lt;TokenType.KILL: &#39;KILL&#39;&gt;, &lt;TokenType.MONEY: &#39;MONEY&#39;&gt;, &lt;TokenType.COPY: &#39;COPY&#39;&gt;, &lt;TokenType.PERCENT: &#39;PERCENT&#39;&gt;, &lt;TokenType.TAG: &#39;TAG&#39;&gt;, &lt;TokenType.TSTZMULTIRANGE: &#39;TSTZMULTIRANGE&#39;&gt;, &lt;TokenType.VOLATILE: &#39;VOLATILE&#39;&gt;, &lt;TokenType.IDENTIFIER: &#39;IDENTIFIER&#39;&gt;, &lt;TokenType.VARBINARY: &#39;VARBINARY&#39;&gt;, &lt;TokenType.HSTORE: &#39;HSTORE&#39;&gt;, &lt;TokenType.ASC: &#39;ASC&#39;&gt;, &lt;TokenType.IPADDRESS: &#39;IPADDRESS&#39;&gt;, &lt;TokenType.ISNULL: &#39;ISNULL&#39;&gt;, &lt;TokenType.TEMPORARY: &#39;TEMPORARY&#39;&gt;, &lt;TokenType.PROCEDURE: &#39;PROCEDURE&#39;&gt;, &lt;TokenType.SCHEMA: &#39;SCHEMA&#39;&gt;, &lt;TokenType.NUMRANGE: &#39;NUMRANGE&#39;&gt;, &lt;TokenType.DATE32: &#39;DATE32&#39;&gt;, &lt;TokenType.INT8RANGE: &#39;INT8RANGE&#39;&gt;, &lt;TokenType.ANTI: &#39;ANTI&#39;&gt;, &lt;TokenType.AGGREGATEFUNCTION: &#39;AGGREGATEFUNCTION&#39;&gt;, &lt;TokenType.VIEW: &#39;VIEW&#39;&gt;, &lt;TokenType.VARCHAR: &#39;VARCHAR&#39;&gt;, &lt;TokenType.TIMETZ: &#39;TIMETZ&#39;&gt;, &lt;TokenType.GEOMETRY: &#39;GEOMETRY&#39;&gt;, &lt;TokenType.BEGIN: &#39;BEGIN&#39;&gt;, &lt;TokenType.ENUM8: &#39;ENUM8&#39;&gt;, &lt;TokenType.INDEX: &#39;INDEX&#39;&gt;, &lt;TokenType.PARTITION: &#39;PARTITION&#39;&gt;, &lt;TokenType.UINT256: &#39;UINT256&#39;&gt;, &lt;TokenType.BIGINT: &#39;BIGINT&#39;&gt;, &lt;TokenType.CACHE: &#39;CACHE&#39;&gt;, &lt;TokenType.OPERATOR: &#39;OPERATOR&#39;&gt;, &lt;TokenType.COLUMN: &#39;COLUMN&#39;&gt;, &lt;TokenType.INT128: &#39;INT128&#39;&gt;, &lt;TokenType.SMALLMONEY: &#39;SMALLMONEY&#39;&gt;, &lt;TokenType.HLLSKETCH: &#39;HLLSKETCH&#39;&gt;, &lt;TokenType.UNPIVOT: &#39;UNPIVOT&#39;&gt;, &lt;TokenType.SMALLINT: &#39;SMALLINT&#39;&gt;, &lt;TokenType.INT256: &#39;INT256&#39;&gt;, &lt;TokenType.FLOAT: &#39;FLOAT&#39;&gt;, &lt;TokenType.COMMIT: &#39;COMMIT&#39;&gt;, &lt;TokenType.NUMMULTIRANGE: &#39;NUMMULTIRANGE&#39;&gt;, &lt;TokenType.EXISTS: &#39;EXISTS&#39;&gt;, &lt;TokenType.NULL: &#39;NULL&#39;&gt;, &lt;TokenType.RECURSIVE: &#39;RECURSIVE&#39;&gt;, &lt;TokenType.SET: &#39;SET&#39;&gt;, &lt;TokenType.NULLABLE: &#39;NULLABLE&#39;&gt;, &lt;TokenType.REFRESH: &#39;REFRESH&#39;&gt;, &lt;TokenType.TINYTEXT: &#39;TINYTEXT&#39;&gt;, &lt;TokenType.SHOW: &#39;SHOW&#39;&gt;, &lt;TokenType.DEFAULT: &#39;DEFAULT&#39;&gt;, &lt;TokenType.DATE: &#39;DATE&#39;&gt;, &lt;TokenType.TIMESTAMPLTZ: &#39;TIMESTAMPLTZ&#39;&gt;, &lt;TokenType.MERGE: &#39;MERGE&#39;&gt;, &lt;TokenType.FIRST: &#39;FIRST&#39;&gt;, &lt;TokenType.BINARY: &#39;BINARY&#39;&gt;, &lt;TokenType.ARRAY: &#39;ARRAY&#39;&gt;, &lt;TokenType.SERIAL: &#39;SERIAL&#39;&gt;, &lt;TokenType.EXECUTE: &#39;EXECUTE&#39;&gt;, &lt;TokenType.TIMESTAMPNTZ: &#39;TIMESTAMPNTZ&#39;&gt;, &lt;TokenType.INTERVAL: &#39;INTERVAL&#39;&gt;, &lt;TokenType.PRAGMA: &#39;PRAGMA&#39;&gt;, &lt;TokenType.STORAGE_INTEGRATION: &#39;STORAGE_INTEGRATION&#39;&gt;, &lt;TokenType.BPCHAR: &#39;BPCHAR&#39;&gt;, &lt;TokenType.BIT: &#39;BIT&#39;&gt;, &lt;TokenType.UINT: &#39;UINT&#39;&gt;, &lt;TokenType.UUID: &#39;UUID&#39;&gt;, &lt;TokenType.STRUCT: &#39;STRUCT&#39;&gt;, &lt;TokenType.FALSE: &#39;FALSE&#39;&gt;, &lt;TokenType.FUNCTION: &#39;FUNCTION&#39;&gt;, &lt;TokenType.TOP: &#39;TOP&#39;&gt;, &lt;TokenType.SUPER: &#39;SUPER&#39;&gt;, &lt;TokenType.CASE: &#39;CASE&#39;&gt;, &lt;TokenType.IMAGE: &#39;IMAGE&#39;&gt;, &lt;TokenType.UBIGINT: &#39;UBIGINT&#39;&gt;, &lt;TokenType.LONGBLOB: &#39;LONGBLOB&#39;&gt;, &lt;TokenType.ROLLUP: &#39;ROLLUP&#39;&gt;, &lt;TokenType.VAR: &#39;VAR&#39;&gt;, &lt;TokenType.COMMAND: &#39;COMMAND&#39;&gt;, &lt;TokenType.LOAD: &#39;LOAD&#39;&gt;, &lt;TokenType.TRUNCATE: &#39;TRUNCATE&#39;&gt;, &lt;TokenType.KEEP: &#39;KEEP&#39;&gt;, &lt;TokenType.UMEDIUMINT: &#39;UMEDIUMINT&#39;&gt;, &lt;TokenType.OBJECT_IDENTIFIER: &#39;OBJECT_IDENTIFIER&#39;&gt;, &lt;TokenType.UINT128: &#39;UINT128&#39;&gt;, &lt;TokenType.END: &#39;END&#39;&gt;, &lt;TokenType.MAP: &#39;MAP&#39;&gt;, &lt;TokenType.IPV4: &#39;IPV4&#39;&gt;, &lt;TokenType.USERDEFINED: &#39;USERDEFINED&#39;&gt;, &lt;TokenType.REFERENCES: &#39;REFERENCES&#39;&gt;, &lt;TokenType.REPLACE: &#39;REPLACE&#39;&gt;, &lt;TokenType.RANGE: &#39;RANGE&#39;&gt;, &lt;TokenType.NVARCHAR: &#39;NVARCHAR&#39;&gt;, &lt;TokenType.INT4MULTIRANGE: &#39;INT4MULTIRANGE&#39;&gt;, &lt;TokenType.TRUE: &#39;TRUE&#39;&gt;, &lt;TokenType.TIMESTAMP_MS: &#39;TIMESTAMP_MS&#39;&gt;, &lt;TokenType.VARIANT: &#39;VARIANT&#39;&gt;, &lt;TokenType.ENUM: &#39;ENUM&#39;&gt;, &lt;TokenType.USE: &#39;USE&#39;&gt;, &lt;TokenType.USMALLINT: &#39;USMALLINT&#39;&gt;, &lt;TokenType.OVERLAPS: &#39;OVERLAPS&#39;&gt;, &lt;TokenType.TIMESTAMP_S: &#39;TIMESTAMP_S&#39;&gt;, &lt;TokenType.CURRENT_TIMESTAMP: &#39;CURRENT_TIMESTAMP&#39;&gt;, &lt;TokenType.UNIQUE: &#39;UNIQUE&#39;&gt;, &lt;TokenType.ORDINALITY: &#39;ORDINALITY&#39;&gt;, &lt;TokenType.UNIQUEIDENTIFIER: &#39;UNIQUEIDENTIFIER&#39;&gt;, &lt;TokenType.TEXT: &#39;TEXT&#39;&gt;, &lt;TokenType.DATABASE: &#39;DATABASE&#39;&gt;, &lt;TokenType.BIGDECIMAL: &#39;BIGDECIMAL&#39;&gt;, &lt;TokenType.PSEUDO_TYPE: &#39;PSEUDO_TYPE&#39;&gt;, &lt;TokenType.FIXEDSTRING: &#39;FIXEDSTRING&#39;&gt;, &lt;TokenType.NEXT: &#39;NEXT&#39;&gt;, &lt;TokenType.INT: &#39;INT&#39;&gt;, &lt;TokenType.BIGSERIAL: &#39;BIGSERIAL&#39;&gt;, &lt;TokenType.BOOLEAN: &#39;BOOLEAN&#39;&gt;, &lt;TokenType.IS: &#39;IS&#39;&gt;, &lt;TokenType.CONSTRAINT: &#39;CONSTRAINT&#39;&gt;, &lt;TokenType.FINAL: &#39;FINAL&#39;&gt;, &lt;TokenType.UNKNOWN: &#39;UNKNOWN&#39;&gt;, &lt;TokenType.SETTINGS: &#39;SETTINGS&#39;&gt;, &lt;TokenType.ROWS: &#39;ROWS&#39;&gt;, &lt;TokenType.TSTZRANGE: &#39;TSTZRANGE&#39;&gt;, &lt;TokenType.DATETIME64: &#39;DATETIME64&#39;&gt;, &lt;TokenType.MEDIUMBLOB: &#39;MEDIUMBLOB&#39;&gt;, &lt;TokenType.DATETIME: &#39;DATETIME&#39;&gt;, &lt;TokenType.MEDIUMINT: &#39;MEDIUMINT&#39;&gt;, &lt;TokenType.TIMESTAMP: &#39;TIMESTAMP&#39;&gt;, &lt;TokenType.TSMULTIRANGE: &#39;TSMULTIRANGE&#39;&gt;, &lt;TokenType.XML: &#39;XML&#39;&gt;, &lt;TokenType.JSON: &#39;JSON&#39;&gt;, &lt;TokenType.UTINYINT: &#39;UTINYINT&#39;&gt;, &lt;TokenType.DELETE: &#39;DELETE&#39;&gt;, &lt;TokenType.TIME: &#39;TIME&#39;&gt;, &lt;TokenType.UDECIMAL: &#39;UDECIMAL&#39;&gt;, &lt;TokenType.NESTED: &#39;NESTED&#39;&gt;, &lt;TokenType.SEMI: &#39;SEMI&#39;&gt;, &lt;TokenType.DESC: &#39;DESC&#39;&gt;, &lt;TokenType.ROWVERSION: &#39;ROWVERSION&#39;&gt;, &lt;TokenType.TIMESTAMP_NS: &#39;TIMESTAMP_NS&#39;&gt;, &lt;TokenType.ANY: &#39;ANY&#39;&gt;, &lt;TokenType.DIV: &#39;DIV&#39;&gt;, &lt;TokenType.DICTIONARY: &#39;DICTIONARY&#39;&gt;, &lt;TokenType.INET: &#39;INET&#39;&gt;, &lt;TokenType.INT8MULTIRANGE: &#39;INT8MULTIRANGE&#39;&gt;, &lt;TokenType.COMMENT: &#39;COMMENT&#39;&gt;, &lt;TokenType.CURRENT_USER: &#39;CURRENT_USER&#39;&gt;, &lt;TokenType.SIMPLEAGGREGATEFUNCTION: &#39;SIMPLEAGGREGATEFUNCTION&#39;&gt;, &lt;TokenType.ALL: &#39;ALL&#39;&gt;, &lt;TokenType.NAME: &#39;NAME&#39;&gt;, &lt;TokenType.SOME: &#39;SOME&#39;&gt;, &lt;TokenType.ENUM16: &#39;ENUM16&#39;&gt;, &lt;TokenType.YEAR: &#39;YEAR&#39;&gt;, &lt;TokenType.GEOGRAPHY: &#39;GEOGRAPHY&#39;&gt;, &lt;TokenType.DOUBLE: &#39;DOUBLE&#39;&gt;, &lt;TokenType.INT4RANGE: &#39;INT4RANGE&#39;&gt;, &lt;TokenType.FORMAT: &#39;FORMAT&#39;&gt;, &lt;TokenType.FOREIGN_KEY: &#39;FOREIGN_KEY&#39;&gt;, &lt;TokenType.AUTO_INCREMENT: &#39;AUTO_INCREMENT&#39;&gt;, &lt;TokenType.IPPREFIX: &#39;IPPREFIX&#39;&gt;, &lt;TokenType.OVERWRITE: &#39;OVERWRITE&#39;&gt;, &lt;TokenType.CURRENT_DATETIME: &#39;CURRENT_DATETIME&#39;&gt;, &lt;TokenType.COLLATE: &#39;COLLATE&#39;&gt;, &lt;TokenType.FILTER: &#39;FILTER&#39;&gt;, &lt;TokenType.JSONB: &#39;JSONB&#39;&gt;, &lt;TokenType.TDIGEST: &#39;TDIGEST&#39;&gt;, &lt;TokenType.CHAR: &#39;CHAR&#39;&gt;, &lt;TokenType.MEDIUMTEXT: &#39;MEDIUMTEXT&#39;&gt;, &lt;TokenType.LOWCARDINALITY: &#39;LOWCARDINALITY&#39;&gt;, &lt;TokenType.ROW: &#39;ROW&#39;&gt;, &lt;TokenType.SMALLSERIAL: &#39;SMALLSERIAL&#39;&gt;, &lt;TokenType.OBJECT: &#39;OBJECT&#39;&gt;, &lt;TokenType.TIMESTAMPTZ: &#39;TIMESTAMPTZ&#39;&gt;, &lt;TokenType.TABLE: &#39;TABLE&#39;&gt;, &lt;TokenType.DATERANGE: &#39;DATERANGE&#39;&gt;, &lt;TokenType.TSRANGE: &#39;TSRANGE&#39;&gt;, &lt;TokenType.ESCAPE: &#39;ESCAPE&#39;&gt;, &lt;TokenType.PIVOT: &#39;PIVOT&#39;&gt;, &lt;TokenType.DECIMAL: &#39;DECIMAL&#39;&gt;, &lt;TokenType.NCHAR: &#39;NCHAR&#39;&gt;, &lt;TokenType.DATEMULTIRANGE: &#39;DATEMULTIRANGE&#39;&gt;, &lt;TokenType.UPDATE: &#39;UPDATE&#39;&gt;, &lt;TokenType.MODEL: &#39;MODEL&#39;&gt;, &lt;TokenType.CURRENT_DATE: &#39;CURRENT_DATE&#39;&gt;, &lt;TokenType.SEQUENCE: &#39;SEQUENCE&#39;&gt;, &lt;TokenType.LONGTEXT: &#39;LONGTEXT&#39;&gt;, &lt;TokenType.DESCRIBE: &#39;DESCRIBE&#39;&gt;, &lt;TokenType.IPV6: &#39;IPV6&#39;&gt;, &lt;TokenType.CURRENT_TIME: &#39;CURRENT_TIME&#39;&gt;, &lt;TokenType.TINYINT: &#39;TINYINT&#39;&gt;, &lt;TokenType.TINYBLOB: &#39;TINYBLOB&#39;&gt;}</span>
</div>
@@ -3295,6 +3291,7 @@ Default: 3</li>
<dd id="BigQuery.Parser.UNION_MODIFIERS" class="variable"><a href="../parser.html#Parser.UNION_MODIFIERS">UNION_MODIFIERS</a></dd>
<dd id="BigQuery.Parser.NO_PAREN_IF_COMMANDS" class="variable"><a href="../parser.html#Parser.NO_PAREN_IF_COMMANDS">NO_PAREN_IF_COMMANDS</a></dd>
<dd id="BigQuery.Parser.JSON_ARROWS_REQUIRE_JSON_TYPE" class="variable"><a href="../parser.html#Parser.JSON_ARROWS_REQUIRE_JSON_TYPE">JSON_ARROWS_REQUIRE_JSON_TYPE</a></dd>
+ <dd id="BigQuery.Parser.COLON_IS_JSON_EXTRACT" class="variable"><a href="../parser.html#Parser.COLON_IS_JSON_EXTRACT">COLON_IS_JSON_EXTRACT</a></dd>
<dd id="BigQuery.Parser.VALUES_FOLLOWED_BY_PAREN" class="variable"><a href="../parser.html#Parser.VALUES_FOLLOWED_BY_PAREN">VALUES_FOLLOWED_BY_PAREN</a></dd>
<dd id="BigQuery.Parser.INTERVAL_SPANS" class="variable"><a href="../parser.html#Parser.INTERVAL_SPANS">INTERVAL_SPANS</a></dd>
<dd id="BigQuery.Parser.SUPPORTS_PARTITION_SELECTION" class="variable"><a href="../parser.html#Parser.SUPPORTS_PARTITION_SELECTION">SUPPORTS_PARTITION_SELECTION</a></dd>
@@ -3349,350 +3346,348 @@ Default: 3</li>
</span><span id="BigQuery.Generator-571"><a href="#BigQuery.Generator-571"><span class="linenos">571</span></a> <span class="n">SUPPORTS_TO_NUMBER</span> <span class="o">=</span> <span class="kc">False</span>
</span><span id="BigQuery.Generator-572"><a href="#BigQuery.Generator-572"><span class="linenos">572</span></a> <span class="n">NAMED_PLACEHOLDER_TOKEN</span> <span class="o">=</span> <span class="s2">&quot;@&quot;</span>
</span><span id="BigQuery.Generator-573"><a href="#BigQuery.Generator-573"><span class="linenos">573</span></a> <span class="n">HEX_FUNC</span> <span class="o">=</span> <span class="s2">&quot;TO_HEX&quot;</span>
-</span><span id="BigQuery.Generator-574"><a href="#BigQuery.Generator-574"><span class="linenos">574</span></a>
-</span><span id="BigQuery.Generator-575"><a href="#BigQuery.Generator-575"><span class="linenos">575</span></a> <span class="n">TRANSFORMS</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="BigQuery.Generator-576"><a href="#BigQuery.Generator-576"><span class="linenos">576</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TRANSFORMS</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-577"><a href="#BigQuery.Generator-577"><span class="linenos">577</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ApproxDistinct</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;APPROX_COUNT_DISTINCT&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-578"><a href="#BigQuery.Generator-578"><span class="linenos">578</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMax</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MAX_BY&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-579"><a href="#BigQuery.Generator-579"><span class="linenos">579</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMin</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MIN_BY&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-580"><a href="#BigQuery.Generator-580"><span class="linenos">580</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Array</span><span class="p">:</span> <span class="n">inline_array_unless_query</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-581"><a href="#BigQuery.Generator-581"><span class="linenos">581</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayContains</span><span class="p">:</span> <span class="n">_array_contains_sql</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-582"><a href="#BigQuery.Generator-582"><span class="linenos">582</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayFilter</span><span class="p">:</span> <span class="n">filter_array_using_unnest</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-583"><a href="#BigQuery.Generator-583"><span class="linenos">583</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArraySize</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;ARRAY_LENGTH&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-584"><a href="#BigQuery.Generator-584"><span class="linenos">584</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">transforms</span><span class="o">.</span><span class="n">remove_precision_parameterized_types</span><span class="p">]),</span>
-</span><span id="BigQuery.Generator-585"><a href="#BigQuery.Generator-585"><span class="linenos">585</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CollateProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
-</span><span id="BigQuery.Generator-586"><a href="#BigQuery.Generator-586"><span class="linenos">586</span></a> <span class="sa">f</span><span class="s2">&quot;DEFAULT COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery.Generator-587"><a href="#BigQuery.Generator-587"><span class="linenos">587</span></a> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;default&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-588"><a href="#BigQuery.Generator-588"><span class="linenos">588</span></a> <span class="k">else</span> <span class="sa">f</span><span class="s2">&quot;COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery.Generator-589"><a href="#BigQuery.Generator-589"><span class="linenos">589</span></a> <span class="p">),</span>
-</span><span id="BigQuery.Generator-590"><a href="#BigQuery.Generator-590"><span class="linenos">590</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Commit</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;COMMIT TRANSACTION&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-591"><a href="#BigQuery.Generator-591"><span class="linenos">591</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CountIf</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;COUNTIF&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-592"><a href="#BigQuery.Generator-592"><span class="linenos">592</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Create</span><span class="p">:</span> <span class="n">_create_sql</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-593"><a href="#BigQuery.Generator-593"><span class="linenos">593</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CTE</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">_pushdown_cte_column_names</span><span class="p">]),</span>
-</span><span id="BigQuery.Generator-594"><a href="#BigQuery.Generator-594"><span class="linenos">594</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-595"><a href="#BigQuery.Generator-595"><span class="linenos">595</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateDiff</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery.Generator-596"><a href="#BigQuery.Generator-596"><span class="linenos">596</span></a> <span class="s2">&quot;DATE_DIFF&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span> <span class="n">unit_to_var</span><span class="p">(</span><span class="n">e</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-597"><a href="#BigQuery.Generator-597"><span class="linenos">597</span></a> <span class="p">),</span>
-</span><span id="BigQuery.Generator-598"><a href="#BigQuery.Generator-598"><span class="linenos">598</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-599"><a href="#BigQuery.Generator-599"><span class="linenos">599</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateStrToDate</span><span class="p">:</span> <span class="n">datestrtodate_sql</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-600"><a href="#BigQuery.Generator-600"><span class="linenos">600</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-601"><a href="#BigQuery.Generator-601"><span class="linenos">601</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-602"><a href="#BigQuery.Generator-602"><span class="linenos">602</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-603"><a href="#BigQuery.Generator-603"><span class="linenos">603</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateTrunc</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATE_TRUNC&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;unit&quot;</span><span class="p">)),</span>
-</span><span id="BigQuery.Generator-604"><a href="#BigQuery.Generator-604"><span class="linenos">604</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">FromTimeZone</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery.Generator-605"><a href="#BigQuery.Generator-605"><span class="linenos">605</span></a> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)),</span> <span class="s2">&quot;&#39;UTC&#39;&quot;</span>
-</span><span id="BigQuery.Generator-606"><a href="#BigQuery.Generator-606"><span class="linenos">606</span></a> <span class="p">),</span>
-</span><span id="BigQuery.Generator-607"><a href="#BigQuery.Generator-607"><span class="linenos">607</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GenerateSeries</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;GENERATE_ARRAY&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-608"><a href="#BigQuery.Generator-608"><span class="linenos">608</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GroupConcat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;STRING_AGG&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-609"><a href="#BigQuery.Generator-609"><span class="linenos">609</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Hex</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;UPPER&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&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">e</span><span class="p">,</span> <span class="s2">&quot;this&quot;</span><span class="p">))),</span>
-</span><span id="BigQuery.Generator-610"><a href="#BigQuery.Generator-610"><span class="linenos">610</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">If</span><span class="p">:</span> <span class="n">if_sql</span><span class="p">(</span><span class="n">false_value</span><span class="o">=</span><span class="s2">&quot;NULL&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-611"><a href="#BigQuery.Generator-611"><span class="linenos">611</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ILike</span><span class="p">:</span> <span class="n">no_ilike_sql</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-612"><a href="#BigQuery.Generator-612"><span class="linenos">612</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">IntDiv</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DIV&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-613"><a href="#BigQuery.Generator-613"><span class="linenos">613</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONFormat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TO_JSON_STRING&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-614"><a href="#BigQuery.Generator-614"><span class="linenos">614</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Max</span><span class="p">:</span> <span class="n">max_or_greatest</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-615"><a href="#BigQuery.Generator-615"><span class="linenos">615</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">)),</span>
-</span><span id="BigQuery.Generator-616"><a href="#BigQuery.Generator-616"><span class="linenos">616</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5Digest</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-617"><a href="#BigQuery.Generator-617"><span class="linenos">617</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Min</span><span class="p">:</span> <span class="n">min_or_least</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-618"><a href="#BigQuery.Generator-618"><span class="linenos">618</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="sa">f</span><span class="s2">&quot;PARTITION BY </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-619"><a href="#BigQuery.Generator-619"><span class="linenos">619</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpExtract</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery.Generator-620"><a href="#BigQuery.Generator-620"><span class="linenos">620</span></a> <span class="s2">&quot;REGEXP_EXTRACT&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-621"><a href="#BigQuery.Generator-621"><span class="linenos">621</span></a> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-622"><a href="#BigQuery.Generator-622"><span class="linenos">622</span></a> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-623"><a href="#BigQuery.Generator-623"><span class="linenos">623</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;position&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-624"><a href="#BigQuery.Generator-624"><span class="linenos">624</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;occurrence&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-625"><a href="#BigQuery.Generator-625"><span class="linenos">625</span></a> <span class="p">),</span>
-</span><span id="BigQuery.Generator-626"><a href="#BigQuery.Generator-626"><span class="linenos">626</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpReplace</span><span class="p">:</span> <span class="n">regexp_replace_sql</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-627"><a href="#BigQuery.Generator-627"><span class="linenos">627</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpLike</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;REGEXP_CONTAINS&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-628"><a href="#BigQuery.Generator-628"><span class="linenos">628</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ReturnsProperty</span><span class="p">:</span> <span class="n">_returnsproperty_sql</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-629"><a href="#BigQuery.Generator-629"><span class="linenos">629</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Rollback</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;ROLLBACK TRANSACTION&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-630"><a href="#BigQuery.Generator-630"><span class="linenos">630</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Select</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">(</span>
-</span><span id="BigQuery.Generator-631"><a href="#BigQuery.Generator-631"><span class="linenos">631</span></a> <span class="p">[</span>
-</span><span id="BigQuery.Generator-632"><a href="#BigQuery.Generator-632"><span class="linenos">632</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">explode_to_unnest</span><span class="p">(),</span>
-</span><span id="BigQuery.Generator-633"><a href="#BigQuery.Generator-633"><span class="linenos">633</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">unqualify_unnest</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-634"><a href="#BigQuery.Generator-634"><span class="linenos">634</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_distinct_on</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-635"><a href="#BigQuery.Generator-635"><span class="linenos">635</span></a> <span class="n">_alias_ordered_group</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-636"><a href="#BigQuery.Generator-636"><span class="linenos">636</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_semi_and_anti_joins</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-637"><a href="#BigQuery.Generator-637"><span class="linenos">637</span></a> <span class="p">]</span>
-</span><span id="BigQuery.Generator-638"><a href="#BigQuery.Generator-638"><span class="linenos">638</span></a> <span class="p">),</span>
-</span><span id="BigQuery.Generator-639"><a href="#BigQuery.Generator-639"><span class="linenos">639</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;SHA1&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-640"><a href="#BigQuery.Generator-640"><span class="linenos">640</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA2</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery.Generator-641"><a href="#BigQuery.Generator-641"><span class="linenos">641</span></a> <span class="s2">&quot;SHA256&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;length&quot;</span><span class="p">)</span> <span class="o">==</span> <span class="s2">&quot;256&quot;</span> <span class="k">else</span> <span class="s2">&quot;SHA512&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span>
-</span><span id="BigQuery.Generator-642"><a href="#BigQuery.Generator-642"><span class="linenos">642</span></a> <span class="p">),</span>
-</span><span id="BigQuery.Generator-643"><a href="#BigQuery.Generator-643"><span class="linenos">643</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StabilityProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
-</span><span id="BigQuery.Generator-644"><a href="#BigQuery.Generator-644"><span class="linenos">644</span></a> <span class="s2">&quot;DETERMINISTIC&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;IMMUTABLE&quot;</span> <span class="k">else</span> <span class="s2">&quot;NOT DETERMINISTIC&quot;</span>
-</span><span id="BigQuery.Generator-645"><a href="#BigQuery.Generator-645"><span class="linenos">645</span></a> <span class="p">),</span>
-</span><span id="BigQuery.Generator-646"><a href="#BigQuery.Generator-646"><span class="linenos">646</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToDate</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;PARSE_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-647"><a href="#BigQuery.Generator-647"><span class="linenos">647</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToTime</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery.Generator-648"><a href="#BigQuery.Generator-648"><span class="linenos">648</span></a> <span class="s2">&quot;PARSE_TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-649"><a href="#BigQuery.Generator-649"><span class="linenos">649</span></a> <span class="p">),</span>
-</span><span id="BigQuery.Generator-650"><a href="#BigQuery.Generator-650"><span class="linenos">650</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-651"><a href="#BigQuery.Generator-651"><span class="linenos">651</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-652"><a href="#BigQuery.Generator-652"><span class="linenos">652</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-653"><a href="#BigQuery.Generator-653"><span class="linenos">653</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-654"><a href="#BigQuery.Generator-654"><span class="linenos">654</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampDiff</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP_DIFF&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-655"><a href="#BigQuery.Generator-655"><span class="linenos">655</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-656"><a href="#BigQuery.Generator-656"><span class="linenos">656</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeStrToTime</span><span class="p">:</span> <span class="n">timestrtotime_sql</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-657"><a href="#BigQuery.Generator-657"><span class="linenos">657</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Transaction</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;BEGIN TRANSACTION&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-658"><a href="#BigQuery.Generator-658"><span class="linenos">658</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Trim</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TRIM&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-659"><a href="#BigQuery.Generator-659"><span class="linenos">659</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsAdd</span><span class="p">:</span> <span class="n">_ts_or_ds_add_sql</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-660"><a href="#BigQuery.Generator-660"><span class="linenos">660</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsDiff</span><span class="p">:</span> <span class="n">_ts_or_ds_diff_sql</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-661"><a href="#BigQuery.Generator-661"><span class="linenos">661</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToTime</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-662"><a href="#BigQuery.Generator-662"><span class="linenos">662</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Unhex</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;FROM_HEX&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-663"><a href="#BigQuery.Generator-663"><span class="linenos">663</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixDate</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;UNIX_DATE&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-664"><a href="#BigQuery.Generator-664"><span class="linenos">664</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixToTime</span><span class="p">:</span> <span class="n">_unix_to_time_sql</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-665"><a href="#BigQuery.Generator-665"><span class="linenos">665</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Values</span><span class="p">:</span> <span class="n">_derived_table_values_to_unnest</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-666"><a href="#BigQuery.Generator-666"><span class="linenos">666</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VariancePop</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;VAR_POP&quot;</span><span class="p">),</span>
-</span><span id="BigQuery.Generator-667"><a href="#BigQuery.Generator-667"><span class="linenos">667</span></a> <span class="p">}</span>
-</span><span id="BigQuery.Generator-668"><a href="#BigQuery.Generator-668"><span class="linenos">668</span></a>
-</span><span id="BigQuery.Generator-669"><a href="#BigQuery.Generator-669"><span class="linenos">669</span></a> <span class="n">SUPPORTED_JSON_PATH_PARTS</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="BigQuery.Generator-670"><a href="#BigQuery.Generator-670"><span class="linenos">670</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathKey</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-671"><a href="#BigQuery.Generator-671"><span class="linenos">671</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathRoot</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-672"><a href="#BigQuery.Generator-672"><span class="linenos">672</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathSubscript</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-673"><a href="#BigQuery.Generator-673"><span class="linenos">673</span></a> <span class="p">}</span>
-</span><span id="BigQuery.Generator-674"><a href="#BigQuery.Generator-674"><span class="linenos">674</span></a>
-</span><span id="BigQuery.Generator-675"><a href="#BigQuery.Generator-675"><span class="linenos">675</span></a> <span class="n">TYPE_MAPPING</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="BigQuery.Generator-676"><a href="#BigQuery.Generator-676"><span class="linenos">676</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TYPE_MAPPING</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-677"><a href="#BigQuery.Generator-677"><span class="linenos">677</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGDECIMAL</span><span class="p">:</span> <span class="s2">&quot;BIGNUMERIC&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-678"><a href="#BigQuery.Generator-678"><span class="linenos">678</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-679"><a href="#BigQuery.Generator-679"><span class="linenos">679</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-680"><a href="#BigQuery.Generator-680"><span class="linenos">680</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BOOLEAN</span><span class="p">:</span> <span class="s2">&quot;BOOL&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-681"><a href="#BigQuery.Generator-681"><span class="linenos">681</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">CHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-682"><a href="#BigQuery.Generator-682"><span class="linenos">682</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DECIMAL</span><span class="p">:</span> <span class="s2">&quot;NUMERIC&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-683"><a href="#BigQuery.Generator-683"><span class="linenos">683</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DOUBLE</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-684"><a href="#BigQuery.Generator-684"><span class="linenos">684</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">FLOAT</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-685"><a href="#BigQuery.Generator-685"><span class="linenos">685</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">INT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-686"><a href="#BigQuery.Generator-686"><span class="linenos">686</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-687"><a href="#BigQuery.Generator-687"><span class="linenos">687</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NVARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-688"><a href="#BigQuery.Generator-688"><span class="linenos">688</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">SMALLINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-689"><a href="#BigQuery.Generator-689"><span class="linenos">689</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TEXT</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-690"><a href="#BigQuery.Generator-690"><span class="linenos">690</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMP</span><span class="p">:</span> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-691"><a href="#BigQuery.Generator-691"><span class="linenos">691</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-692"><a href="#BigQuery.Generator-692"><span class="linenos">692</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPLTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-693"><a href="#BigQuery.Generator-693"><span class="linenos">693</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TINYINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-694"><a href="#BigQuery.Generator-694"><span class="linenos">694</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARBINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-695"><a href="#BigQuery.Generator-695"><span class="linenos">695</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">ROWVERSION</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-696"><a href="#BigQuery.Generator-696"><span class="linenos">696</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-697"><a href="#BigQuery.Generator-697"><span class="linenos">697</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARIANT</span><span class="p">:</span> <span class="s2">&quot;ANY TYPE&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-698"><a href="#BigQuery.Generator-698"><span class="linenos">698</span></a> <span class="p">}</span>
-</span><span id="BigQuery.Generator-699"><a href="#BigQuery.Generator-699"><span class="linenos">699</span></a>
-</span><span id="BigQuery.Generator-700"><a href="#BigQuery.Generator-700"><span class="linenos">700</span></a> <span class="n">PROPERTIES_LOCATION</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="BigQuery.Generator-701"><a href="#BigQuery.Generator-701"><span class="linenos">701</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">PROPERTIES_LOCATION</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-702"><a href="#BigQuery.Generator-702"><span class="linenos">702</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">POST_SCHEMA</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-703"><a href="#BigQuery.Generator-703"><span class="linenos">703</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VolatileProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">UNSUPPORTED</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-704"><a href="#BigQuery.Generator-704"><span class="linenos">704</span></a> <span class="p">}</span>
-</span><span id="BigQuery.Generator-705"><a href="#BigQuery.Generator-705"><span class="linenos">705</span></a>
-</span><span id="BigQuery.Generator-706"><a href="#BigQuery.Generator-706"><span class="linenos">706</span></a> <span class="c1"># from: https://cloud.google.com/bigquery/docs/reference/standard-sql/lexical#reserved_keywords</span>
-</span><span id="BigQuery.Generator-707"><a href="#BigQuery.Generator-707"><span class="linenos">707</span></a> <span class="n">RESERVED_KEYWORDS</span> <span class="o">=</span> <span class="p">{</span>
-</span><span id="BigQuery.Generator-708"><a href="#BigQuery.Generator-708"><span class="linenos">708</span></a> <span class="o">*</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">RESERVED_KEYWORDS</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-709"><a href="#BigQuery.Generator-709"><span class="linenos">709</span></a> <span class="s2">&quot;all&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-710"><a href="#BigQuery.Generator-710"><span class="linenos">710</span></a> <span class="s2">&quot;and&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-711"><a href="#BigQuery.Generator-711"><span class="linenos">711</span></a> <span class="s2">&quot;any&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-712"><a href="#BigQuery.Generator-712"><span class="linenos">712</span></a> <span class="s2">&quot;array&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-713"><a href="#BigQuery.Generator-713"><span class="linenos">713</span></a> <span class="s2">&quot;as&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-714"><a href="#BigQuery.Generator-714"><span class="linenos">714</span></a> <span class="s2">&quot;asc&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-715"><a href="#BigQuery.Generator-715"><span class="linenos">715</span></a> <span class="s2">&quot;assert_rows_modified&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-716"><a href="#BigQuery.Generator-716"><span class="linenos">716</span></a> <span class="s2">&quot;at&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-717"><a href="#BigQuery.Generator-717"><span class="linenos">717</span></a> <span class="s2">&quot;between&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-718"><a href="#BigQuery.Generator-718"><span class="linenos">718</span></a> <span class="s2">&quot;by&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-719"><a href="#BigQuery.Generator-719"><span class="linenos">719</span></a> <span class="s2">&quot;case&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-720"><a href="#BigQuery.Generator-720"><span class="linenos">720</span></a> <span class="s2">&quot;cast&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-721"><a href="#BigQuery.Generator-721"><span class="linenos">721</span></a> <span class="s2">&quot;collate&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-722"><a href="#BigQuery.Generator-722"><span class="linenos">722</span></a> <span class="s2">&quot;contains&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-723"><a href="#BigQuery.Generator-723"><span class="linenos">723</span></a> <span class="s2">&quot;create&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-724"><a href="#BigQuery.Generator-724"><span class="linenos">724</span></a> <span class="s2">&quot;cross&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-725"><a href="#BigQuery.Generator-725"><span class="linenos">725</span></a> <span class="s2">&quot;cube&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-726"><a href="#BigQuery.Generator-726"><span class="linenos">726</span></a> <span class="s2">&quot;current&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-727"><a href="#BigQuery.Generator-727"><span class="linenos">727</span></a> <span class="s2">&quot;default&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-728"><a href="#BigQuery.Generator-728"><span class="linenos">728</span></a> <span class="s2">&quot;define&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-729"><a href="#BigQuery.Generator-729"><span class="linenos">729</span></a> <span class="s2">&quot;desc&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-730"><a href="#BigQuery.Generator-730"><span class="linenos">730</span></a> <span class="s2">&quot;distinct&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-731"><a href="#BigQuery.Generator-731"><span class="linenos">731</span></a> <span class="s2">&quot;else&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-732"><a href="#BigQuery.Generator-732"><span class="linenos">732</span></a> <span class="s2">&quot;end&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-733"><a href="#BigQuery.Generator-733"><span class="linenos">733</span></a> <span class="s2">&quot;enum&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-734"><a href="#BigQuery.Generator-734"><span class="linenos">734</span></a> <span class="s2">&quot;escape&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-735"><a href="#BigQuery.Generator-735"><span class="linenos">735</span></a> <span class="s2">&quot;except&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-736"><a href="#BigQuery.Generator-736"><span class="linenos">736</span></a> <span class="s2">&quot;exclude&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-737"><a href="#BigQuery.Generator-737"><span class="linenos">737</span></a> <span class="s2">&quot;exists&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-738"><a href="#BigQuery.Generator-738"><span class="linenos">738</span></a> <span class="s2">&quot;extract&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-739"><a href="#BigQuery.Generator-739"><span class="linenos">739</span></a> <span class="s2">&quot;false&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-740"><a href="#BigQuery.Generator-740"><span class="linenos">740</span></a> <span class="s2">&quot;fetch&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-741"><a href="#BigQuery.Generator-741"><span class="linenos">741</span></a> <span class="s2">&quot;following&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-742"><a href="#BigQuery.Generator-742"><span class="linenos">742</span></a> <span class="s2">&quot;for&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-743"><a href="#BigQuery.Generator-743"><span class="linenos">743</span></a> <span class="s2">&quot;from&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-744"><a href="#BigQuery.Generator-744"><span class="linenos">744</span></a> <span class="s2">&quot;full&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-745"><a href="#BigQuery.Generator-745"><span class="linenos">745</span></a> <span class="s2">&quot;group&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-746"><a href="#BigQuery.Generator-746"><span class="linenos">746</span></a> <span class="s2">&quot;grouping&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-747"><a href="#BigQuery.Generator-747"><span class="linenos">747</span></a> <span class="s2">&quot;groups&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-748"><a href="#BigQuery.Generator-748"><span class="linenos">748</span></a> <span class="s2">&quot;hash&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-749"><a href="#BigQuery.Generator-749"><span class="linenos">749</span></a> <span class="s2">&quot;having&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-750"><a href="#BigQuery.Generator-750"><span class="linenos">750</span></a> <span class="s2">&quot;if&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-751"><a href="#BigQuery.Generator-751"><span class="linenos">751</span></a> <span class="s2">&quot;ignore&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-752"><a href="#BigQuery.Generator-752"><span class="linenos">752</span></a> <span class="s2">&quot;in&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-753"><a href="#BigQuery.Generator-753"><span class="linenos">753</span></a> <span class="s2">&quot;inner&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-754"><a href="#BigQuery.Generator-754"><span class="linenos">754</span></a> <span class="s2">&quot;intersect&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-755"><a href="#BigQuery.Generator-755"><span class="linenos">755</span></a> <span class="s2">&quot;interval&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-756"><a href="#BigQuery.Generator-756"><span class="linenos">756</span></a> <span class="s2">&quot;into&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-757"><a href="#BigQuery.Generator-757"><span class="linenos">757</span></a> <span class="s2">&quot;is&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-758"><a href="#BigQuery.Generator-758"><span class="linenos">758</span></a> <span class="s2">&quot;join&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-759"><a href="#BigQuery.Generator-759"><span class="linenos">759</span></a> <span class="s2">&quot;lateral&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-760"><a href="#BigQuery.Generator-760"><span class="linenos">760</span></a> <span class="s2">&quot;left&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-761"><a href="#BigQuery.Generator-761"><span class="linenos">761</span></a> <span class="s2">&quot;like&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-762"><a href="#BigQuery.Generator-762"><span class="linenos">762</span></a> <span class="s2">&quot;limit&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-763"><a href="#BigQuery.Generator-763"><span class="linenos">763</span></a> <span class="s2">&quot;lookup&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-764"><a href="#BigQuery.Generator-764"><span class="linenos">764</span></a> <span class="s2">&quot;merge&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-765"><a href="#BigQuery.Generator-765"><span class="linenos">765</span></a> <span class="s2">&quot;natural&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-766"><a href="#BigQuery.Generator-766"><span class="linenos">766</span></a> <span class="s2">&quot;new&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-767"><a href="#BigQuery.Generator-767"><span class="linenos">767</span></a> <span class="s2">&quot;no&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-768"><a href="#BigQuery.Generator-768"><span class="linenos">768</span></a> <span class="s2">&quot;not&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-769"><a href="#BigQuery.Generator-769"><span class="linenos">769</span></a> <span class="s2">&quot;null&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-770"><a href="#BigQuery.Generator-770"><span class="linenos">770</span></a> <span class="s2">&quot;nulls&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-771"><a href="#BigQuery.Generator-771"><span class="linenos">771</span></a> <span class="s2">&quot;of&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-772"><a href="#BigQuery.Generator-772"><span class="linenos">772</span></a> <span class="s2">&quot;on&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-773"><a href="#BigQuery.Generator-773"><span class="linenos">773</span></a> <span class="s2">&quot;or&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-774"><a href="#BigQuery.Generator-774"><span class="linenos">774</span></a> <span class="s2">&quot;order&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-775"><a href="#BigQuery.Generator-775"><span class="linenos">775</span></a> <span class="s2">&quot;outer&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-776"><a href="#BigQuery.Generator-776"><span class="linenos">776</span></a> <span class="s2">&quot;over&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-777"><a href="#BigQuery.Generator-777"><span class="linenos">777</span></a> <span class="s2">&quot;partition&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-778"><a href="#BigQuery.Generator-778"><span class="linenos">778</span></a> <span class="s2">&quot;preceding&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-779"><a href="#BigQuery.Generator-779"><span class="linenos">779</span></a> <span class="s2">&quot;proto&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-780"><a href="#BigQuery.Generator-780"><span class="linenos">780</span></a> <span class="s2">&quot;qualify&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-781"><a href="#BigQuery.Generator-781"><span class="linenos">781</span></a> <span class="s2">&quot;range&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-782"><a href="#BigQuery.Generator-782"><span class="linenos">782</span></a> <span class="s2">&quot;recursive&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-783"><a href="#BigQuery.Generator-783"><span class="linenos">783</span></a> <span class="s2">&quot;respect&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-784"><a href="#BigQuery.Generator-784"><span class="linenos">784</span></a> <span class="s2">&quot;right&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-785"><a href="#BigQuery.Generator-785"><span class="linenos">785</span></a> <span class="s2">&quot;rollup&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-786"><a href="#BigQuery.Generator-786"><span class="linenos">786</span></a> <span class="s2">&quot;rows&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-787"><a href="#BigQuery.Generator-787"><span class="linenos">787</span></a> <span class="s2">&quot;select&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-788"><a href="#BigQuery.Generator-788"><span class="linenos">788</span></a> <span class="s2">&quot;set&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-789"><a href="#BigQuery.Generator-789"><span class="linenos">789</span></a> <span class="s2">&quot;some&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-790"><a href="#BigQuery.Generator-790"><span class="linenos">790</span></a> <span class="s2">&quot;struct&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-791"><a href="#BigQuery.Generator-791"><span class="linenos">791</span></a> <span class="s2">&quot;tablesample&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-792"><a href="#BigQuery.Generator-792"><span class="linenos">792</span></a> <span class="s2">&quot;then&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-793"><a href="#BigQuery.Generator-793"><span class="linenos">793</span></a> <span class="s2">&quot;to&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-794"><a href="#BigQuery.Generator-794"><span class="linenos">794</span></a> <span class="s2">&quot;treat&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-795"><a href="#BigQuery.Generator-795"><span class="linenos">795</span></a> <span class="s2">&quot;true&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-796"><a href="#BigQuery.Generator-796"><span class="linenos">796</span></a> <span class="s2">&quot;unbounded&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-797"><a href="#BigQuery.Generator-797"><span class="linenos">797</span></a> <span class="s2">&quot;union&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-798"><a href="#BigQuery.Generator-798"><span class="linenos">798</span></a> <span class="s2">&quot;unnest&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-799"><a href="#BigQuery.Generator-799"><span class="linenos">799</span></a> <span class="s2">&quot;using&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-800"><a href="#BigQuery.Generator-800"><span class="linenos">800</span></a> <span class="s2">&quot;when&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-801"><a href="#BigQuery.Generator-801"><span class="linenos">801</span></a> <span class="s2">&quot;where&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-802"><a href="#BigQuery.Generator-802"><span class="linenos">802</span></a> <span class="s2">&quot;window&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-803"><a href="#BigQuery.Generator-803"><span class="linenos">803</span></a> <span class="s2">&quot;with&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-804"><a href="#BigQuery.Generator-804"><span class="linenos">804</span></a> <span class="s2">&quot;within&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-805"><a href="#BigQuery.Generator-805"><span class="linenos">805</span></a> <span class="p">}</span>
-</span><span id="BigQuery.Generator-806"><a href="#BigQuery.Generator-806"><span class="linenos">806</span></a>
-</span><span id="BigQuery.Generator-807"><a href="#BigQuery.Generator-807"><span class="linenos">807</span></a> <span class="k">def</span> <span class="nf">mod_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Mod</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-808"><a href="#BigQuery.Generator-808"><span class="linenos">808</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
-</span><span id="BigQuery.Generator-809"><a href="#BigQuery.Generator-809"><span class="linenos">809</span></a> <span class="n">expr</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expression</span>
-</span><span id="BigQuery.Generator-810"><a href="#BigQuery.Generator-810"><span class="linenos">810</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery.Generator-811"><a href="#BigQuery.Generator-811"><span class="linenos">811</span></a> <span class="s2">&quot;MOD&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-812"><a href="#BigQuery.Generator-812"><span class="linenos">812</span></a> <span class="n">this</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">this</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-813"><a href="#BigQuery.Generator-813"><span class="linenos">813</span></a> <span class="n">expr</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expr</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">expr</span><span class="p">,</span>
-</span><span id="BigQuery.Generator-814"><a href="#BigQuery.Generator-814"><span class="linenos">814</span></a> <span class="p">)</span>
-</span><span id="BigQuery.Generator-815"><a href="#BigQuery.Generator-815"><span class="linenos">815</span></a>
-</span><span id="BigQuery.Generator-816"><a href="#BigQuery.Generator-816"><span class="linenos">816</span></a> <span class="k">def</span> <span class="nf">column_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Column</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-817"><a href="#BigQuery.Generator-817"><span class="linenos">817</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_column&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator-818"><a href="#BigQuery.Generator-818"><span class="linenos">818</span></a> <span class="c1"># If a column reference is of the form `dataset.table`.name, we need</span>
-</span><span id="BigQuery.Generator-819"><a href="#BigQuery.Generator-819"><span class="linenos">819</span></a> <span class="c1"># to preserve the quoted table path, otherwise the reference breaks</span>
-</span><span id="BigQuery.Generator-820"><a href="#BigQuery.Generator-820"><span class="linenos">820</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">[:</span><span class="o">-</span><span class="mi">1</span><span class="p">])</span>
-</span><span id="BigQuery.Generator-821"><a href="#BigQuery.Generator-821"><span class="linenos">821</span></a> <span class="n">table_path</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">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
-</span><span id="BigQuery.Generator-822"><a href="#BigQuery.Generator-822"><span class="linenos">822</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="n">table_path</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery.Generator-823"><a href="#BigQuery.Generator-823"><span class="linenos">823</span></a>
-</span><span id="BigQuery.Generator-824"><a href="#BigQuery.Generator-824"><span class="linenos">824</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">column_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-825"><a href="#BigQuery.Generator-825"><span class="linenos">825</span></a>
-</span><span id="BigQuery.Generator-826"><a href="#BigQuery.Generator-826"><span class="linenos">826</span></a> <span class="k">def</span> <span class="nf">table_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Table</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-827"><a href="#BigQuery.Generator-827"><span class="linenos">827</span></a> <span class="c1"># Depending on the context, `x.y` may not resolve to the same data source as `x`.`y`, so</span>
-</span><span id="BigQuery.Generator-828"><a href="#BigQuery.Generator-828"><span class="linenos">828</span></a> <span class="c1"># we need to make sure the correct quoting is used in each case.</span>
-</span><span id="BigQuery.Generator-829"><a href="#BigQuery.Generator-829"><span class="linenos">829</span></a> <span class="c1">#</span>
-</span><span id="BigQuery.Generator-830"><a href="#BigQuery.Generator-830"><span class="linenos">830</span></a> <span class="c1"># For example, if there is a CTE x that clashes with a schema name, then the former will</span>
-</span><span id="BigQuery.Generator-831"><a href="#BigQuery.Generator-831"><span class="linenos">831</span></a> <span class="c1"># return the table y in that schema, whereas the latter will return the CTE&#39;s y column:</span>
-</span><span id="BigQuery.Generator-832"><a href="#BigQuery.Generator-832"><span class="linenos">832</span></a> <span class="c1">#</span>
-</span><span id="BigQuery.Generator-833"><a href="#BigQuery.Generator-833"><span class="linenos">833</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x.y` -&gt; cross join</span>
-</span><span id="BigQuery.Generator-834"><a href="#BigQuery.Generator-834"><span class="linenos">834</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x`.`y` -&gt; implicit unnest</span>
-</span><span id="BigQuery.Generator-835"><a href="#BigQuery.Generator-835"><span class="linenos">835</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_table&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator-836"><a href="#BigQuery.Generator-836"><span class="linenos">836</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-837"><a href="#BigQuery.Generator-837"><span class="linenos">837</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
-</span><span id="BigQuery.Generator-838"><a href="#BigQuery.Generator-838"><span class="linenos">838</span></a>
-</span><span id="BigQuery.Generator-839"><a href="#BigQuery.Generator-839"><span class="linenos">839</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">table_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-840"><a href="#BigQuery.Generator-840"><span class="linenos">840</span></a>
-</span><span id="BigQuery.Generator-841"><a href="#BigQuery.Generator-841"><span class="linenos">841</span></a> <span class="k">def</span> <span class="nf">timetostr_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TimeToStr</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-842"><a href="#BigQuery.Generator-842"><span class="linenos">842</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToDate</span><span class="p">)</span> <span class="k">else</span> <span class="n">expression</span>
-</span><span id="BigQuery.Generator-843"><a href="#BigQuery.Generator-843"><span class="linenos">843</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;FORMAT_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">expression</span><span class="p">),</span> <span class="n">this</span><span class="o">.</span><span class="n">this</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-844"><a href="#BigQuery.Generator-844"><span class="linenos">844</span></a>
-</span><span id="BigQuery.Generator-845"><a href="#BigQuery.Generator-845"><span class="linenos">845</span></a> <span class="k">def</span> <span class="nf">eq_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">EQ</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-846"><a href="#BigQuery.Generator-846"><span class="linenos">846</span></a> <span class="c1"># Operands of = cannot be NULL in BigQuery</span>
-</span><span id="BigQuery.Generator-847"><a href="#BigQuery.Generator-847"><span class="linenos">847</span></a> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">left</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">)</span> <span class="ow">or</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">right</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">):</span>
-</span><span id="BigQuery.Generator-848"><a href="#BigQuery.Generator-848"><span class="linenos">848</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Update</span><span class="p">):</span>
-</span><span id="BigQuery.Generator-849"><a href="#BigQuery.Generator-849"><span class="linenos">849</span></a> <span class="k">return</span> <span class="s2">&quot;NULL&quot;</span>
-</span><span id="BigQuery.Generator-850"><a href="#BigQuery.Generator-850"><span class="linenos">850</span></a>
-</span><span id="BigQuery.Generator-851"><a href="#BigQuery.Generator-851"><span class="linenos">851</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">binary</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="s2">&quot;=&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-852"><a href="#BigQuery.Generator-852"><span class="linenos">852</span></a>
-</span><span id="BigQuery.Generator-853"><a href="#BigQuery.Generator-853"><span class="linenos">853</span></a> <span class="k">def</span> <span class="nf">attimezone_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">AtTimeZone</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-854"><a href="#BigQuery.Generator-854"><span class="linenos">854</span></a> <span class="n">parent</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">parent</span>
-</span><span id="BigQuery.Generator-855"><a href="#BigQuery.Generator-855"><span class="linenos">855</span></a>
-</span><span id="BigQuery.Generator-856"><a href="#BigQuery.Generator-856"><span class="linenos">856</span></a> <span class="c1"># BigQuery allows CAST(.. AS {STRING|TIMESTAMP} [FORMAT &lt;fmt&gt; [AT TIME ZONE &lt;tz&gt;]]).</span>
-</span><span id="BigQuery.Generator-857"><a href="#BigQuery.Generator-857"><span class="linenos">857</span></a> <span class="c1"># Only the TIMESTAMP one should use the below conversion, when AT TIME ZONE is included.</span>
-</span><span id="BigQuery.Generator-858"><a href="#BigQuery.Generator-858"><span class="linenos">858</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">)</span> <span class="ow">or</span> <span class="ow">not</span> <span class="n">parent</span><span class="o">.</span><span class="n">to</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="s2">&quot;text&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator-859"><a href="#BigQuery.Generator-859"><span class="linenos">859</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery.Generator-860"><a href="#BigQuery.Generator-860"><span class="linenos">860</span></a> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">))</span>
-</span><span id="BigQuery.Generator-861"><a href="#BigQuery.Generator-861"><span class="linenos">861</span></a> <span class="p">)</span>
-</span><span id="BigQuery.Generator-862"><a href="#BigQuery.Generator-862"><span class="linenos">862</span></a>
-</span><span id="BigQuery.Generator-863"><a href="#BigQuery.Generator-863"><span class="linenos">863</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">attimezone_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-864"><a href="#BigQuery.Generator-864"><span class="linenos">864</span></a>
-</span><span id="BigQuery.Generator-865"><a href="#BigQuery.Generator-865"><span class="linenos">865</span></a> <span class="k">def</span> <span class="nf">trycast_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TryCast</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-866"><a href="#BigQuery.Generator-866"><span class="linenos">866</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">cast_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">safe_prefix</span><span class="o">=</span><span class="s2">&quot;SAFE_&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-867"><a href="#BigQuery.Generator-867"><span class="linenos">867</span></a>
-</span><span id="BigQuery.Generator-868"><a href="#BigQuery.Generator-868"><span class="linenos">868</span></a> <span class="k">def</span> <span class="nf">bracket_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Bracket</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-869"><a href="#BigQuery.Generator-869"><span class="linenos">869</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
-</span><span id="BigQuery.Generator-870"><a href="#BigQuery.Generator-870"><span class="linenos">870</span></a> <span class="n">expressions</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expressions</span>
-</span><span id="BigQuery.Generator-871"><a href="#BigQuery.Generator-871"><span class="linenos">871</span></a>
-</span><span id="BigQuery.Generator-872"><a href="#BigQuery.Generator-872"><span class="linenos">872</span></a> <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">expressions</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> <span class="ow">and</span> <span class="n">this</span> <span class="ow">and</span> <span class="n">this</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">STRUCT</span><span class="p">):</span>
-</span><span id="BigQuery.Generator-873"><a href="#BigQuery.Generator-873"><span class="linenos">873</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">expressions</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
-</span><span id="BigQuery.Generator-874"><a href="#BigQuery.Generator-874"><span class="linenos">874</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">is</span> <span class="kc">None</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-875"><a href="#BigQuery.Generator-875"><span class="linenos">875</span></a> <span class="kn">from</span> <span class="nn">sqlglot.optimizer.annotate_types</span> <span class="kn">import</span> <span class="n">annotate_types</span>
-</span><span id="BigQuery.Generator-876"><a href="#BigQuery.Generator-876"><span class="linenos">876</span></a>
-</span><span id="BigQuery.Generator-877"><a href="#BigQuery.Generator-877"><span class="linenos">877</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">annotate_types</span><span class="p">(</span><span class="n">arg</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-878"><a href="#BigQuery.Generator-878"><span class="linenos">878</span></a>
-</span><span id="BigQuery.Generator-879"><a href="#BigQuery.Generator-879"><span class="linenos">879</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">and</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span><span class="o">.</span><span class="n">this</span> <span class="ow">in</span> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">TEXT_TYPES</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-880"><a href="#BigQuery.Generator-880"><span class="linenos">880</span></a> <span class="c1"># BQ doesn&#39;t support bracket syntax with string values for structs</span>
-</span><span id="BigQuery.Generator-881"><a href="#BigQuery.Generator-881"><span class="linenos">881</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="n">arg</span><span class="o">.</span><span class="n">name</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery.Generator-882"><a href="#BigQuery.Generator-882"><span class="linenos">882</span></a>
-</span><span id="BigQuery.Generator-883"><a href="#BigQuery.Generator-883"><span class="linenos">883</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">expressions</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">flat</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-884"><a href="#BigQuery.Generator-884"><span class="linenos">884</span></a> <span class="n">offset</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;offset&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-885"><a href="#BigQuery.Generator-885"><span class="linenos">885</span></a>
-</span><span id="BigQuery.Generator-886"><a href="#BigQuery.Generator-886"><span class="linenos">886</span></a> <span class="k">if</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-887"><a href="#BigQuery.Generator-887"><span class="linenos">887</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;OFFSET(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
-</span><span id="BigQuery.Generator-888"><a href="#BigQuery.Generator-888"><span class="linenos">888</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-889"><a href="#BigQuery.Generator-889"><span class="linenos">889</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;ORDINAL(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
-</span><span id="BigQuery.Generator-890"><a href="#BigQuery.Generator-890"><span class="linenos">890</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-891"><a href="#BigQuery.Generator-891"><span class="linenos">891</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Unsupported array offset: </span><span class="si">{</span><span class="n">offset</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-892"><a href="#BigQuery.Generator-892"><span class="linenos">892</span></a>
-</span><span id="BigQuery.Generator-893"><a href="#BigQuery.Generator-893"><span class="linenos">893</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;safe&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator-894"><a href="#BigQuery.Generator-894"><span class="linenos">894</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SAFE_</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery.Generator-895"><a href="#BigQuery.Generator-895"><span class="linenos">895</span></a>
-</span><span id="BigQuery.Generator-896"><a href="#BigQuery.Generator-896"><span class="linenos">896</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">[</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">]&quot;</span>
-</span><span id="BigQuery.Generator-897"><a href="#BigQuery.Generator-897"><span class="linenos">897</span></a>
-</span><span id="BigQuery.Generator-898"><a href="#BigQuery.Generator-898"><span class="linenos">898</span></a> <span class="k">def</span> <span class="nf">in_unnest_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Unnest</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-899"><a href="#BigQuery.Generator-899"><span class="linenos">899</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-900"><a href="#BigQuery.Generator-900"><span class="linenos">900</span></a>
-</span><span id="BigQuery.Generator-901"><a href="#BigQuery.Generator-901"><span class="linenos">901</span></a> <span class="k">def</span> <span class="nf">except_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Except</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-902"><a href="#BigQuery.Generator-902"><span class="linenos">902</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator-903"><a href="#BigQuery.Generator-903"><span class="linenos">903</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;EXCEPT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-904"><a href="#BigQuery.Generator-904"><span class="linenos">904</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;EXCEPT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery.Generator-905"><a href="#BigQuery.Generator-905"><span class="linenos">905</span></a>
-</span><span id="BigQuery.Generator-906"><a href="#BigQuery.Generator-906"><span class="linenos">906</span></a> <span class="k">def</span> <span class="nf">intersect_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Intersect</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-907"><a href="#BigQuery.Generator-907"><span class="linenos">907</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator-908"><a href="#BigQuery.Generator-908"><span class="linenos">908</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;INTERSECT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-909"><a href="#BigQuery.Generator-909"><span class="linenos">909</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;INTERSECT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery.Generator-910"><a href="#BigQuery.Generator-910"><span class="linenos">910</span></a>
-</span><span id="BigQuery.Generator-911"><a href="#BigQuery.Generator-911"><span class="linenos">911</span></a> <span class="k">def</span> <span class="nf">with_properties</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">properties</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-912"><a href="#BigQuery.Generator-912"><span class="linenos">912</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">properties</span><span class="p">(</span><span class="n">properties</span><span class="p">,</span> <span class="n">prefix</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">seg</span><span class="p">(</span><span class="s2">&quot;OPTIONS&quot;</span><span class="p">))</span>
-</span><span id="BigQuery.Generator-913"><a href="#BigQuery.Generator-913"><span class="linenos">913</span></a>
-</span><span id="BigQuery.Generator-914"><a href="#BigQuery.Generator-914"><span class="linenos">914</span></a> <span class="k">def</span> <span class="nf">version_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Version</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-915"><a href="#BigQuery.Generator-915"><span class="linenos">915</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">:</span>
-</span><span id="BigQuery.Generator-916"><a href="#BigQuery.Generator-916"><span class="linenos">916</span></a> <span class="n">expression</span><span class="o">.</span><span class="n">set</span><span class="p">(</span><span class="s2">&quot;this&quot;</span><span class="p">,</span> <span class="s2">&quot;SYSTEM_TIME&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator-917"><a href="#BigQuery.Generator-917"><span class="linenos">917</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">version_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-574"><a href="#BigQuery.Generator-574"><span class="linenos">574</span></a> <span class="n">WITH_PROPERTIES_PREFIX</span> <span class="o">=</span> <span class="s2">&quot;OPTIONS&quot;</span>
+</span><span id="BigQuery.Generator-575"><a href="#BigQuery.Generator-575"><span class="linenos">575</span></a>
+</span><span id="BigQuery.Generator-576"><a href="#BigQuery.Generator-576"><span class="linenos">576</span></a> <span class="n">TRANSFORMS</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="BigQuery.Generator-577"><a href="#BigQuery.Generator-577"><span class="linenos">577</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TRANSFORMS</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-578"><a href="#BigQuery.Generator-578"><span class="linenos">578</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ApproxDistinct</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;APPROX_COUNT_DISTINCT&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-579"><a href="#BigQuery.Generator-579"><span class="linenos">579</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMax</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MAX_BY&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-580"><a href="#BigQuery.Generator-580"><span class="linenos">580</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArgMin</span><span class="p">:</span> <span class="n">arg_max_or_min_no_count</span><span class="p">(</span><span class="s2">&quot;MIN_BY&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-581"><a href="#BigQuery.Generator-581"><span class="linenos">581</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Array</span><span class="p">:</span> <span class="n">inline_array_unless_query</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-582"><a href="#BigQuery.Generator-582"><span class="linenos">582</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayContains</span><span class="p">:</span> <span class="n">_array_contains_sql</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-583"><a href="#BigQuery.Generator-583"><span class="linenos">583</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArrayFilter</span><span class="p">:</span> <span class="n">filter_array_using_unnest</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-584"><a href="#BigQuery.Generator-584"><span class="linenos">584</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ArraySize</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;ARRAY_LENGTH&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-585"><a href="#BigQuery.Generator-585"><span class="linenos">585</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">transforms</span><span class="o">.</span><span class="n">remove_precision_parameterized_types</span><span class="p">]),</span>
+</span><span id="BigQuery.Generator-586"><a href="#BigQuery.Generator-586"><span class="linenos">586</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CollateProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
+</span><span id="BigQuery.Generator-587"><a href="#BigQuery.Generator-587"><span class="linenos">587</span></a> <span class="sa">f</span><span class="s2">&quot;DEFAULT COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery.Generator-588"><a href="#BigQuery.Generator-588"><span class="linenos">588</span></a> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;default&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-589"><a href="#BigQuery.Generator-589"><span class="linenos">589</span></a> <span class="k">else</span> <span class="sa">f</span><span class="s2">&quot;COLLATE </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery.Generator-590"><a href="#BigQuery.Generator-590"><span class="linenos">590</span></a> <span class="p">),</span>
+</span><span id="BigQuery.Generator-591"><a href="#BigQuery.Generator-591"><span class="linenos">591</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Commit</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;COMMIT TRANSACTION&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-592"><a href="#BigQuery.Generator-592"><span class="linenos">592</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CountIf</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;COUNTIF&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-593"><a href="#BigQuery.Generator-593"><span class="linenos">593</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Create</span><span class="p">:</span> <span class="n">_create_sql</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-594"><a href="#BigQuery.Generator-594"><span class="linenos">594</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">CTE</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">([</span><span class="n">_pushdown_cte_column_names</span><span class="p">]),</span>
+</span><span id="BigQuery.Generator-595"><a href="#BigQuery.Generator-595"><span class="linenos">595</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-596"><a href="#BigQuery.Generator-596"><span class="linenos">596</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateDiff</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery.Generator-597"><a href="#BigQuery.Generator-597"><span class="linenos">597</span></a> <span class="s2">&quot;DATE_DIFF&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span> <span class="n">unit_to_var</span><span class="p">(</span><span class="n">e</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-598"><a href="#BigQuery.Generator-598"><span class="linenos">598</span></a> <span class="p">),</span>
+</span><span id="BigQuery.Generator-599"><a href="#BigQuery.Generator-599"><span class="linenos">599</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-600"><a href="#BigQuery.Generator-600"><span class="linenos">600</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateStrToDate</span><span class="p">:</span> <span class="n">datestrtodate_sql</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-601"><a href="#BigQuery.Generator-601"><span class="linenos">601</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATE&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-602"><a href="#BigQuery.Generator-602"><span class="linenos">602</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-603"><a href="#BigQuery.Generator-603"><span class="linenos">603</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DatetimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-604"><a href="#BigQuery.Generator-604"><span class="linenos">604</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DateTrunc</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATE_TRUNC&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;unit&quot;</span><span class="p">)),</span>
+</span><span id="BigQuery.Generator-605"><a href="#BigQuery.Generator-605"><span class="linenos">605</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">FromTimeZone</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery.Generator-606"><a href="#BigQuery.Generator-606"><span class="linenos">606</span></a> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)),</span> <span class="s2">&quot;&#39;UTC&#39;&quot;</span>
+</span><span id="BigQuery.Generator-607"><a href="#BigQuery.Generator-607"><span class="linenos">607</span></a> <span class="p">),</span>
+</span><span id="BigQuery.Generator-608"><a href="#BigQuery.Generator-608"><span class="linenos">608</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GenerateSeries</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;GENERATE_ARRAY&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-609"><a href="#BigQuery.Generator-609"><span class="linenos">609</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">GroupConcat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;STRING_AGG&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-610"><a href="#BigQuery.Generator-610"><span class="linenos">610</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Hex</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;UPPER&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&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">e</span><span class="p">,</span> <span class="s2">&quot;this&quot;</span><span class="p">))),</span>
+</span><span id="BigQuery.Generator-611"><a href="#BigQuery.Generator-611"><span class="linenos">611</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">If</span><span class="p">:</span> <span class="n">if_sql</span><span class="p">(</span><span class="n">false_value</span><span class="o">=</span><span class="s2">&quot;NULL&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-612"><a href="#BigQuery.Generator-612"><span class="linenos">612</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ILike</span><span class="p">:</span> <span class="n">no_ilike_sql</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-613"><a href="#BigQuery.Generator-613"><span class="linenos">613</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">IntDiv</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;DIV&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-614"><a href="#BigQuery.Generator-614"><span class="linenos">614</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONFormat</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TO_JSON_STRING&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-615"><a href="#BigQuery.Generator-615"><span class="linenos">615</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Max</span><span class="p">:</span> <span class="n">max_or_greatest</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-616"><a href="#BigQuery.Generator-616"><span class="linenos">616</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TO_HEX&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">)),</span>
+</span><span id="BigQuery.Generator-617"><a href="#BigQuery.Generator-617"><span class="linenos">617</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">MD5Digest</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;MD5&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-618"><a href="#BigQuery.Generator-618"><span class="linenos">618</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Min</span><span class="p">:</span> <span class="n">min_or_least</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-619"><a href="#BigQuery.Generator-619"><span class="linenos">619</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="sa">f</span><span class="s2">&quot;PARTITION BY </span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">e</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-620"><a href="#BigQuery.Generator-620"><span class="linenos">620</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpExtract</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery.Generator-621"><a href="#BigQuery.Generator-621"><span class="linenos">621</span></a> <span class="s2">&quot;REGEXP_EXTRACT&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-622"><a href="#BigQuery.Generator-622"><span class="linenos">622</span></a> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-623"><a href="#BigQuery.Generator-623"><span class="linenos">623</span></a> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-624"><a href="#BigQuery.Generator-624"><span class="linenos">624</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;position&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-625"><a href="#BigQuery.Generator-625"><span class="linenos">625</span></a> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;occurrence&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-626"><a href="#BigQuery.Generator-626"><span class="linenos">626</span></a> <span class="p">),</span>
+</span><span id="BigQuery.Generator-627"><a href="#BigQuery.Generator-627"><span class="linenos">627</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpReplace</span><span class="p">:</span> <span class="n">regexp_replace_sql</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-628"><a href="#BigQuery.Generator-628"><span class="linenos">628</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">RegexpLike</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;REGEXP_CONTAINS&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-629"><a href="#BigQuery.Generator-629"><span class="linenos">629</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">ReturnsProperty</span><span class="p">:</span> <span class="n">_returnsproperty_sql</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-630"><a href="#BigQuery.Generator-630"><span class="linenos">630</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Rollback</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;ROLLBACK TRANSACTION&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-631"><a href="#BigQuery.Generator-631"><span class="linenos">631</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Select</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">preprocess</span><span class="p">(</span>
+</span><span id="BigQuery.Generator-632"><a href="#BigQuery.Generator-632"><span class="linenos">632</span></a> <span class="p">[</span>
+</span><span id="BigQuery.Generator-633"><a href="#BigQuery.Generator-633"><span class="linenos">633</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">explode_to_unnest</span><span class="p">(),</span>
+</span><span id="BigQuery.Generator-634"><a href="#BigQuery.Generator-634"><span class="linenos">634</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">unqualify_unnest</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-635"><a href="#BigQuery.Generator-635"><span class="linenos">635</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_distinct_on</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-636"><a href="#BigQuery.Generator-636"><span class="linenos">636</span></a> <span class="n">_alias_ordered_group</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-637"><a href="#BigQuery.Generator-637"><span class="linenos">637</span></a> <span class="n">transforms</span><span class="o">.</span><span class="n">eliminate_semi_and_anti_joins</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-638"><a href="#BigQuery.Generator-638"><span class="linenos">638</span></a> <span class="p">]</span>
+</span><span id="BigQuery.Generator-639"><a href="#BigQuery.Generator-639"><span class="linenos">639</span></a> <span class="p">),</span>
+</span><span id="BigQuery.Generator-640"><a href="#BigQuery.Generator-640"><span class="linenos">640</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;SHA1&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-641"><a href="#BigQuery.Generator-641"><span class="linenos">641</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">SHA2</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery.Generator-642"><a href="#BigQuery.Generator-642"><span class="linenos">642</span></a> <span class="s2">&quot;SHA256&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="s2">&quot;length&quot;</span><span class="p">)</span> <span class="o">==</span> <span class="s2">&quot;256&quot;</span> <span class="k">else</span> <span class="s2">&quot;SHA512&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span>
+</span><span id="BigQuery.Generator-643"><a href="#BigQuery.Generator-643"><span class="linenos">643</span></a> <span class="p">),</span>
+</span><span id="BigQuery.Generator-644"><a href="#BigQuery.Generator-644"><span class="linenos">644</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StabilityProperty</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="p">(</span>
+</span><span id="BigQuery.Generator-645"><a href="#BigQuery.Generator-645"><span class="linenos">645</span></a> <span class="s2">&quot;DETERMINISTIC&quot;</span> <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;IMMUTABLE&quot;</span> <span class="k">else</span> <span class="s2">&quot;NOT DETERMINISTIC&quot;</span>
+</span><span id="BigQuery.Generator-646"><a href="#BigQuery.Generator-646"><span class="linenos">646</span></a> <span class="p">),</span>
+</span><span id="BigQuery.Generator-647"><a href="#BigQuery.Generator-647"><span class="linenos">647</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToDate</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;PARSE_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-648"><a href="#BigQuery.Generator-648"><span class="linenos">648</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">StrToTime</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery.Generator-649"><a href="#BigQuery.Generator-649"><span class="linenos">649</span></a> <span class="s2">&quot;PARSE_TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">e</span><span class="p">),</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-650"><a href="#BigQuery.Generator-650"><span class="linenos">650</span></a> <span class="p">),</span>
+</span><span id="BigQuery.Generator-651"><a href="#BigQuery.Generator-651"><span class="linenos">651</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-652"><a href="#BigQuery.Generator-652"><span class="linenos">652</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeFromParts</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-653"><a href="#BigQuery.Generator-653"><span class="linenos">653</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-654"><a href="#BigQuery.Generator-654"><span class="linenos">654</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampAdd</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;ADD&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-655"><a href="#BigQuery.Generator-655"><span class="linenos">655</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampDiff</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP_DIFF&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-656"><a href="#BigQuery.Generator-656"><span class="linenos">656</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimestampSub</span><span class="p">:</span> <span class="n">date_add_interval_sql</span><span class="p">(</span><span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="s2">&quot;SUB&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-657"><a href="#BigQuery.Generator-657"><span class="linenos">657</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TimeStrToTime</span><span class="p">:</span> <span class="n">timestrtotime_sql</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-658"><a href="#BigQuery.Generator-658"><span class="linenos">658</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Transaction</span><span class="p">:</span> <span class="k">lambda</span> <span class="o">*</span><span class="n">_</span><span class="p">:</span> <span class="s2">&quot;BEGIN TRANSACTION&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-659"><a href="#BigQuery.Generator-659"><span class="linenos">659</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Trim</span><span class="p">:</span> <span class="k">lambda</span> <span class="bp">self</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;TRIM&quot;</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">e</span><span class="o">.</span><span class="n">expression</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-660"><a href="#BigQuery.Generator-660"><span class="linenos">660</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsAdd</span><span class="p">:</span> <span class="n">_ts_or_ds_add_sql</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-661"><a href="#BigQuery.Generator-661"><span class="linenos">661</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsDiff</span><span class="p">:</span> <span class="n">_ts_or_ds_diff_sql</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-662"><a href="#BigQuery.Generator-662"><span class="linenos">662</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToTime</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;TIME&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-663"><a href="#BigQuery.Generator-663"><span class="linenos">663</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Unhex</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;FROM_HEX&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-664"><a href="#BigQuery.Generator-664"><span class="linenos">664</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixDate</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;UNIX_DATE&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-665"><a href="#BigQuery.Generator-665"><span class="linenos">665</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">UnixToTime</span><span class="p">:</span> <span class="n">_unix_to_time_sql</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-666"><a href="#BigQuery.Generator-666"><span class="linenos">666</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">Values</span><span class="p">:</span> <span class="n">_derived_table_values_to_unnest</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-667"><a href="#BigQuery.Generator-667"><span class="linenos">667</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VariancePop</span><span class="p">:</span> <span class="n">rename_func</span><span class="p">(</span><span class="s2">&quot;VAR_POP&quot;</span><span class="p">),</span>
+</span><span id="BigQuery.Generator-668"><a href="#BigQuery.Generator-668"><span class="linenos">668</span></a> <span class="p">}</span>
+</span><span id="BigQuery.Generator-669"><a href="#BigQuery.Generator-669"><span class="linenos">669</span></a>
+</span><span id="BigQuery.Generator-670"><a href="#BigQuery.Generator-670"><span class="linenos">670</span></a> <span class="n">SUPPORTED_JSON_PATH_PARTS</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="BigQuery.Generator-671"><a href="#BigQuery.Generator-671"><span class="linenos">671</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathKey</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-672"><a href="#BigQuery.Generator-672"><span class="linenos">672</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathRoot</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-673"><a href="#BigQuery.Generator-673"><span class="linenos">673</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">JSONPathSubscript</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-674"><a href="#BigQuery.Generator-674"><span class="linenos">674</span></a> <span class="p">}</span>
+</span><span id="BigQuery.Generator-675"><a href="#BigQuery.Generator-675"><span class="linenos">675</span></a>
+</span><span id="BigQuery.Generator-676"><a href="#BigQuery.Generator-676"><span class="linenos">676</span></a> <span class="n">TYPE_MAPPING</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="BigQuery.Generator-677"><a href="#BigQuery.Generator-677"><span class="linenos">677</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">TYPE_MAPPING</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-678"><a href="#BigQuery.Generator-678"><span class="linenos">678</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGDECIMAL</span><span class="p">:</span> <span class="s2">&quot;BIGNUMERIC&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-679"><a href="#BigQuery.Generator-679"><span class="linenos">679</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BIGINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-680"><a href="#BigQuery.Generator-680"><span class="linenos">680</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-681"><a href="#BigQuery.Generator-681"><span class="linenos">681</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">BOOLEAN</span><span class="p">:</span> <span class="s2">&quot;BOOL&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-682"><a href="#BigQuery.Generator-682"><span class="linenos">682</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">CHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-683"><a href="#BigQuery.Generator-683"><span class="linenos">683</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DECIMAL</span><span class="p">:</span> <span class="s2">&quot;NUMERIC&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-684"><a href="#BigQuery.Generator-684"><span class="linenos">684</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">DOUBLE</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-685"><a href="#BigQuery.Generator-685"><span class="linenos">685</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">FLOAT</span><span class="p">:</span> <span class="s2">&quot;FLOAT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-686"><a href="#BigQuery.Generator-686"><span class="linenos">686</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">INT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-687"><a href="#BigQuery.Generator-687"><span class="linenos">687</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-688"><a href="#BigQuery.Generator-688"><span class="linenos">688</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">NVARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-689"><a href="#BigQuery.Generator-689"><span class="linenos">689</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">SMALLINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-690"><a href="#BigQuery.Generator-690"><span class="linenos">690</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TEXT</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-691"><a href="#BigQuery.Generator-691"><span class="linenos">691</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMP</span><span class="p">:</span> <span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-692"><a href="#BigQuery.Generator-692"><span class="linenos">692</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-693"><a href="#BigQuery.Generator-693"><span class="linenos">693</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TIMESTAMPLTZ</span><span class="p">:</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-694"><a href="#BigQuery.Generator-694"><span class="linenos">694</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">TINYINT</span><span class="p">:</span> <span class="s2">&quot;INT64&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-695"><a href="#BigQuery.Generator-695"><span class="linenos">695</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARBINARY</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-696"><a href="#BigQuery.Generator-696"><span class="linenos">696</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">ROWVERSION</span><span class="p">:</span> <span class="s2">&quot;BYTES&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-697"><a href="#BigQuery.Generator-697"><span class="linenos">697</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARCHAR</span><span class="p">:</span> <span class="s2">&quot;STRING&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-698"><a href="#BigQuery.Generator-698"><span class="linenos">698</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">VARIANT</span><span class="p">:</span> <span class="s2">&quot;ANY TYPE&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-699"><a href="#BigQuery.Generator-699"><span class="linenos">699</span></a> <span class="p">}</span>
+</span><span id="BigQuery.Generator-700"><a href="#BigQuery.Generator-700"><span class="linenos">700</span></a>
+</span><span id="BigQuery.Generator-701"><a href="#BigQuery.Generator-701"><span class="linenos">701</span></a> <span class="n">PROPERTIES_LOCATION</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="BigQuery.Generator-702"><a href="#BigQuery.Generator-702"><span class="linenos">702</span></a> <span class="o">**</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">PROPERTIES_LOCATION</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-703"><a href="#BigQuery.Generator-703"><span class="linenos">703</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">PartitionedByProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">POST_SCHEMA</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-704"><a href="#BigQuery.Generator-704"><span class="linenos">704</span></a> <span class="n">exp</span><span class="o">.</span><span class="n">VolatileProperty</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="o">.</span><span class="n">Location</span><span class="o">.</span><span class="n">UNSUPPORTED</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-705"><a href="#BigQuery.Generator-705"><span class="linenos">705</span></a> <span class="p">}</span>
+</span><span id="BigQuery.Generator-706"><a href="#BigQuery.Generator-706"><span class="linenos">706</span></a>
+</span><span id="BigQuery.Generator-707"><a href="#BigQuery.Generator-707"><span class="linenos">707</span></a> <span class="c1"># from: https://cloud.google.com/bigquery/docs/reference/standard-sql/lexical#reserved_keywords</span>
+</span><span id="BigQuery.Generator-708"><a href="#BigQuery.Generator-708"><span class="linenos">708</span></a> <span class="n">RESERVED_KEYWORDS</span> <span class="o">=</span> <span class="p">{</span>
+</span><span id="BigQuery.Generator-709"><a href="#BigQuery.Generator-709"><span class="linenos">709</span></a> <span class="o">*</span><span class="n">generator</span><span class="o">.</span><span class="n">Generator</span><span class="o">.</span><span class="n">RESERVED_KEYWORDS</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-710"><a href="#BigQuery.Generator-710"><span class="linenos">710</span></a> <span class="s2">&quot;all&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-711"><a href="#BigQuery.Generator-711"><span class="linenos">711</span></a> <span class="s2">&quot;and&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-712"><a href="#BigQuery.Generator-712"><span class="linenos">712</span></a> <span class="s2">&quot;any&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-713"><a href="#BigQuery.Generator-713"><span class="linenos">713</span></a> <span class="s2">&quot;array&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-714"><a href="#BigQuery.Generator-714"><span class="linenos">714</span></a> <span class="s2">&quot;as&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-715"><a href="#BigQuery.Generator-715"><span class="linenos">715</span></a> <span class="s2">&quot;asc&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-716"><a href="#BigQuery.Generator-716"><span class="linenos">716</span></a> <span class="s2">&quot;assert_rows_modified&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-717"><a href="#BigQuery.Generator-717"><span class="linenos">717</span></a> <span class="s2">&quot;at&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-718"><a href="#BigQuery.Generator-718"><span class="linenos">718</span></a> <span class="s2">&quot;between&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-719"><a href="#BigQuery.Generator-719"><span class="linenos">719</span></a> <span class="s2">&quot;by&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-720"><a href="#BigQuery.Generator-720"><span class="linenos">720</span></a> <span class="s2">&quot;case&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-721"><a href="#BigQuery.Generator-721"><span class="linenos">721</span></a> <span class="s2">&quot;cast&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-722"><a href="#BigQuery.Generator-722"><span class="linenos">722</span></a> <span class="s2">&quot;collate&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-723"><a href="#BigQuery.Generator-723"><span class="linenos">723</span></a> <span class="s2">&quot;contains&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-724"><a href="#BigQuery.Generator-724"><span class="linenos">724</span></a> <span class="s2">&quot;create&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-725"><a href="#BigQuery.Generator-725"><span class="linenos">725</span></a> <span class="s2">&quot;cross&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-726"><a href="#BigQuery.Generator-726"><span class="linenos">726</span></a> <span class="s2">&quot;cube&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-727"><a href="#BigQuery.Generator-727"><span class="linenos">727</span></a> <span class="s2">&quot;current&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-728"><a href="#BigQuery.Generator-728"><span class="linenos">728</span></a> <span class="s2">&quot;default&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-729"><a href="#BigQuery.Generator-729"><span class="linenos">729</span></a> <span class="s2">&quot;define&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-730"><a href="#BigQuery.Generator-730"><span class="linenos">730</span></a> <span class="s2">&quot;desc&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-731"><a href="#BigQuery.Generator-731"><span class="linenos">731</span></a> <span class="s2">&quot;distinct&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-732"><a href="#BigQuery.Generator-732"><span class="linenos">732</span></a> <span class="s2">&quot;else&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-733"><a href="#BigQuery.Generator-733"><span class="linenos">733</span></a> <span class="s2">&quot;end&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-734"><a href="#BigQuery.Generator-734"><span class="linenos">734</span></a> <span class="s2">&quot;enum&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-735"><a href="#BigQuery.Generator-735"><span class="linenos">735</span></a> <span class="s2">&quot;escape&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-736"><a href="#BigQuery.Generator-736"><span class="linenos">736</span></a> <span class="s2">&quot;except&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-737"><a href="#BigQuery.Generator-737"><span class="linenos">737</span></a> <span class="s2">&quot;exclude&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-738"><a href="#BigQuery.Generator-738"><span class="linenos">738</span></a> <span class="s2">&quot;exists&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-739"><a href="#BigQuery.Generator-739"><span class="linenos">739</span></a> <span class="s2">&quot;extract&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-740"><a href="#BigQuery.Generator-740"><span class="linenos">740</span></a> <span class="s2">&quot;false&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-741"><a href="#BigQuery.Generator-741"><span class="linenos">741</span></a> <span class="s2">&quot;fetch&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-742"><a href="#BigQuery.Generator-742"><span class="linenos">742</span></a> <span class="s2">&quot;following&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-743"><a href="#BigQuery.Generator-743"><span class="linenos">743</span></a> <span class="s2">&quot;for&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-744"><a href="#BigQuery.Generator-744"><span class="linenos">744</span></a> <span class="s2">&quot;from&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-745"><a href="#BigQuery.Generator-745"><span class="linenos">745</span></a> <span class="s2">&quot;full&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-746"><a href="#BigQuery.Generator-746"><span class="linenos">746</span></a> <span class="s2">&quot;group&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-747"><a href="#BigQuery.Generator-747"><span class="linenos">747</span></a> <span class="s2">&quot;grouping&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-748"><a href="#BigQuery.Generator-748"><span class="linenos">748</span></a> <span class="s2">&quot;groups&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-749"><a href="#BigQuery.Generator-749"><span class="linenos">749</span></a> <span class="s2">&quot;hash&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-750"><a href="#BigQuery.Generator-750"><span class="linenos">750</span></a> <span class="s2">&quot;having&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-751"><a href="#BigQuery.Generator-751"><span class="linenos">751</span></a> <span class="s2">&quot;if&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-752"><a href="#BigQuery.Generator-752"><span class="linenos">752</span></a> <span class="s2">&quot;ignore&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-753"><a href="#BigQuery.Generator-753"><span class="linenos">753</span></a> <span class="s2">&quot;in&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-754"><a href="#BigQuery.Generator-754"><span class="linenos">754</span></a> <span class="s2">&quot;inner&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-755"><a href="#BigQuery.Generator-755"><span class="linenos">755</span></a> <span class="s2">&quot;intersect&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-756"><a href="#BigQuery.Generator-756"><span class="linenos">756</span></a> <span class="s2">&quot;interval&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-757"><a href="#BigQuery.Generator-757"><span class="linenos">757</span></a> <span class="s2">&quot;into&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-758"><a href="#BigQuery.Generator-758"><span class="linenos">758</span></a> <span class="s2">&quot;is&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-759"><a href="#BigQuery.Generator-759"><span class="linenos">759</span></a> <span class="s2">&quot;join&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-760"><a href="#BigQuery.Generator-760"><span class="linenos">760</span></a> <span class="s2">&quot;lateral&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-761"><a href="#BigQuery.Generator-761"><span class="linenos">761</span></a> <span class="s2">&quot;left&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-762"><a href="#BigQuery.Generator-762"><span class="linenos">762</span></a> <span class="s2">&quot;like&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-763"><a href="#BigQuery.Generator-763"><span class="linenos">763</span></a> <span class="s2">&quot;limit&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-764"><a href="#BigQuery.Generator-764"><span class="linenos">764</span></a> <span class="s2">&quot;lookup&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-765"><a href="#BigQuery.Generator-765"><span class="linenos">765</span></a> <span class="s2">&quot;merge&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-766"><a href="#BigQuery.Generator-766"><span class="linenos">766</span></a> <span class="s2">&quot;natural&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-767"><a href="#BigQuery.Generator-767"><span class="linenos">767</span></a> <span class="s2">&quot;new&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-768"><a href="#BigQuery.Generator-768"><span class="linenos">768</span></a> <span class="s2">&quot;no&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-769"><a href="#BigQuery.Generator-769"><span class="linenos">769</span></a> <span class="s2">&quot;not&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-770"><a href="#BigQuery.Generator-770"><span class="linenos">770</span></a> <span class="s2">&quot;null&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-771"><a href="#BigQuery.Generator-771"><span class="linenos">771</span></a> <span class="s2">&quot;nulls&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-772"><a href="#BigQuery.Generator-772"><span class="linenos">772</span></a> <span class="s2">&quot;of&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-773"><a href="#BigQuery.Generator-773"><span class="linenos">773</span></a> <span class="s2">&quot;on&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-774"><a href="#BigQuery.Generator-774"><span class="linenos">774</span></a> <span class="s2">&quot;or&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-775"><a href="#BigQuery.Generator-775"><span class="linenos">775</span></a> <span class="s2">&quot;order&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-776"><a href="#BigQuery.Generator-776"><span class="linenos">776</span></a> <span class="s2">&quot;outer&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-777"><a href="#BigQuery.Generator-777"><span class="linenos">777</span></a> <span class="s2">&quot;over&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-778"><a href="#BigQuery.Generator-778"><span class="linenos">778</span></a> <span class="s2">&quot;partition&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-779"><a href="#BigQuery.Generator-779"><span class="linenos">779</span></a> <span class="s2">&quot;preceding&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-780"><a href="#BigQuery.Generator-780"><span class="linenos">780</span></a> <span class="s2">&quot;proto&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-781"><a href="#BigQuery.Generator-781"><span class="linenos">781</span></a> <span class="s2">&quot;qualify&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-782"><a href="#BigQuery.Generator-782"><span class="linenos">782</span></a> <span class="s2">&quot;range&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-783"><a href="#BigQuery.Generator-783"><span class="linenos">783</span></a> <span class="s2">&quot;recursive&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-784"><a href="#BigQuery.Generator-784"><span class="linenos">784</span></a> <span class="s2">&quot;respect&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-785"><a href="#BigQuery.Generator-785"><span class="linenos">785</span></a> <span class="s2">&quot;right&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-786"><a href="#BigQuery.Generator-786"><span class="linenos">786</span></a> <span class="s2">&quot;rollup&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-787"><a href="#BigQuery.Generator-787"><span class="linenos">787</span></a> <span class="s2">&quot;rows&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-788"><a href="#BigQuery.Generator-788"><span class="linenos">788</span></a> <span class="s2">&quot;select&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-789"><a href="#BigQuery.Generator-789"><span class="linenos">789</span></a> <span class="s2">&quot;set&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-790"><a href="#BigQuery.Generator-790"><span class="linenos">790</span></a> <span class="s2">&quot;some&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-791"><a href="#BigQuery.Generator-791"><span class="linenos">791</span></a> <span class="s2">&quot;struct&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-792"><a href="#BigQuery.Generator-792"><span class="linenos">792</span></a> <span class="s2">&quot;tablesample&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-793"><a href="#BigQuery.Generator-793"><span class="linenos">793</span></a> <span class="s2">&quot;then&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-794"><a href="#BigQuery.Generator-794"><span class="linenos">794</span></a> <span class="s2">&quot;to&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-795"><a href="#BigQuery.Generator-795"><span class="linenos">795</span></a> <span class="s2">&quot;treat&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-796"><a href="#BigQuery.Generator-796"><span class="linenos">796</span></a> <span class="s2">&quot;true&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-797"><a href="#BigQuery.Generator-797"><span class="linenos">797</span></a> <span class="s2">&quot;unbounded&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-798"><a href="#BigQuery.Generator-798"><span class="linenos">798</span></a> <span class="s2">&quot;union&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-799"><a href="#BigQuery.Generator-799"><span class="linenos">799</span></a> <span class="s2">&quot;unnest&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-800"><a href="#BigQuery.Generator-800"><span class="linenos">800</span></a> <span class="s2">&quot;using&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-801"><a href="#BigQuery.Generator-801"><span class="linenos">801</span></a> <span class="s2">&quot;when&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-802"><a href="#BigQuery.Generator-802"><span class="linenos">802</span></a> <span class="s2">&quot;where&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-803"><a href="#BigQuery.Generator-803"><span class="linenos">803</span></a> <span class="s2">&quot;window&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-804"><a href="#BigQuery.Generator-804"><span class="linenos">804</span></a> <span class="s2">&quot;with&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-805"><a href="#BigQuery.Generator-805"><span class="linenos">805</span></a> <span class="s2">&quot;within&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-806"><a href="#BigQuery.Generator-806"><span class="linenos">806</span></a> <span class="p">}</span>
+</span><span id="BigQuery.Generator-807"><a href="#BigQuery.Generator-807"><span class="linenos">807</span></a>
+</span><span id="BigQuery.Generator-808"><a href="#BigQuery.Generator-808"><span class="linenos">808</span></a> <span class="k">def</span> <span class="nf">mod_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Mod</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-809"><a href="#BigQuery.Generator-809"><span class="linenos">809</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
+</span><span id="BigQuery.Generator-810"><a href="#BigQuery.Generator-810"><span class="linenos">810</span></a> <span class="n">expr</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expression</span>
+</span><span id="BigQuery.Generator-811"><a href="#BigQuery.Generator-811"><span class="linenos">811</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery.Generator-812"><a href="#BigQuery.Generator-812"><span class="linenos">812</span></a> <span class="s2">&quot;MOD&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-813"><a href="#BigQuery.Generator-813"><span class="linenos">813</span></a> <span class="n">this</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">this</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-814"><a href="#BigQuery.Generator-814"><span class="linenos">814</span></a> <span class="n">expr</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expr</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">expr</span><span class="p">,</span>
+</span><span id="BigQuery.Generator-815"><a href="#BigQuery.Generator-815"><span class="linenos">815</span></a> <span class="p">)</span>
+</span><span id="BigQuery.Generator-816"><a href="#BigQuery.Generator-816"><span class="linenos">816</span></a>
+</span><span id="BigQuery.Generator-817"><a href="#BigQuery.Generator-817"><span class="linenos">817</span></a> <span class="k">def</span> <span class="nf">column_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Column</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-818"><a href="#BigQuery.Generator-818"><span class="linenos">818</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_column&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator-819"><a href="#BigQuery.Generator-819"><span class="linenos">819</span></a> <span class="c1"># If a column reference is of the form `dataset.table`.name, we need</span>
+</span><span id="BigQuery.Generator-820"><a href="#BigQuery.Generator-820"><span class="linenos">820</span></a> <span class="c1"># to preserve the quoted table path, otherwise the reference breaks</span>
+</span><span id="BigQuery.Generator-821"><a href="#BigQuery.Generator-821"><span class="linenos">821</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">[:</span><span class="o">-</span><span class="mi">1</span><span class="p">])</span>
+</span><span id="BigQuery.Generator-822"><a href="#BigQuery.Generator-822"><span class="linenos">822</span></a> <span class="n">table_path</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">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+</span><span id="BigQuery.Generator-823"><a href="#BigQuery.Generator-823"><span class="linenos">823</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="n">table_path</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery.Generator-824"><a href="#BigQuery.Generator-824"><span class="linenos">824</span></a>
+</span><span id="BigQuery.Generator-825"><a href="#BigQuery.Generator-825"><span class="linenos">825</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">column_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-826"><a href="#BigQuery.Generator-826"><span class="linenos">826</span></a>
+</span><span id="BigQuery.Generator-827"><a href="#BigQuery.Generator-827"><span class="linenos">827</span></a> <span class="k">def</span> <span class="nf">table_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Table</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-828"><a href="#BigQuery.Generator-828"><span class="linenos">828</span></a> <span class="c1"># Depending on the context, `x.y` may not resolve to the same data source as `x`.`y`, so</span>
+</span><span id="BigQuery.Generator-829"><a href="#BigQuery.Generator-829"><span class="linenos">829</span></a> <span class="c1"># we need to make sure the correct quoting is used in each case.</span>
+</span><span id="BigQuery.Generator-830"><a href="#BigQuery.Generator-830"><span class="linenos">830</span></a> <span class="c1">#</span>
+</span><span id="BigQuery.Generator-831"><a href="#BigQuery.Generator-831"><span class="linenos">831</span></a> <span class="c1"># For example, if there is a CTE x that clashes with a schema name, then the former will</span>
+</span><span id="BigQuery.Generator-832"><a href="#BigQuery.Generator-832"><span class="linenos">832</span></a> <span class="c1"># return the table y in that schema, whereas the latter will return the CTE&#39;s y column:</span>
+</span><span id="BigQuery.Generator-833"><a href="#BigQuery.Generator-833"><span class="linenos">833</span></a> <span class="c1">#</span>
+</span><span id="BigQuery.Generator-834"><a href="#BigQuery.Generator-834"><span class="linenos">834</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x.y` -&gt; cross join</span>
+</span><span id="BigQuery.Generator-835"><a href="#BigQuery.Generator-835"><span class="linenos">835</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x`.`y` -&gt; implicit unnest</span>
+</span><span id="BigQuery.Generator-836"><a href="#BigQuery.Generator-836"><span class="linenos">836</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_table&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator-837"><a href="#BigQuery.Generator-837"><span class="linenos">837</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-838"><a href="#BigQuery.Generator-838"><span class="linenos">838</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+</span><span id="BigQuery.Generator-839"><a href="#BigQuery.Generator-839"><span class="linenos">839</span></a>
+</span><span id="BigQuery.Generator-840"><a href="#BigQuery.Generator-840"><span class="linenos">840</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">table_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-841"><a href="#BigQuery.Generator-841"><span class="linenos">841</span></a>
+</span><span id="BigQuery.Generator-842"><a href="#BigQuery.Generator-842"><span class="linenos">842</span></a> <span class="k">def</span> <span class="nf">timetostr_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TimeToStr</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-843"><a href="#BigQuery.Generator-843"><span class="linenos">843</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToDate</span><span class="p">)</span> <span class="k">else</span> <span class="n">expression</span>
+</span><span id="BigQuery.Generator-844"><a href="#BigQuery.Generator-844"><span class="linenos">844</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;FORMAT_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">expression</span><span class="p">),</span> <span class="n">this</span><span class="o">.</span><span class="n">this</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-845"><a href="#BigQuery.Generator-845"><span class="linenos">845</span></a>
+</span><span id="BigQuery.Generator-846"><a href="#BigQuery.Generator-846"><span class="linenos">846</span></a> <span class="k">def</span> <span class="nf">eq_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">EQ</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-847"><a href="#BigQuery.Generator-847"><span class="linenos">847</span></a> <span class="c1"># Operands of = cannot be NULL in BigQuery</span>
+</span><span id="BigQuery.Generator-848"><a href="#BigQuery.Generator-848"><span class="linenos">848</span></a> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">left</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">)</span> <span class="ow">or</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">right</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">):</span>
+</span><span id="BigQuery.Generator-849"><a href="#BigQuery.Generator-849"><span class="linenos">849</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Update</span><span class="p">):</span>
+</span><span id="BigQuery.Generator-850"><a href="#BigQuery.Generator-850"><span class="linenos">850</span></a> <span class="k">return</span> <span class="s2">&quot;NULL&quot;</span>
+</span><span id="BigQuery.Generator-851"><a href="#BigQuery.Generator-851"><span class="linenos">851</span></a>
+</span><span id="BigQuery.Generator-852"><a href="#BigQuery.Generator-852"><span class="linenos">852</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">binary</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="s2">&quot;=&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-853"><a href="#BigQuery.Generator-853"><span class="linenos">853</span></a>
+</span><span id="BigQuery.Generator-854"><a href="#BigQuery.Generator-854"><span class="linenos">854</span></a> <span class="k">def</span> <span class="nf">attimezone_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">AtTimeZone</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-855"><a href="#BigQuery.Generator-855"><span class="linenos">855</span></a> <span class="n">parent</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">parent</span>
+</span><span id="BigQuery.Generator-856"><a href="#BigQuery.Generator-856"><span class="linenos">856</span></a>
+</span><span id="BigQuery.Generator-857"><a href="#BigQuery.Generator-857"><span class="linenos">857</span></a> <span class="c1"># BigQuery allows CAST(.. AS {STRING|TIMESTAMP} [FORMAT &lt;fmt&gt; [AT TIME ZONE &lt;tz&gt;]]).</span>
+</span><span id="BigQuery.Generator-858"><a href="#BigQuery.Generator-858"><span class="linenos">858</span></a> <span class="c1"># Only the TIMESTAMP one should use the below conversion, when AT TIME ZONE is included.</span>
+</span><span id="BigQuery.Generator-859"><a href="#BigQuery.Generator-859"><span class="linenos">859</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">)</span> <span class="ow">or</span> <span class="ow">not</span> <span class="n">parent</span><span class="o">.</span><span class="n">to</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="s2">&quot;text&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator-860"><a href="#BigQuery.Generator-860"><span class="linenos">860</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery.Generator-861"><a href="#BigQuery.Generator-861"><span class="linenos">861</span></a> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">))</span>
+</span><span id="BigQuery.Generator-862"><a href="#BigQuery.Generator-862"><span class="linenos">862</span></a> <span class="p">)</span>
+</span><span id="BigQuery.Generator-863"><a href="#BigQuery.Generator-863"><span class="linenos">863</span></a>
+</span><span id="BigQuery.Generator-864"><a href="#BigQuery.Generator-864"><span class="linenos">864</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">attimezone_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-865"><a href="#BigQuery.Generator-865"><span class="linenos">865</span></a>
+</span><span id="BigQuery.Generator-866"><a href="#BigQuery.Generator-866"><span class="linenos">866</span></a> <span class="k">def</span> <span class="nf">trycast_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TryCast</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-867"><a href="#BigQuery.Generator-867"><span class="linenos">867</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">cast_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">safe_prefix</span><span class="o">=</span><span class="s2">&quot;SAFE_&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-868"><a href="#BigQuery.Generator-868"><span class="linenos">868</span></a>
+</span><span id="BigQuery.Generator-869"><a href="#BigQuery.Generator-869"><span class="linenos">869</span></a> <span class="k">def</span> <span class="nf">bracket_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Bracket</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-870"><a href="#BigQuery.Generator-870"><span class="linenos">870</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
+</span><span id="BigQuery.Generator-871"><a href="#BigQuery.Generator-871"><span class="linenos">871</span></a> <span class="n">expressions</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expressions</span>
+</span><span id="BigQuery.Generator-872"><a href="#BigQuery.Generator-872"><span class="linenos">872</span></a>
+</span><span id="BigQuery.Generator-873"><a href="#BigQuery.Generator-873"><span class="linenos">873</span></a> <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">expressions</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> <span class="ow">and</span> <span class="n">this</span> <span class="ow">and</span> <span class="n">this</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">STRUCT</span><span class="p">):</span>
+</span><span id="BigQuery.Generator-874"><a href="#BigQuery.Generator-874"><span class="linenos">874</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">expressions</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
+</span><span id="BigQuery.Generator-875"><a href="#BigQuery.Generator-875"><span class="linenos">875</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">is</span> <span class="kc">None</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-876"><a href="#BigQuery.Generator-876"><span class="linenos">876</span></a> <span class="kn">from</span> <span class="nn">sqlglot.optimizer.annotate_types</span> <span class="kn">import</span> <span class="n">annotate_types</span>
+</span><span id="BigQuery.Generator-877"><a href="#BigQuery.Generator-877"><span class="linenos">877</span></a>
+</span><span id="BigQuery.Generator-878"><a href="#BigQuery.Generator-878"><span class="linenos">878</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">annotate_types</span><span class="p">(</span><span class="n">arg</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-879"><a href="#BigQuery.Generator-879"><span class="linenos">879</span></a>
+</span><span id="BigQuery.Generator-880"><a href="#BigQuery.Generator-880"><span class="linenos">880</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">and</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span><span class="o">.</span><span class="n">this</span> <span class="ow">in</span> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">TEXT_TYPES</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-881"><a href="#BigQuery.Generator-881"><span class="linenos">881</span></a> <span class="c1"># BQ doesn&#39;t support bracket syntax with string values for structs</span>
+</span><span id="BigQuery.Generator-882"><a href="#BigQuery.Generator-882"><span class="linenos">882</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="n">arg</span><span class="o">.</span><span class="n">name</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery.Generator-883"><a href="#BigQuery.Generator-883"><span class="linenos">883</span></a>
+</span><span id="BigQuery.Generator-884"><a href="#BigQuery.Generator-884"><span class="linenos">884</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">expressions</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">flat</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-885"><a href="#BigQuery.Generator-885"><span class="linenos">885</span></a> <span class="n">offset</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;offset&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-886"><a href="#BigQuery.Generator-886"><span class="linenos">886</span></a>
+</span><span id="BigQuery.Generator-887"><a href="#BigQuery.Generator-887"><span class="linenos">887</span></a> <span class="k">if</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-888"><a href="#BigQuery.Generator-888"><span class="linenos">888</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;OFFSET(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
+</span><span id="BigQuery.Generator-889"><a href="#BigQuery.Generator-889"><span class="linenos">889</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-890"><a href="#BigQuery.Generator-890"><span class="linenos">890</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;ORDINAL(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
+</span><span id="BigQuery.Generator-891"><a href="#BigQuery.Generator-891"><span class="linenos">891</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-892"><a href="#BigQuery.Generator-892"><span class="linenos">892</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Unsupported array offset: </span><span class="si">{</span><span class="n">offset</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-893"><a href="#BigQuery.Generator-893"><span class="linenos">893</span></a>
+</span><span id="BigQuery.Generator-894"><a href="#BigQuery.Generator-894"><span class="linenos">894</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;safe&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator-895"><a href="#BigQuery.Generator-895"><span class="linenos">895</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SAFE_</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery.Generator-896"><a href="#BigQuery.Generator-896"><span class="linenos">896</span></a>
+</span><span id="BigQuery.Generator-897"><a href="#BigQuery.Generator-897"><span class="linenos">897</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">[</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">]&quot;</span>
+</span><span id="BigQuery.Generator-898"><a href="#BigQuery.Generator-898"><span class="linenos">898</span></a>
+</span><span id="BigQuery.Generator-899"><a href="#BigQuery.Generator-899"><span class="linenos">899</span></a> <span class="k">def</span> <span class="nf">in_unnest_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Unnest</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-900"><a href="#BigQuery.Generator-900"><span class="linenos">900</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-901"><a href="#BigQuery.Generator-901"><span class="linenos">901</span></a>
+</span><span id="BigQuery.Generator-902"><a href="#BigQuery.Generator-902"><span class="linenos">902</span></a> <span class="k">def</span> <span class="nf">except_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Except</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-903"><a href="#BigQuery.Generator-903"><span class="linenos">903</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator-904"><a href="#BigQuery.Generator-904"><span class="linenos">904</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;EXCEPT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-905"><a href="#BigQuery.Generator-905"><span class="linenos">905</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;EXCEPT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery.Generator-906"><a href="#BigQuery.Generator-906"><span class="linenos">906</span></a>
+</span><span id="BigQuery.Generator-907"><a href="#BigQuery.Generator-907"><span class="linenos">907</span></a> <span class="k">def</span> <span class="nf">intersect_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Intersect</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-908"><a href="#BigQuery.Generator-908"><span class="linenos">908</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator-909"><a href="#BigQuery.Generator-909"><span class="linenos">909</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;INTERSECT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-910"><a href="#BigQuery.Generator-910"><span class="linenos">910</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;INTERSECT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery.Generator-911"><a href="#BigQuery.Generator-911"><span class="linenos">911</span></a>
+</span><span id="BigQuery.Generator-912"><a href="#BigQuery.Generator-912"><span class="linenos">912</span></a> <span class="k">def</span> <span class="nf">version_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Version</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-913"><a href="#BigQuery.Generator-913"><span class="linenos">913</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">:</span>
+</span><span id="BigQuery.Generator-914"><a href="#BigQuery.Generator-914"><span class="linenos">914</span></a> <span class="n">expression</span><span class="o">.</span><span class="n">set</span><span class="p">(</span><span class="s2">&quot;this&quot;</span><span class="p">,</span> <span class="s2">&quot;SYSTEM_TIME&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator-915"><a href="#BigQuery.Generator-915"><span class="linenos">915</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">version_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
</span></pre></div>
@@ -3989,11 +3984,23 @@ Default: True</li>
</div>
+ <div id="BigQuery.Generator.WITH_PROPERTIES_PREFIX" class="classattr">
+ <div class="attr variable">
+ <span class="name">WITH_PROPERTIES_PREFIX</span> =
+<span class="default_value">&#39;OPTIONS&#39;</span>
+
+
+ </div>
+ <a class="headerlink" href="#BigQuery.Generator.WITH_PROPERTIES_PREFIX"></a>
+
+
+
+ </div>
<div id="BigQuery.Generator.TRANSFORMS" class="classattr">
<div class="attr variable">
<span class="name">TRANSFORMS</span> =
<input id="BigQuery.Generator.TRANSFORMS-view-value" class="view-value-toggle-state" type="checkbox" aria-hidden="true" tabindex="-1">
- <label class="view-value-button pdoc-button" for="BigQuery.Generator.TRANSFORMS-view-value"></label><span class="default_value">{&lt;class &#39;<a href="../expressions.html#JSONPathKey">sqlglot.expressions.JSONPathKey</a>&#39;&gt;: &lt;function &lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#JSONPathRoot">sqlglot.expressions.JSONPathRoot</a>&#39;&gt;: &lt;function &lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#JSONPathSubscript">sqlglot.expressions.JSONPathSubscript</a>&#39;&gt;: &lt;function &lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#AllowedValuesProperty">sqlglot.expressions.AllowedValuesProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#AutoRefreshProperty">sqlglot.expressions.AutoRefreshProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#BackupProperty">sqlglot.expressions.BackupProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CaseSpecificColumnConstraint">sqlglot.expressions.CaseSpecificColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CharacterSetColumnConstraint">sqlglot.expressions.CharacterSetColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CharacterSetProperty">sqlglot.expressions.CharacterSetProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ClusteredColumnConstraint">sqlglot.expressions.ClusteredColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CollateColumnConstraint">sqlglot.expressions.CollateColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CommentColumnConstraint">sqlglot.expressions.CommentColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CopyGrantsProperty">sqlglot.expressions.CopyGrantsProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#DateFormatColumnConstraint">sqlglot.expressions.DateFormatColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#DefaultColumnConstraint">sqlglot.expressions.DefaultColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#EncodeColumnConstraint">sqlglot.expressions.EncodeColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#EphemeralColumnConstraint">sqlglot.expressions.EphemeralColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ExcludeColumnConstraint">sqlglot.expressions.ExcludeColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ExecuteAsProperty">sqlglot.expressions.ExecuteAsProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ExternalProperty">sqlglot.expressions.ExternalProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#GlobalProperty">sqlglot.expressions.GlobalProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#HeapProperty">sqlglot.expressions.HeapProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#IcebergProperty">sqlglot.expressions.IcebergProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#InheritsProperty">sqlglot.expressions.InheritsProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#InlineLengthColumnConstraint">sqlglot.expressions.InlineLengthColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#InputModelProperty">sqlglot.expressions.InputModelProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#IntervalSpan">sqlglot.expressions.IntervalSpan</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#JSONExtract">sqlglot.expressions.JSONExtract</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#JSONExtractScalar">sqlglot.expressions.JSONExtractScalar</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#LanguageProperty">sqlglot.expressions.LanguageProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#LocationProperty">sqlglot.expressions.LocationProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#LogProperty">sqlglot.expressions.LogProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#MaterializedProperty">sqlglot.expressions.MaterializedProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#NonClusteredColumnConstraint">sqlglot.expressions.NonClusteredColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#NoPrimaryIndexProperty">sqlglot.expressions.NoPrimaryIndexProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#NotForReplicationColumnConstraint">sqlglot.expressions.NotForReplicationColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#OnCommitProperty">sqlglot.expressions.OnCommitProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#OnProperty">sqlglot.expressions.OnProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#OnUpdateColumnConstraint">sqlglot.expressions.OnUpdateColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#OutputModelProperty">sqlglot.expressions.OutputModelProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#PathColumnConstraint">sqlglot.expressions.PathColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#RemoteWithConnectionModelProperty">sqlglot.expressions.RemoteWithConnectionModelProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ReturnsProperty">sqlglot.expressions.ReturnsProperty</a>&#39;&gt;: &lt;function _returnsproperty_sql&gt;, &lt;class &#39;<a href="../expressions.html#SampleProperty">sqlglot.expressions.SampleProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SetConfigProperty">sqlglot.expressions.SetConfigProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SetProperty">sqlglot.expressions.SetProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SettingsProperty">sqlglot.expressions.SettingsProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SharingProperty">sqlglot.expressions.SharingProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SqlReadWriteProperty">sqlglot.expressions.SqlReadWriteProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SqlSecurityProperty">sqlglot.expressions.SqlSecurityProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#StabilityProperty">sqlglot.expressions.StabilityProperty</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TemporaryProperty">sqlglot.expressions.TemporaryProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TitleColumnConstraint">sqlglot.expressions.TitleColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Timestamp">sqlglot.expressions.Timestamp</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ToMap">sqlglot.expressions.ToMap</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ToTableProperty">sqlglot.expressions.ToTableProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TransformModelProperty">sqlglot.expressions.TransformModelProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TransientProperty">sqlglot.expressions.TransientProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#UppercaseColumnConstraint">sqlglot.expressions.UppercaseColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#UnloggedProperty">sqlglot.expressions.UnloggedProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#VarMap">sqlglot.expressions.VarMap</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ViewAttributeProperty">sqlglot.expressions.ViewAttributeProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#VolatileProperty">sqlglot.expressions.VolatileProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#WithJournalTableProperty">sqlglot.expressions.WithJournalTableProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#WithOperator">sqlglot.expressions.WithOperator</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ApproxDistinct">sqlglot.expressions.ApproxDistinct</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ArgMax">sqlglot.expressions.ArgMax</a>&#39;&gt;: &lt;function arg_max_or_min_no_count.&lt;locals&gt;._arg_max_or_min_sql&gt;, &lt;class &#39;<a href="../expressions.html#ArgMin">sqlglot.expressions.ArgMin</a>&#39;&gt;: &lt;function arg_max_or_min_no_count.&lt;locals&gt;._arg_max_or_min_sql&gt;, &lt;class &#39;<a href="../expressions.html#Array">sqlglot.expressions.Array</a>&#39;&gt;: &lt;function inline_array_unless_query&gt;, &lt;class &#39;<a href="../expressions.html#ArrayContains">sqlglot.expressions.ArrayContains</a>&#39;&gt;: &lt;function _array_contains_sql&gt;, &lt;class &#39;<a href="../expressions.html#ArrayFilter">sqlglot.expressions.ArrayFilter</a>&#39;&gt;: &lt;function filter_array_using_unnest&gt;, &lt;class &#39;<a href="../expressions.html#ArraySize">sqlglot.expressions.ArraySize</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Cast">sqlglot.expressions.Cast</a>&#39;&gt;: &lt;function preprocess.&lt;locals&gt;._to_sql&gt;, &lt;class &#39;<a href="../expressions.html#CollateProperty">sqlglot.expressions.CollateProperty</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Commit">sqlglot.expressions.Commit</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CountIf">sqlglot.expressions.CountIf</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Create">sqlglot.expressions.Create</a>&#39;&gt;: &lt;function _create_sql&gt;, &lt;class &#39;<a href="../expressions.html#CTE">sqlglot.expressions.CTE</a>&#39;&gt;: &lt;function preprocess.&lt;locals&gt;._to_sql&gt;, &lt;class &#39;<a href="../expressions.html#DateAdd">sqlglot.expressions.DateAdd</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#DateDiff">sqlglot.expressions.DateDiff</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#DateFromParts">sqlglot.expressions.DateFromParts</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#DateStrToDate">sqlglot.expressions.DateStrToDate</a>&#39;&gt;: &lt;function datestrtodate_sql&gt;, &lt;class &#39;<a href="../expressions.html#DateSub">sqlglot.expressions.DateSub</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#DatetimeAdd">sqlglot.expressions.DatetimeAdd</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#DatetimeSub">sqlglot.expressions.DatetimeSub</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#DateTrunc">sqlglot.expressions.DateTrunc</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#FromTimeZone">sqlglot.expressions.FromTimeZone</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#GenerateSeries">sqlglot.expressions.GenerateSeries</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#GroupConcat">sqlglot.expressions.GroupConcat</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Hex">sqlglot.expressions.Hex</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#If">sqlglot.expressions.If</a>&#39;&gt;: &lt;function if_sql.&lt;locals&gt;._if_sql&gt;, &lt;class &#39;<a href="../expressions.html#ILike">sqlglot.expressions.ILike</a>&#39;&gt;: &lt;function no_ilike_sql&gt;, &lt;class &#39;<a href="../expressions.html#IntDiv">sqlglot.expressions.IntDiv</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#JSONFormat">sqlglot.expressions.JSONFormat</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Max">sqlglot.expressions.Max</a>&#39;&gt;: &lt;function max_or_greatest&gt;, &lt;class &#39;<a href="../expressions.html#MD5">sqlglot.expressions.MD5</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#MD5Digest">sqlglot.expressions.MD5Digest</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Min">sqlglot.expressions.Min</a>&#39;&gt;: &lt;function min_or_least&gt;, &lt;class &#39;<a href="../expressions.html#PartitionedByProperty">sqlglot.expressions.PartitionedByProperty</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#RegexpExtract">sqlglot.expressions.RegexpExtract</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#RegexpReplace">sqlglot.expressions.RegexpReplace</a>&#39;&gt;: &lt;function regexp_replace_sql&gt;, &lt;class &#39;<a href="../expressions.html#RegexpLike">sqlglot.expressions.RegexpLike</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Rollback">sqlglot.expressions.Rollback</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Select">sqlglot.expressions.Select</a>&#39;&gt;: &lt;function preprocess.&lt;locals&gt;._to_sql&gt;, &lt;class &#39;<a href="../expressions.html#SHA">sqlglot.expressions.SHA</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SHA2">sqlglot.expressions.SHA2</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#StrToDate">sqlglot.expressions.StrToDate</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#StrToTime">sqlglot.expressions.StrToTime</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TimeAdd">sqlglot.expressions.TimeAdd</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#TimeFromParts">sqlglot.expressions.TimeFromParts</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TimeSub">sqlglot.expressions.TimeSub</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#TimestampAdd">sqlglot.expressions.TimestampAdd</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#TimestampDiff">sqlglot.expressions.TimestampDiff</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TimestampSub">sqlglot.expressions.TimestampSub</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#TimeStrToTime">sqlglot.expressions.TimeStrToTime</a>&#39;&gt;: &lt;function timestrtotime_sql&gt;, &lt;class &#39;<a href="../expressions.html#Transaction">sqlglot.expressions.Transaction</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Trim">sqlglot.expressions.Trim</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TsOrDsAdd">sqlglot.expressions.TsOrDsAdd</a>&#39;&gt;: &lt;function _ts_or_ds_add_sql&gt;, &lt;class &#39;<a href="../expressions.html#TsOrDsDiff">sqlglot.expressions.TsOrDsDiff</a>&#39;&gt;: &lt;function _ts_or_ds_diff_sql&gt;, &lt;class &#39;<a href="../expressions.html#TsOrDsToTime">sqlglot.expressions.TsOrDsToTime</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Unhex">sqlglot.expressions.Unhex</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#UnixDate">sqlglot.expressions.UnixDate</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#UnixToTime">sqlglot.expressions.UnixToTime</a>&#39;&gt;: &lt;function _unix_to_time_sql&gt;, &lt;class &#39;<a href="../expressions.html#Values">sqlglot.expressions.Values</a>&#39;&gt;: &lt;function _derived_table_values_to_unnest&gt;, &lt;class &#39;<a href="../expressions.html#VariancePop">sqlglot.expressions.VariancePop</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;}</span>
+ <label class="view-value-button pdoc-button" for="BigQuery.Generator.TRANSFORMS-view-value"></label><span class="default_value">{&lt;class &#39;<a href="../expressions.html#JSONPathKey">sqlglot.expressions.JSONPathKey</a>&#39;&gt;: &lt;function &lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#JSONPathRoot">sqlglot.expressions.JSONPathRoot</a>&#39;&gt;: &lt;function &lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#JSONPathSubscript">sqlglot.expressions.JSONPathSubscript</a>&#39;&gt;: &lt;function &lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#AllowedValuesProperty">sqlglot.expressions.AllowedValuesProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#AutoRefreshProperty">sqlglot.expressions.AutoRefreshProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#BackupProperty">sqlglot.expressions.BackupProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CaseSpecificColumnConstraint">sqlglot.expressions.CaseSpecificColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CharacterSetColumnConstraint">sqlglot.expressions.CharacterSetColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CharacterSetProperty">sqlglot.expressions.CharacterSetProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ClusteredColumnConstraint">sqlglot.expressions.ClusteredColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CollateColumnConstraint">sqlglot.expressions.CollateColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CommentColumnConstraint">sqlglot.expressions.CommentColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CopyGrantsProperty">sqlglot.expressions.CopyGrantsProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#DateFormatColumnConstraint">sqlglot.expressions.DateFormatColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#DefaultColumnConstraint">sqlglot.expressions.DefaultColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#EncodeColumnConstraint">sqlglot.expressions.EncodeColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#EphemeralColumnConstraint">sqlglot.expressions.EphemeralColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ExcludeColumnConstraint">sqlglot.expressions.ExcludeColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ExecuteAsProperty">sqlglot.expressions.ExecuteAsProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ExternalProperty">sqlglot.expressions.ExternalProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#GlobalProperty">sqlglot.expressions.GlobalProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#HeapProperty">sqlglot.expressions.HeapProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#IcebergProperty">sqlglot.expressions.IcebergProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#InheritsProperty">sqlglot.expressions.InheritsProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#InlineLengthColumnConstraint">sqlglot.expressions.InlineLengthColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#InputModelProperty">sqlglot.expressions.InputModelProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#IntervalSpan">sqlglot.expressions.IntervalSpan</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#JSONExtract">sqlglot.expressions.JSONExtract</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#JSONExtractScalar">sqlglot.expressions.JSONExtractScalar</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#LanguageProperty">sqlglot.expressions.LanguageProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#LocationProperty">sqlglot.expressions.LocationProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#LogProperty">sqlglot.expressions.LogProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#MaterializedProperty">sqlglot.expressions.MaterializedProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#NonClusteredColumnConstraint">sqlglot.expressions.NonClusteredColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#NoPrimaryIndexProperty">sqlglot.expressions.NoPrimaryIndexProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#NotForReplicationColumnConstraint">sqlglot.expressions.NotForReplicationColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#OnCommitProperty">sqlglot.expressions.OnCommitProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#OnProperty">sqlglot.expressions.OnProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#OnUpdateColumnConstraint">sqlglot.expressions.OnUpdateColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#OutputModelProperty">sqlglot.expressions.OutputModelProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#PathColumnConstraint">sqlglot.expressions.PathColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#RemoteWithConnectionModelProperty">sqlglot.expressions.RemoteWithConnectionModelProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ReturnsProperty">sqlglot.expressions.ReturnsProperty</a>&#39;&gt;: &lt;function _returnsproperty_sql&gt;, &lt;class &#39;<a href="../expressions.html#SampleProperty">sqlglot.expressions.SampleProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SetConfigProperty">sqlglot.expressions.SetConfigProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SetProperty">sqlglot.expressions.SetProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SettingsProperty">sqlglot.expressions.SettingsProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SharingProperty">sqlglot.expressions.SharingProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SqlReadWriteProperty">sqlglot.expressions.SqlReadWriteProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SqlSecurityProperty">sqlglot.expressions.SqlSecurityProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#StabilityProperty">sqlglot.expressions.StabilityProperty</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#StrictProperty">sqlglot.expressions.StrictProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TemporaryProperty">sqlglot.expressions.TemporaryProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TitleColumnConstraint">sqlglot.expressions.TitleColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Timestamp">sqlglot.expressions.Timestamp</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ToMap">sqlglot.expressions.ToMap</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ToTableProperty">sqlglot.expressions.ToTableProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TransformModelProperty">sqlglot.expressions.TransformModelProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TransientProperty">sqlglot.expressions.TransientProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#UppercaseColumnConstraint">sqlglot.expressions.UppercaseColumnConstraint</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#UnloggedProperty">sqlglot.expressions.UnloggedProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#VarMap">sqlglot.expressions.VarMap</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ViewAttributeProperty">sqlglot.expressions.ViewAttributeProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#VolatileProperty">sqlglot.expressions.VolatileProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#WithJournalTableProperty">sqlglot.expressions.WithJournalTableProperty</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#WithOperator">sqlglot.expressions.WithOperator</a>&#39;&gt;: &lt;function Generator.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ApproxDistinct">sqlglot.expressions.ApproxDistinct</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#ArgMax">sqlglot.expressions.ArgMax</a>&#39;&gt;: &lt;function arg_max_or_min_no_count.&lt;locals&gt;._arg_max_or_min_sql&gt;, &lt;class &#39;<a href="../expressions.html#ArgMin">sqlglot.expressions.ArgMin</a>&#39;&gt;: &lt;function arg_max_or_min_no_count.&lt;locals&gt;._arg_max_or_min_sql&gt;, &lt;class &#39;<a href="../expressions.html#Array">sqlglot.expressions.Array</a>&#39;&gt;: &lt;function inline_array_unless_query&gt;, &lt;class &#39;<a href="../expressions.html#ArrayContains">sqlglot.expressions.ArrayContains</a>&#39;&gt;: &lt;function _array_contains_sql&gt;, &lt;class &#39;<a href="../expressions.html#ArrayFilter">sqlglot.expressions.ArrayFilter</a>&#39;&gt;: &lt;function filter_array_using_unnest&gt;, &lt;class &#39;<a href="../expressions.html#ArraySize">sqlglot.expressions.ArraySize</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Cast">sqlglot.expressions.Cast</a>&#39;&gt;: &lt;function preprocess.&lt;locals&gt;._to_sql&gt;, &lt;class &#39;<a href="../expressions.html#CollateProperty">sqlglot.expressions.CollateProperty</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Commit">sqlglot.expressions.Commit</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#CountIf">sqlglot.expressions.CountIf</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Create">sqlglot.expressions.Create</a>&#39;&gt;: &lt;function _create_sql&gt;, &lt;class &#39;<a href="../expressions.html#CTE">sqlglot.expressions.CTE</a>&#39;&gt;: &lt;function preprocess.&lt;locals&gt;._to_sql&gt;, &lt;class &#39;<a href="../expressions.html#DateAdd">sqlglot.expressions.DateAdd</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#DateDiff">sqlglot.expressions.DateDiff</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#DateFromParts">sqlglot.expressions.DateFromParts</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#DateStrToDate">sqlglot.expressions.DateStrToDate</a>&#39;&gt;: &lt;function datestrtodate_sql&gt;, &lt;class &#39;<a href="../expressions.html#DateSub">sqlglot.expressions.DateSub</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#DatetimeAdd">sqlglot.expressions.DatetimeAdd</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#DatetimeSub">sqlglot.expressions.DatetimeSub</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#DateTrunc">sqlglot.expressions.DateTrunc</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#FromTimeZone">sqlglot.expressions.FromTimeZone</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#GenerateSeries">sqlglot.expressions.GenerateSeries</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#GroupConcat">sqlglot.expressions.GroupConcat</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Hex">sqlglot.expressions.Hex</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#If">sqlglot.expressions.If</a>&#39;&gt;: &lt;function if_sql.&lt;locals&gt;._if_sql&gt;, &lt;class &#39;<a href="../expressions.html#ILike">sqlglot.expressions.ILike</a>&#39;&gt;: &lt;function no_ilike_sql&gt;, &lt;class &#39;<a href="../expressions.html#IntDiv">sqlglot.expressions.IntDiv</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#JSONFormat">sqlglot.expressions.JSONFormat</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Max">sqlglot.expressions.Max</a>&#39;&gt;: &lt;function max_or_greatest&gt;, &lt;class &#39;<a href="../expressions.html#MD5">sqlglot.expressions.MD5</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#MD5Digest">sqlglot.expressions.MD5Digest</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Min">sqlglot.expressions.Min</a>&#39;&gt;: &lt;function min_or_least&gt;, &lt;class &#39;<a href="../expressions.html#PartitionedByProperty">sqlglot.expressions.PartitionedByProperty</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#RegexpExtract">sqlglot.expressions.RegexpExtract</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#RegexpReplace">sqlglot.expressions.RegexpReplace</a>&#39;&gt;: &lt;function regexp_replace_sql&gt;, &lt;class &#39;<a href="../expressions.html#RegexpLike">sqlglot.expressions.RegexpLike</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Rollback">sqlglot.expressions.Rollback</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Select">sqlglot.expressions.Select</a>&#39;&gt;: &lt;function preprocess.&lt;locals&gt;._to_sql&gt;, &lt;class &#39;<a href="../expressions.html#SHA">sqlglot.expressions.SHA</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#SHA2">sqlglot.expressions.SHA2</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#StrToDate">sqlglot.expressions.StrToDate</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#StrToTime">sqlglot.expressions.StrToTime</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TimeAdd">sqlglot.expressions.TimeAdd</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#TimeFromParts">sqlglot.expressions.TimeFromParts</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TimeSub">sqlglot.expressions.TimeSub</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#TimestampAdd">sqlglot.expressions.TimestampAdd</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#TimestampDiff">sqlglot.expressions.TimestampDiff</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TimestampSub">sqlglot.expressions.TimestampSub</a>&#39;&gt;: &lt;function date_add_interval_sql.&lt;locals&gt;.func&gt;, &lt;class &#39;<a href="../expressions.html#TimeStrToTime">sqlglot.expressions.TimeStrToTime</a>&#39;&gt;: &lt;function timestrtotime_sql&gt;, &lt;class &#39;<a href="../expressions.html#Transaction">sqlglot.expressions.Transaction</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Trim">sqlglot.expressions.Trim</a>&#39;&gt;: &lt;function <a href="#BigQuery.Generator">BigQuery.Generator</a>.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#TsOrDsAdd">sqlglot.expressions.TsOrDsAdd</a>&#39;&gt;: &lt;function _ts_or_ds_add_sql&gt;, &lt;class &#39;<a href="../expressions.html#TsOrDsDiff">sqlglot.expressions.TsOrDsDiff</a>&#39;&gt;: &lt;function _ts_or_ds_diff_sql&gt;, &lt;class &#39;<a href="../expressions.html#TsOrDsToTime">sqlglot.expressions.TsOrDsToTime</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#Unhex">sqlglot.expressions.Unhex</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#UnixDate">sqlglot.expressions.UnixDate</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;, &lt;class &#39;<a href="../expressions.html#UnixToTime">sqlglot.expressions.UnixToTime</a>&#39;&gt;: &lt;function _unix_to_time_sql&gt;, &lt;class &#39;<a href="../expressions.html#Values">sqlglot.expressions.Values</a>&#39;&gt;: &lt;function _derived_table_values_to_unnest&gt;, &lt;class &#39;<a href="../expressions.html#VariancePop">sqlglot.expressions.VariancePop</a>&#39;&gt;: &lt;function rename_func.&lt;locals&gt;.&lt;lambda&gt;&gt;}</span>
</div>
@@ -4006,7 +4013,7 @@ Default: True</li>
<div class="attr variable">
<span class="name">SUPPORTED_JSON_PATH_PARTS</span> =
<input id="BigQuery.Generator.SUPPORTED_JSON_PATH_PARTS-view-value" class="view-value-toggle-state" type="checkbox" aria-hidden="true" tabindex="-1">
- <label class="view-value-button pdoc-button" for="BigQuery.Generator.SUPPORTED_JSON_PATH_PARTS-view-value"></label><span class="default_value">{&lt;class &#39;<a href="../expressions.html#JSONPathRoot">sqlglot.expressions.JSONPathRoot</a>&#39;&gt;, &lt;class &#39;<a href="../expressions.html#JSONPathSubscript">sqlglot.expressions.JSONPathSubscript</a>&#39;&gt;, &lt;class &#39;<a href="../expressions.html#JSONPathKey">sqlglot.expressions.JSONPathKey</a>&#39;&gt;}</span>
+ <label class="view-value-button pdoc-button" for="BigQuery.Generator.SUPPORTED_JSON_PATH_PARTS-view-value"></label><span class="default_value">{&lt;class &#39;<a href="../expressions.html#JSONPathSubscript">sqlglot.expressions.JSONPathSubscript</a>&#39;&gt;, &lt;class &#39;<a href="../expressions.html#JSONPathRoot">sqlglot.expressions.JSONPathRoot</a>&#39;&gt;, &lt;class &#39;<a href="../expressions.html#JSONPathKey">sqlglot.expressions.JSONPathKey</a>&#39;&gt;}</span>
</div>
@@ -4032,7 +4039,7 @@ Default: True</li>
<div class="attr variable">
<span class="name">PROPERTIES_LOCATION</span> =
<input id="BigQuery.Generator.PROPERTIES_LOCATION-view-value" class="view-value-toggle-state" type="checkbox" aria-hidden="true" tabindex="-1">
- <label class="view-value-button pdoc-button" for="BigQuery.Generator.PROPERTIES_LOCATION-view-value"></label><span class="default_value">{&lt;class &#39;<a href="../expressions.html#AllowedValuesProperty">sqlglot.expressions.AllowedValuesProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#AlgorithmProperty">sqlglot.expressions.AlgorithmProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#AutoIncrementProperty">sqlglot.expressions.AutoIncrementProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#AutoRefreshProperty">sqlglot.expressions.AutoRefreshProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#BackupProperty">sqlglot.expressions.BackupProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#BlockCompressionProperty">sqlglot.expressions.BlockCompressionProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#CharacterSetProperty">sqlglot.expressions.CharacterSetProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ChecksumProperty">sqlglot.expressions.ChecksumProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#CollateProperty">sqlglot.expressions.CollateProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#CopyGrantsProperty">sqlglot.expressions.CopyGrantsProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#Cluster">sqlglot.expressions.Cluster</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ClusteredByProperty">sqlglot.expressions.ClusteredByProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DataBlocksizeProperty">sqlglot.expressions.DataBlocksizeProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DefinerProperty">sqlglot.expressions.DefinerProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DictRange">sqlglot.expressions.DictRange</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DictProperty">sqlglot.expressions.DictProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DistKeyProperty">sqlglot.expressions.DistKeyProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DistStyleProperty">sqlglot.expressions.DistStyleProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#EngineProperty">sqlglot.expressions.EngineProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ExecuteAsProperty">sqlglot.expressions.ExecuteAsProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ExternalProperty">sqlglot.expressions.ExternalProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#FallbackProperty">sqlglot.expressions.FallbackProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#FileFormatProperty">sqlglot.expressions.FileFormatProperty</a>&#39;&gt;: &lt;Location.POST_WITH: &#39;POST_WITH&#39;&gt;, &lt;class &#39;<a href="../expressions.html#FreespaceProperty">sqlglot.expressions.FreespaceProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#GlobalProperty">sqlglot.expressions.GlobalProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#HeapProperty">sqlglot.expressions.HeapProperty</a>&#39;&gt;: &lt;Location.POST_WITH: &#39;POST_WITH&#39;&gt;, &lt;class &#39;<a href="../expressions.html#InheritsProperty">sqlglot.expressions.InheritsProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#IcebergProperty">sqlglot.expressions.IcebergProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#InputModelProperty">sqlglot.expressions.InputModelProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#IsolatedLoadingProperty">sqlglot.expressions.IsolatedLoadingProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#JournalProperty">sqlglot.expressions.JournalProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LanguageProperty">sqlglot.expressions.LanguageProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LikeProperty">sqlglot.expressions.LikeProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LocationProperty">sqlglot.expressions.LocationProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LockProperty">sqlglot.expressions.LockProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LockingProperty">sqlglot.expressions.LockingProperty</a>&#39;&gt;: &lt;Location.POST_ALIAS: &#39;POST_ALIAS&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LogProperty">sqlglot.expressions.LogProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#MaterializedProperty">sqlglot.expressions.MaterializedProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#MergeBlockRatioProperty">sqlglot.expressions.MergeBlockRatioProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#NoPrimaryIndexProperty">sqlglot.expressions.NoPrimaryIndexProperty</a>&#39;&gt;: &lt;Location.POST_EXPRESSION: &#39;POST_EXPRESSION&#39;&gt;, &lt;class &#39;<a href="../expressions.html#OnProperty">sqlglot.expressions.OnProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#OnCommitProperty">sqlglot.expressions.OnCommitProperty</a>&#39;&gt;: &lt;Location.POST_EXPRESSION: &#39;POST_EXPRESSION&#39;&gt;, &lt;class &#39;<a href="../expressions.html#Order">sqlglot.expressions.Order</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#OutputModelProperty">sqlglot.expressions.OutputModelProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#PartitionedByProperty">sqlglot.expressions.PartitionedByProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#PartitionedOfProperty">sqlglot.expressions.PartitionedOfProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#PrimaryKey">sqlglot.expressions.PrimaryKey</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#Property">sqlglot.expressions.Property</a>&#39;&gt;: &lt;Location.POST_WITH: &#39;POST_WITH&#39;&gt;, &lt;class &#39;<a href="../expressions.html#RemoteWithConnectionModelProperty">sqlglot.expressions.RemoteWithConnectionModelProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ReturnsProperty">sqlglot.expressions.ReturnsProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#RowFormatProperty">sqlglot.expressions.RowFormatProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#RowFormatDelimitedProperty">sqlglot.expressions.RowFormatDelimitedProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#RowFormatSerdeProperty">sqlglot.expressions.RowFormatSerdeProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SampleProperty">sqlglot.expressions.SampleProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SchemaCommentProperty">sqlglot.expressions.SchemaCommentProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SerdeProperties">sqlglot.expressions.SerdeProperties</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#Set">sqlglot.expressions.Set</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SettingsProperty">sqlglot.expressions.SettingsProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SetProperty">sqlglot.expressions.SetProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SetConfigProperty">sqlglot.expressions.SetConfigProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SharingProperty">sqlglot.expressions.SharingProperty</a>&#39;&gt;: &lt;Location.POST_EXPRESSION: &#39;POST_EXPRESSION&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SequenceProperties">sqlglot.expressions.SequenceProperties</a>&#39;&gt;: &lt;Location.POST_EXPRESSION: &#39;POST_EXPRESSION&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SortKeyProperty">sqlglot.expressions.SortKeyProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SqlReadWriteProperty">sqlglot.expressions.SqlReadWriteProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SqlSecurityProperty">sqlglot.expressions.SqlSecurityProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#StabilityProperty">sqlglot.expressions.StabilityProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#TemporaryProperty">sqlglot.expressions.TemporaryProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ToTableProperty">sqlglot.expressions.ToTableProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#TransientProperty">sqlglot.expressions.TransientProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#TransformModelProperty">sqlglot.expressions.TransformModelProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#MergeTreeTTL">sqlglot.expressions.MergeTreeTTL</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#UnloggedProperty">sqlglot.expressions.UnloggedProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ViewAttributeProperty">sqlglot.expressions.ViewAttributeProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#VolatileProperty">sqlglot.expressions.VolatileProperty</a>&#39;&gt;: &lt;Location.UNSUPPORTED: &#39;UNSUPPORTED&#39;&gt;, &lt;class &#39;<a href="../expressions.html#WithDataProperty">sqlglot.expressions.WithDataProperty</a>&#39;&gt;: &lt;Location.POST_EXPRESSION: &#39;POST_EXPRESSION&#39;&gt;, &lt;class &#39;<a href="../expressions.html#WithJournalTableProperty">sqlglot.expressions.WithJournalTableProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#WithSystemVersioningProperty">sqlglot.expressions.WithSystemVersioningProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;}</span>
+ <label class="view-value-button pdoc-button" for="BigQuery.Generator.PROPERTIES_LOCATION-view-value"></label><span class="default_value">{&lt;class &#39;<a href="../expressions.html#AllowedValuesProperty">sqlglot.expressions.AllowedValuesProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#AlgorithmProperty">sqlglot.expressions.AlgorithmProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#AutoIncrementProperty">sqlglot.expressions.AutoIncrementProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#AutoRefreshProperty">sqlglot.expressions.AutoRefreshProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#BackupProperty">sqlglot.expressions.BackupProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#BlockCompressionProperty">sqlglot.expressions.BlockCompressionProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#CharacterSetProperty">sqlglot.expressions.CharacterSetProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ChecksumProperty">sqlglot.expressions.ChecksumProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#CollateProperty">sqlglot.expressions.CollateProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#CopyGrantsProperty">sqlglot.expressions.CopyGrantsProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#Cluster">sqlglot.expressions.Cluster</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ClusteredByProperty">sqlglot.expressions.ClusteredByProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DataBlocksizeProperty">sqlglot.expressions.DataBlocksizeProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DataDeletionProperty">sqlglot.expressions.DataDeletionProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DefinerProperty">sqlglot.expressions.DefinerProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DictRange">sqlglot.expressions.DictRange</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DictProperty">sqlglot.expressions.DictProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DistKeyProperty">sqlglot.expressions.DistKeyProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#DistStyleProperty">sqlglot.expressions.DistStyleProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#EngineProperty">sqlglot.expressions.EngineProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ExecuteAsProperty">sqlglot.expressions.ExecuteAsProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ExternalProperty">sqlglot.expressions.ExternalProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#FallbackProperty">sqlglot.expressions.FallbackProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#FileFormatProperty">sqlglot.expressions.FileFormatProperty</a>&#39;&gt;: &lt;Location.POST_WITH: &#39;POST_WITH&#39;&gt;, &lt;class &#39;<a href="../expressions.html#FreespaceProperty">sqlglot.expressions.FreespaceProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#GlobalProperty">sqlglot.expressions.GlobalProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#HeapProperty">sqlglot.expressions.HeapProperty</a>&#39;&gt;: &lt;Location.POST_WITH: &#39;POST_WITH&#39;&gt;, &lt;class &#39;<a href="../expressions.html#InheritsProperty">sqlglot.expressions.InheritsProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#IcebergProperty">sqlglot.expressions.IcebergProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#InputModelProperty">sqlglot.expressions.InputModelProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#IsolatedLoadingProperty">sqlglot.expressions.IsolatedLoadingProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#JournalProperty">sqlglot.expressions.JournalProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LanguageProperty">sqlglot.expressions.LanguageProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LikeProperty">sqlglot.expressions.LikeProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LocationProperty">sqlglot.expressions.LocationProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LockProperty">sqlglot.expressions.LockProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LockingProperty">sqlglot.expressions.LockingProperty</a>&#39;&gt;: &lt;Location.POST_ALIAS: &#39;POST_ALIAS&#39;&gt;, &lt;class &#39;<a href="../expressions.html#LogProperty">sqlglot.expressions.LogProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#MaterializedProperty">sqlglot.expressions.MaterializedProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#MergeBlockRatioProperty">sqlglot.expressions.MergeBlockRatioProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#NoPrimaryIndexProperty">sqlglot.expressions.NoPrimaryIndexProperty</a>&#39;&gt;: &lt;Location.POST_EXPRESSION: &#39;POST_EXPRESSION&#39;&gt;, &lt;class &#39;<a href="../expressions.html#OnProperty">sqlglot.expressions.OnProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#OnCommitProperty">sqlglot.expressions.OnCommitProperty</a>&#39;&gt;: &lt;Location.POST_EXPRESSION: &#39;POST_EXPRESSION&#39;&gt;, &lt;class &#39;<a href="../expressions.html#Order">sqlglot.expressions.Order</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#OutputModelProperty">sqlglot.expressions.OutputModelProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#PartitionedByProperty">sqlglot.expressions.PartitionedByProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#PartitionedOfProperty">sqlglot.expressions.PartitionedOfProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#PrimaryKey">sqlglot.expressions.PrimaryKey</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#Property">sqlglot.expressions.Property</a>&#39;&gt;: &lt;Location.POST_WITH: &#39;POST_WITH&#39;&gt;, &lt;class &#39;<a href="../expressions.html#RemoteWithConnectionModelProperty">sqlglot.expressions.RemoteWithConnectionModelProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ReturnsProperty">sqlglot.expressions.ReturnsProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#RowFormatProperty">sqlglot.expressions.RowFormatProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#RowFormatDelimitedProperty">sqlglot.expressions.RowFormatDelimitedProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#RowFormatSerdeProperty">sqlglot.expressions.RowFormatSerdeProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SampleProperty">sqlglot.expressions.SampleProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SchemaCommentProperty">sqlglot.expressions.SchemaCommentProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SerdeProperties">sqlglot.expressions.SerdeProperties</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#Set">sqlglot.expressions.Set</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SettingsProperty">sqlglot.expressions.SettingsProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SetProperty">sqlglot.expressions.SetProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SetConfigProperty">sqlglot.expressions.SetConfigProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SharingProperty">sqlglot.expressions.SharingProperty</a>&#39;&gt;: &lt;Location.POST_EXPRESSION: &#39;POST_EXPRESSION&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SequenceProperties">sqlglot.expressions.SequenceProperties</a>&#39;&gt;: &lt;Location.POST_EXPRESSION: &#39;POST_EXPRESSION&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SortKeyProperty">sqlglot.expressions.SortKeyProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SqlReadWriteProperty">sqlglot.expressions.SqlReadWriteProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#SqlSecurityProperty">sqlglot.expressions.SqlSecurityProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#StabilityProperty">sqlglot.expressions.StabilityProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#StrictProperty">sqlglot.expressions.StrictProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#TemporaryProperty">sqlglot.expressions.TemporaryProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ToTableProperty">sqlglot.expressions.ToTableProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#TransientProperty">sqlglot.expressions.TransientProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#TransformModelProperty">sqlglot.expressions.TransformModelProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#MergeTreeTTL">sqlglot.expressions.MergeTreeTTL</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#UnloggedProperty">sqlglot.expressions.UnloggedProperty</a>&#39;&gt;: &lt;Location.POST_CREATE: &#39;POST_CREATE&#39;&gt;, &lt;class &#39;<a href="../expressions.html#ViewAttributeProperty">sqlglot.expressions.ViewAttributeProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;, &lt;class &#39;<a href="../expressions.html#VolatileProperty">sqlglot.expressions.VolatileProperty</a>&#39;&gt;: &lt;Location.UNSUPPORTED: &#39;UNSUPPORTED&#39;&gt;, &lt;class &#39;<a href="../expressions.html#WithDataProperty">sqlglot.expressions.WithDataProperty</a>&#39;&gt;: &lt;Location.POST_EXPRESSION: &#39;POST_EXPRESSION&#39;&gt;, &lt;class &#39;<a href="../expressions.html#WithJournalTableProperty">sqlglot.expressions.WithJournalTableProperty</a>&#39;&gt;: &lt;Location.POST_NAME: &#39;POST_NAME&#39;&gt;, &lt;class &#39;<a href="../expressions.html#WithSystemVersioningProperty">sqlglot.expressions.WithSystemVersioningProperty</a>&#39;&gt;: &lt;Location.POST_SCHEMA: &#39;POST_SCHEMA&#39;&gt;}</span>
</div>
@@ -4045,7 +4052,7 @@ Default: True</li>
<div class="attr variable">
<span class="name">RESERVED_KEYWORDS</span> =
<input id="BigQuery.Generator.RESERVED_KEYWORDS-view-value" class="view-value-toggle-state" type="checkbox" aria-hidden="true" tabindex="-1">
- <label class="view-value-button pdoc-button" for="BigQuery.Generator.RESERVED_KEYWORDS-view-value"></label><span class="default_value">{&#39;preceding&#39;, &#39;else&#39;, &#39;fetch&#39;, &#39;exists&#39;, &#39;like&#39;, &#39;group&#39;, &#39;intersect&#39;, &#39;end&#39;, &#39;contains&#39;, &#39;from&#39;, &#39;case&#39;, &#39;union&#39;, &#39;all&#39;, &#39;cast&#39;, &#39;default&#39;, &#39;in&#39;, &#39;range&#39;, &#39;natural&#39;, &#39;treat&#39;, &#39;unbounded&#39;, &#39;within&#39;, &#39;following&#39;, &#39;left&#39;, &#39;between&#39;, &#39;with&#39;, &#39;array&#39;, &#39;order&#39;, &#39;and&#39;, &#39;for&#39;, &#39;distinct&#39;, &#39;select&#39;, &#39;when&#39;, &#39;except&#39;, &#39;new&#39;, &#39;into&#39;, &#39;any&#39;, &#39;exclude&#39;, &#39;is&#39;, &#39;on&#39;, &#39;inner&#39;, &#39;hash&#39;, &#39;window&#39;, &#39;null&#39;, &#39;join&#39;, &#39;full&#39;, &#39;by&#39;, &#39;desc&#39;, &#39;grouping&#39;, &#39;interval&#39;, &#39;using&#39;, &#39;collate&#39;, &#39;respect&#39;, &#39;rollup&#39;, &#39;assert_rows_modified&#39;, &#39;rows&#39;, &#39;cube&#39;, &#39;right&#39;, &#39;some&#39;, &#39;lookup&#39;, &#39;no&#39;, &#39;enum&#39;, &#39;merge&#39;, &#39;create&#39;, &#39;of&#39;, &#39;proto&#39;, &#39;then&#39;, &#39;cross&#39;, &#39;partition&#39;, &#39;over&#39;, &#39;where&#39;, &#39;struct&#39;, &#39;escape&#39;, &#39;limit&#39;, &#39;or&#39;, &#39;extract&#39;, &#39;define&#39;, &#39;false&#39;, &#39;ignore&#39;, &#39;current&#39;, &#39;qualify&#39;, &#39;unnest&#39;, &#39;outer&#39;, &#39;set&#39;, &#39;nulls&#39;, &#39;lateral&#39;, &#39;to&#39;, &#39;asc&#39;, &#39;having&#39;, &#39;not&#39;, &#39;if&#39;, &#39;groups&#39;, &#39;recursive&#39;, &#39;as&#39;, &#39;tablesample&#39;, &#39;true&#39;, &#39;at&#39;}</span>
+ <label class="view-value-button pdoc-button" for="BigQuery.Generator.RESERVED_KEYWORDS-view-value"></label><span class="default_value">{&#39;cross&#39;, &#39;false&#39;, &#39;treat&#39;, &#39;some&#39;, &#39;recursive&#39;, &#39;then&#39;, &#39;unnest&#39;, &#39;for&#39;, &#39;right&#39;, &#39;all&#39;, &#39;any&#39;, &#39;true&#39;, &#39;following&#39;, &#39;union&#39;, &#39;within&#39;, &#39;current&#39;, &#39;desc&#39;, &#39;create&#39;, &#39;by&#39;, &#39;define&#39;, &#39;outer&#39;, &#39;using&#39;, &#39;qualify&#39;, &#39;when&#39;, &#39;respect&#39;, &#39;full&#39;, &#39;rows&#39;, &#39;else&#39;, &#39;enum&#39;, &#39;lookup&#39;, &#39;assert_rows_modified&#39;, &#39;extract&#39;, &#39;end&#39;, &#39;asc&#39;, &#39;range&#39;, &#39;new&#39;, &#39;natural&#39;, &#39;fetch&#39;, &#39;window&#39;, &#39;with&#39;, &#39;hash&#39;, &#39;interval&#39;, &#39;is&#39;, &#39;from&#39;, &#39;set&#39;, &#39;and&#39;, &#39;at&#39;, &#39;like&#39;, &#39;default&#39;, &#39;cast&#39;, &#39;preceding&#39;, &#39;inner&#39;, &#39;except&#39;, &#39;nulls&#39;, &#39;escape&#39;, &#39;if&#39;, &#39;having&#39;, &#39;join&#39;, &#39;contains&#39;, &#39;collate&#39;, &#39;case&#39;, &#39;exists&#39;, &#39;merge&#39;, &#39;in&#39;, &#39;rollup&#39;, &#39;or&#39;, &#39;between&#39;, &#39;groups&#39;, &#39;proto&#39;, &#39;intersect&#39;, &#39;distinct&#39;, &#39;on&#39;, &#39;lateral&#39;, &#39;of&#39;, &#39;cube&#39;, &#39;not&#39;, &#39;group&#39;, &#39;limit&#39;, &#39;over&#39;, &#39;into&#39;, &#39;struct&#39;, &#39;tablesample&#39;, &#39;left&#39;, &#39;as&#39;, &#39;select&#39;, &#39;partition&#39;, &#39;exclude&#39;, &#39;unbounded&#39;, &#39;where&#39;, &#39;array&#39;, &#39;null&#39;, &#39;no&#39;, &#39;to&#39;, &#39;order&#39;, &#39;ignore&#39;, &#39;grouping&#39;}</span>
</div>
@@ -4065,14 +4072,14 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.mod_sql"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.mod_sql-807"><a href="#BigQuery.Generator.mod_sql-807"><span class="linenos">807</span></a> <span class="k">def</span> <span class="nf">mod_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Mod</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.mod_sql-808"><a href="#BigQuery.Generator.mod_sql-808"><span class="linenos">808</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
-</span><span id="BigQuery.Generator.mod_sql-809"><a href="#BigQuery.Generator.mod_sql-809"><span class="linenos">809</span></a> <span class="n">expr</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expression</span>
-</span><span id="BigQuery.Generator.mod_sql-810"><a href="#BigQuery.Generator.mod_sql-810"><span class="linenos">810</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery.Generator.mod_sql-811"><a href="#BigQuery.Generator.mod_sql-811"><span class="linenos">811</span></a> <span class="s2">&quot;MOD&quot;</span><span class="p">,</span>
-</span><span id="BigQuery.Generator.mod_sql-812"><a href="#BigQuery.Generator.mod_sql-812"><span class="linenos">812</span></a> <span class="n">this</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">this</span><span class="p">,</span>
-</span><span id="BigQuery.Generator.mod_sql-813"><a href="#BigQuery.Generator.mod_sql-813"><span class="linenos">813</span></a> <span class="n">expr</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expr</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">expr</span><span class="p">,</span>
-</span><span id="BigQuery.Generator.mod_sql-814"><a href="#BigQuery.Generator.mod_sql-814"><span class="linenos">814</span></a> <span class="p">)</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.mod_sql-808"><a href="#BigQuery.Generator.mod_sql-808"><span class="linenos">808</span></a> <span class="k">def</span> <span class="nf">mod_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Mod</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.mod_sql-809"><a href="#BigQuery.Generator.mod_sql-809"><span class="linenos">809</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
+</span><span id="BigQuery.Generator.mod_sql-810"><a href="#BigQuery.Generator.mod_sql-810"><span class="linenos">810</span></a> <span class="n">expr</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expression</span>
+</span><span id="BigQuery.Generator.mod_sql-811"><a href="#BigQuery.Generator.mod_sql-811"><span class="linenos">811</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery.Generator.mod_sql-812"><a href="#BigQuery.Generator.mod_sql-812"><span class="linenos">812</span></a> <span class="s2">&quot;MOD&quot;</span><span class="p">,</span>
+</span><span id="BigQuery.Generator.mod_sql-813"><a href="#BigQuery.Generator.mod_sql-813"><span class="linenos">813</span></a> <span class="n">this</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">this</span><span class="p">,</span>
+</span><span id="BigQuery.Generator.mod_sql-814"><a href="#BigQuery.Generator.mod_sql-814"><span class="linenos">814</span></a> <span class="n">expr</span><span class="o">.</span><span class="n">unnest</span><span class="p">()</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expr</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Paren</span><span class="p">)</span> <span class="k">else</span> <span class="n">expr</span><span class="p">,</span>
+</span><span id="BigQuery.Generator.mod_sql-815"><a href="#BigQuery.Generator.mod_sql-815"><span class="linenos">815</span></a> <span class="p">)</span>
</span></pre></div>
@@ -4090,15 +4097,15 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.column_parts"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.column_parts-816"><a href="#BigQuery.Generator.column_parts-816"><span class="linenos">816</span></a> <span class="k">def</span> <span class="nf">column_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Column</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.column_parts-817"><a href="#BigQuery.Generator.column_parts-817"><span class="linenos">817</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_column&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator.column_parts-818"><a href="#BigQuery.Generator.column_parts-818"><span class="linenos">818</span></a> <span class="c1"># If a column reference is of the form `dataset.table`.name, we need</span>
-</span><span id="BigQuery.Generator.column_parts-819"><a href="#BigQuery.Generator.column_parts-819"><span class="linenos">819</span></a> <span class="c1"># to preserve the quoted table path, otherwise the reference breaks</span>
-</span><span id="BigQuery.Generator.column_parts-820"><a href="#BigQuery.Generator.column_parts-820"><span class="linenos">820</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">[:</span><span class="o">-</span><span class="mi">1</span><span class="p">])</span>
-</span><span id="BigQuery.Generator.column_parts-821"><a href="#BigQuery.Generator.column_parts-821"><span class="linenos">821</span></a> <span class="n">table_path</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">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
-</span><span id="BigQuery.Generator.column_parts-822"><a href="#BigQuery.Generator.column_parts-822"><span class="linenos">822</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="n">table_path</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery.Generator.column_parts-823"><a href="#BigQuery.Generator.column_parts-823"><span class="linenos">823</span></a>
-</span><span id="BigQuery.Generator.column_parts-824"><a href="#BigQuery.Generator.column_parts-824"><span class="linenos">824</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">column_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.column_parts-817"><a href="#BigQuery.Generator.column_parts-817"><span class="linenos">817</span></a> <span class="k">def</span> <span class="nf">column_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Column</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.column_parts-818"><a href="#BigQuery.Generator.column_parts-818"><span class="linenos">818</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_column&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator.column_parts-819"><a href="#BigQuery.Generator.column_parts-819"><span class="linenos">819</span></a> <span class="c1"># If a column reference is of the form `dataset.table`.name, we need</span>
+</span><span id="BigQuery.Generator.column_parts-820"><a href="#BigQuery.Generator.column_parts-820"><span class="linenos">820</span></a> <span class="c1"># to preserve the quoted table path, otherwise the reference breaks</span>
+</span><span id="BigQuery.Generator.column_parts-821"><a href="#BigQuery.Generator.column_parts-821"><span class="linenos">821</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">[:</span><span class="o">-</span><span class="mi">1</span><span class="p">])</span>
+</span><span id="BigQuery.Generator.column_parts-822"><a href="#BigQuery.Generator.column_parts-822"><span class="linenos">822</span></a> <span class="n">table_path</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">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+</span><span id="BigQuery.Generator.column_parts-823"><a href="#BigQuery.Generator.column_parts-823"><span class="linenos">823</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="n">table_path</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span><span class="w"> </span><span class="s1">&#39;this&#39;</span><span class="p">)</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery.Generator.column_parts-824"><a href="#BigQuery.Generator.column_parts-824"><span class="linenos">824</span></a>
+</span><span id="BigQuery.Generator.column_parts-825"><a href="#BigQuery.Generator.column_parts-825"><span class="linenos">825</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">column_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
</span></pre></div>
@@ -4116,20 +4123,20 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.table_parts"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.table_parts-826"><a href="#BigQuery.Generator.table_parts-826"><span class="linenos">826</span></a> <span class="k">def</span> <span class="nf">table_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Table</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.table_parts-827"><a href="#BigQuery.Generator.table_parts-827"><span class="linenos">827</span></a> <span class="c1"># Depending on the context, `x.y` may not resolve to the same data source as `x`.`y`, so</span>
-</span><span id="BigQuery.Generator.table_parts-828"><a href="#BigQuery.Generator.table_parts-828"><span class="linenos">828</span></a> <span class="c1"># we need to make sure the correct quoting is used in each case.</span>
-</span><span id="BigQuery.Generator.table_parts-829"><a href="#BigQuery.Generator.table_parts-829"><span class="linenos">829</span></a> <span class="c1">#</span>
-</span><span id="BigQuery.Generator.table_parts-830"><a href="#BigQuery.Generator.table_parts-830"><span class="linenos">830</span></a> <span class="c1"># For example, if there is a CTE x that clashes with a schema name, then the former will</span>
-</span><span id="BigQuery.Generator.table_parts-831"><a href="#BigQuery.Generator.table_parts-831"><span class="linenos">831</span></a> <span class="c1"># return the table y in that schema, whereas the latter will return the CTE&#39;s y column:</span>
-</span><span id="BigQuery.Generator.table_parts-832"><a href="#BigQuery.Generator.table_parts-832"><span class="linenos">832</span></a> <span class="c1">#</span>
-</span><span id="BigQuery.Generator.table_parts-833"><a href="#BigQuery.Generator.table_parts-833"><span class="linenos">833</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x.y` -&gt; cross join</span>
-</span><span id="BigQuery.Generator.table_parts-834"><a href="#BigQuery.Generator.table_parts-834"><span class="linenos">834</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x`.`y` -&gt; implicit unnest</span>
-</span><span id="BigQuery.Generator.table_parts-835"><a href="#BigQuery.Generator.table_parts-835"><span class="linenos">835</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_table&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator.table_parts-836"><a href="#BigQuery.Generator.table_parts-836"><span class="linenos">836</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">)</span>
-</span><span id="BigQuery.Generator.table_parts-837"><a href="#BigQuery.Generator.table_parts-837"><span class="linenos">837</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
-</span><span id="BigQuery.Generator.table_parts-838"><a href="#BigQuery.Generator.table_parts-838"><span class="linenos">838</span></a>
-</span><span id="BigQuery.Generator.table_parts-839"><a href="#BigQuery.Generator.table_parts-839"><span class="linenos">839</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">table_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.table_parts-827"><a href="#BigQuery.Generator.table_parts-827"><span class="linenos">827</span></a> <span class="k">def</span> <span class="nf">table_parts</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Table</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.table_parts-828"><a href="#BigQuery.Generator.table_parts-828"><span class="linenos">828</span></a> <span class="c1"># Depending on the context, `x.y` may not resolve to the same data source as `x`.`y`, so</span>
+</span><span id="BigQuery.Generator.table_parts-829"><a href="#BigQuery.Generator.table_parts-829"><span class="linenos">829</span></a> <span class="c1"># we need to make sure the correct quoting is used in each case.</span>
+</span><span id="BigQuery.Generator.table_parts-830"><a href="#BigQuery.Generator.table_parts-830"><span class="linenos">830</span></a> <span class="c1">#</span>
+</span><span id="BigQuery.Generator.table_parts-831"><a href="#BigQuery.Generator.table_parts-831"><span class="linenos">831</span></a> <span class="c1"># For example, if there is a CTE x that clashes with a schema name, then the former will</span>
+</span><span id="BigQuery.Generator.table_parts-832"><a href="#BigQuery.Generator.table_parts-832"><span class="linenos">832</span></a> <span class="c1"># return the table y in that schema, whereas the latter will return the CTE&#39;s y column:</span>
+</span><span id="BigQuery.Generator.table_parts-833"><a href="#BigQuery.Generator.table_parts-833"><span class="linenos">833</span></a> <span class="c1">#</span>
+</span><span id="BigQuery.Generator.table_parts-834"><a href="#BigQuery.Generator.table_parts-834"><span class="linenos">834</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x.y` -&gt; cross join</span>
+</span><span id="BigQuery.Generator.table_parts-835"><a href="#BigQuery.Generator.table_parts-835"><span class="linenos">835</span></a> <span class="c1"># - WITH x AS (SELECT [1, 2] AS y) SELECT * FROM x, `x`.`y` -&gt; implicit unnest</span>
+</span><span id="BigQuery.Generator.table_parts-836"><a href="#BigQuery.Generator.table_parts-836"><span class="linenos">836</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">meta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;quoted_table&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator.table_parts-837"><a href="#BigQuery.Generator.table_parts-837"><span class="linenos">837</span></a> <span class="n">table_parts</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">p</span><span class="o">.</span><span class="n">name</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="n">expression</span><span class="o">.</span><span class="n">parts</span><span class="p">)</span>
+</span><span id="BigQuery.Generator.table_parts-838"><a href="#BigQuery.Generator.table_parts-838"><span class="linenos">838</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">Identifier</span><span class="p">(</span><span class="n">this</span><span class="o">=</span><span class="n">table_parts</span><span class="p">,</span> <span class="n">quoted</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+</span><span id="BigQuery.Generator.table_parts-839"><a href="#BigQuery.Generator.table_parts-839"><span class="linenos">839</span></a>
+</span><span id="BigQuery.Generator.table_parts-840"><a href="#BigQuery.Generator.table_parts-840"><span class="linenos">840</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">table_parts</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
</span></pre></div>
@@ -4147,9 +4154,9 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.timetostr_sql"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.timetostr_sql-841"><a href="#BigQuery.Generator.timetostr_sql-841"><span class="linenos">841</span></a> <span class="k">def</span> <span class="nf">timetostr_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TimeToStr</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.timetostr_sql-842"><a href="#BigQuery.Generator.timetostr_sql-842"><span class="linenos">842</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToDate</span><span class="p">)</span> <span class="k">else</span> <span class="n">expression</span>
-</span><span id="BigQuery.Generator.timetostr_sql-843"><a href="#BigQuery.Generator.timetostr_sql-843"><span class="linenos">843</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;FORMAT_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">expression</span><span class="p">),</span> <span class="n">this</span><span class="o">.</span><span class="n">this</span><span class="p">)</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.timetostr_sql-842"><a href="#BigQuery.Generator.timetostr_sql-842"><span class="linenos">842</span></a> <span class="k">def</span> <span class="nf">timetostr_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TimeToStr</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.timetostr_sql-843"><a href="#BigQuery.Generator.timetostr_sql-843"><span class="linenos">843</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">TsOrDsToDate</span><span class="p">)</span> <span class="k">else</span> <span class="n">expression</span>
+</span><span id="BigQuery.Generator.timetostr_sql-844"><a href="#BigQuery.Generator.timetostr_sql-844"><span class="linenos">844</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;FORMAT_DATE&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">format_time</span><span class="p">(</span><span class="n">expression</span><span class="p">),</span> <span class="n">this</span><span class="o">.</span><span class="n">this</span><span class="p">)</span>
</span></pre></div>
@@ -4167,13 +4174,13 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.eq_sql"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.eq_sql-845"><a href="#BigQuery.Generator.eq_sql-845"><span class="linenos">845</span></a> <span class="k">def</span> <span class="nf">eq_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">EQ</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.eq_sql-846"><a href="#BigQuery.Generator.eq_sql-846"><span class="linenos">846</span></a> <span class="c1"># Operands of = cannot be NULL in BigQuery</span>
-</span><span id="BigQuery.Generator.eq_sql-847"><a href="#BigQuery.Generator.eq_sql-847"><span class="linenos">847</span></a> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">left</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">)</span> <span class="ow">or</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">right</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">):</span>
-</span><span id="BigQuery.Generator.eq_sql-848"><a href="#BigQuery.Generator.eq_sql-848"><span class="linenos">848</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Update</span><span class="p">):</span>
-</span><span id="BigQuery.Generator.eq_sql-849"><a href="#BigQuery.Generator.eq_sql-849"><span class="linenos">849</span></a> <span class="k">return</span> <span class="s2">&quot;NULL&quot;</span>
-</span><span id="BigQuery.Generator.eq_sql-850"><a href="#BigQuery.Generator.eq_sql-850"><span class="linenos">850</span></a>
-</span><span id="BigQuery.Generator.eq_sql-851"><a href="#BigQuery.Generator.eq_sql-851"><span class="linenos">851</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">binary</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="s2">&quot;=&quot;</span><span class="p">)</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.eq_sql-846"><a href="#BigQuery.Generator.eq_sql-846"><span class="linenos">846</span></a> <span class="k">def</span> <span class="nf">eq_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">EQ</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.eq_sql-847"><a href="#BigQuery.Generator.eq_sql-847"><span class="linenos">847</span></a> <span class="c1"># Operands of = cannot be NULL in BigQuery</span>
+</span><span id="BigQuery.Generator.eq_sql-848"><a href="#BigQuery.Generator.eq_sql-848"><span class="linenos">848</span></a> <span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">left</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">)</span> <span class="ow">or</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">right</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Null</span><span class="p">):</span>
+</span><span id="BigQuery.Generator.eq_sql-849"><a href="#BigQuery.Generator.eq_sql-849"><span class="linenos">849</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">expression</span><span class="o">.</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Update</span><span class="p">):</span>
+</span><span id="BigQuery.Generator.eq_sql-850"><a href="#BigQuery.Generator.eq_sql-850"><span class="linenos">850</span></a> <span class="k">return</span> <span class="s2">&quot;NULL&quot;</span>
+</span><span id="BigQuery.Generator.eq_sql-851"><a href="#BigQuery.Generator.eq_sql-851"><span class="linenos">851</span></a>
+</span><span id="BigQuery.Generator.eq_sql-852"><a href="#BigQuery.Generator.eq_sql-852"><span class="linenos">852</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">binary</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="s2">&quot;=&quot;</span><span class="p">)</span>
</span></pre></div>
@@ -4191,17 +4198,17 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.attimezone_sql"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.attimezone_sql-853"><a href="#BigQuery.Generator.attimezone_sql-853"><span class="linenos">853</span></a> <span class="k">def</span> <span class="nf">attimezone_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">AtTimeZone</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.attimezone_sql-854"><a href="#BigQuery.Generator.attimezone_sql-854"><span class="linenos">854</span></a> <span class="n">parent</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">parent</span>
-</span><span id="BigQuery.Generator.attimezone_sql-855"><a href="#BigQuery.Generator.attimezone_sql-855"><span class="linenos">855</span></a>
-</span><span id="BigQuery.Generator.attimezone_sql-856"><a href="#BigQuery.Generator.attimezone_sql-856"><span class="linenos">856</span></a> <span class="c1"># BigQuery allows CAST(.. AS {STRING|TIMESTAMP} [FORMAT &lt;fmt&gt; [AT TIME ZONE &lt;tz&gt;]]).</span>
-</span><span id="BigQuery.Generator.attimezone_sql-857"><a href="#BigQuery.Generator.attimezone_sql-857"><span class="linenos">857</span></a> <span class="c1"># Only the TIMESTAMP one should use the below conversion, when AT TIME ZONE is included.</span>
-</span><span id="BigQuery.Generator.attimezone_sql-858"><a href="#BigQuery.Generator.attimezone_sql-858"><span class="linenos">858</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">)</span> <span class="ow">or</span> <span class="ow">not</span> <span class="n">parent</span><span class="o">.</span><span class="n">to</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="s2">&quot;text&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator.attimezone_sql-859"><a href="#BigQuery.Generator.attimezone_sql-859"><span class="linenos">859</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
-</span><span id="BigQuery.Generator.attimezone_sql-860"><a href="#BigQuery.Generator.attimezone_sql-860"><span class="linenos">860</span></a> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">))</span>
-</span><span id="BigQuery.Generator.attimezone_sql-861"><a href="#BigQuery.Generator.attimezone_sql-861"><span class="linenos">861</span></a> <span class="p">)</span>
-</span><span id="BigQuery.Generator.attimezone_sql-862"><a href="#BigQuery.Generator.attimezone_sql-862"><span class="linenos">862</span></a>
-</span><span id="BigQuery.Generator.attimezone_sql-863"><a href="#BigQuery.Generator.attimezone_sql-863"><span class="linenos">863</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">attimezone_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.attimezone_sql-854"><a href="#BigQuery.Generator.attimezone_sql-854"><span class="linenos">854</span></a> <span class="k">def</span> <span class="nf">attimezone_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">AtTimeZone</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.attimezone_sql-855"><a href="#BigQuery.Generator.attimezone_sql-855"><span class="linenos">855</span></a> <span class="n">parent</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">parent</span>
+</span><span id="BigQuery.Generator.attimezone_sql-856"><a href="#BigQuery.Generator.attimezone_sql-856"><span class="linenos">856</span></a>
+</span><span id="BigQuery.Generator.attimezone_sql-857"><a href="#BigQuery.Generator.attimezone_sql-857"><span class="linenos">857</span></a> <span class="c1"># BigQuery allows CAST(.. AS {STRING|TIMESTAMP} [FORMAT &lt;fmt&gt; [AT TIME ZONE &lt;tz&gt;]]).</span>
+</span><span id="BigQuery.Generator.attimezone_sql-858"><a href="#BigQuery.Generator.attimezone_sql-858"><span class="linenos">858</span></a> <span class="c1"># Only the TIMESTAMP one should use the below conversion, when AT TIME ZONE is included.</span>
+</span><span id="BigQuery.Generator.attimezone_sql-859"><a href="#BigQuery.Generator.attimezone_sql-859"><span class="linenos">859</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">exp</span><span class="o">.</span><span class="n">Cast</span><span class="p">)</span> <span class="ow">or</span> <span class="ow">not</span> <span class="n">parent</span><span class="o">.</span><span class="n">to</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="s2">&quot;text&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator.attimezone_sql-860"><a href="#BigQuery.Generator.attimezone_sql-860"><span class="linenos">860</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span>
+</span><span id="BigQuery.Generator.attimezone_sql-861"><a href="#BigQuery.Generator.attimezone_sql-861"><span class="linenos">861</span></a> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">func</span><span class="p">(</span><span class="s2">&quot;DATETIME&quot;</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span><span class="p">,</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;zone&quot;</span><span class="p">))</span>
+</span><span id="BigQuery.Generator.attimezone_sql-862"><a href="#BigQuery.Generator.attimezone_sql-862"><span class="linenos">862</span></a> <span class="p">)</span>
+</span><span id="BigQuery.Generator.attimezone_sql-863"><a href="#BigQuery.Generator.attimezone_sql-863"><span class="linenos">863</span></a>
+</span><span id="BigQuery.Generator.attimezone_sql-864"><a href="#BigQuery.Generator.attimezone_sql-864"><span class="linenos">864</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">attimezone_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
</span></pre></div>
@@ -4219,8 +4226,8 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.trycast_sql"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.trycast_sql-865"><a href="#BigQuery.Generator.trycast_sql-865"><span class="linenos">865</span></a> <span class="k">def</span> <span class="nf">trycast_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TryCast</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.trycast_sql-866"><a href="#BigQuery.Generator.trycast_sql-866"><span class="linenos">866</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">cast_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">safe_prefix</span><span class="o">=</span><span class="s2">&quot;SAFE_&quot;</span><span class="p">)</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.trycast_sql-866"><a href="#BigQuery.Generator.trycast_sql-866"><span class="linenos">866</span></a> <span class="k">def</span> <span class="nf">trycast_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">TryCast</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.trycast_sql-867"><a href="#BigQuery.Generator.trycast_sql-867"><span class="linenos">867</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">cast_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">safe_prefix</span><span class="o">=</span><span class="s2">&quot;SAFE_&quot;</span><span class="p">)</span>
</span></pre></div>
@@ -4238,35 +4245,35 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.bracket_sql"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.bracket_sql-868"><a href="#BigQuery.Generator.bracket_sql-868"><span class="linenos">868</span></a> <span class="k">def</span> <span class="nf">bracket_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Bracket</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.bracket_sql-869"><a href="#BigQuery.Generator.bracket_sql-869"><span class="linenos">869</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
-</span><span id="BigQuery.Generator.bracket_sql-870"><a href="#BigQuery.Generator.bracket_sql-870"><span class="linenos">870</span></a> <span class="n">expressions</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expressions</span>
-</span><span id="BigQuery.Generator.bracket_sql-871"><a href="#BigQuery.Generator.bracket_sql-871"><span class="linenos">871</span></a>
-</span><span id="BigQuery.Generator.bracket_sql-872"><a href="#BigQuery.Generator.bracket_sql-872"><span class="linenos">872</span></a> <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">expressions</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> <span class="ow">and</span> <span class="n">this</span> <span class="ow">and</span> <span class="n">this</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">STRUCT</span><span class="p">):</span>
-</span><span id="BigQuery.Generator.bracket_sql-873"><a href="#BigQuery.Generator.bracket_sql-873"><span class="linenos">873</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">expressions</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
-</span><span id="BigQuery.Generator.bracket_sql-874"><a href="#BigQuery.Generator.bracket_sql-874"><span class="linenos">874</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">is</span> <span class="kc">None</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.bracket_sql-875"><a href="#BigQuery.Generator.bracket_sql-875"><span class="linenos">875</span></a> <span class="kn">from</span> <span class="nn">sqlglot.optimizer.annotate_types</span> <span class="kn">import</span> <span class="n">annotate_types</span>
-</span><span id="BigQuery.Generator.bracket_sql-876"><a href="#BigQuery.Generator.bracket_sql-876"><span class="linenos">876</span></a>
-</span><span id="BigQuery.Generator.bracket_sql-877"><a href="#BigQuery.Generator.bracket_sql-877"><span class="linenos">877</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">annotate_types</span><span class="p">(</span><span class="n">arg</span><span class="p">)</span>
-</span><span id="BigQuery.Generator.bracket_sql-878"><a href="#BigQuery.Generator.bracket_sql-878"><span class="linenos">878</span></a>
-</span><span id="BigQuery.Generator.bracket_sql-879"><a href="#BigQuery.Generator.bracket_sql-879"><span class="linenos">879</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">and</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span><span class="o">.</span><span class="n">this</span> <span class="ow">in</span> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">TEXT_TYPES</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.bracket_sql-880"><a href="#BigQuery.Generator.bracket_sql-880"><span class="linenos">880</span></a> <span class="c1"># BQ doesn&#39;t support bracket syntax with string values for structs</span>
-</span><span id="BigQuery.Generator.bracket_sql-881"><a href="#BigQuery.Generator.bracket_sql-881"><span class="linenos">881</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="n">arg</span><span class="o">.</span><span class="n">name</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery.Generator.bracket_sql-882"><a href="#BigQuery.Generator.bracket_sql-882"><span class="linenos">882</span></a>
-</span><span id="BigQuery.Generator.bracket_sql-883"><a href="#BigQuery.Generator.bracket_sql-883"><span class="linenos">883</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">expressions</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">flat</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
-</span><span id="BigQuery.Generator.bracket_sql-884"><a href="#BigQuery.Generator.bracket_sql-884"><span class="linenos">884</span></a> <span class="n">offset</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;offset&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator.bracket_sql-885"><a href="#BigQuery.Generator.bracket_sql-885"><span class="linenos">885</span></a>
-</span><span id="BigQuery.Generator.bracket_sql-886"><a href="#BigQuery.Generator.bracket_sql-886"><span class="linenos">886</span></a> <span class="k">if</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.bracket_sql-887"><a href="#BigQuery.Generator.bracket_sql-887"><span class="linenos">887</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;OFFSET(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
-</span><span id="BigQuery.Generator.bracket_sql-888"><a href="#BigQuery.Generator.bracket_sql-888"><span class="linenos">888</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.bracket_sql-889"><a href="#BigQuery.Generator.bracket_sql-889"><span class="linenos">889</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;ORDINAL(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
-</span><span id="BigQuery.Generator.bracket_sql-890"><a href="#BigQuery.Generator.bracket_sql-890"><span class="linenos">890</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.bracket_sql-891"><a href="#BigQuery.Generator.bracket_sql-891"><span class="linenos">891</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Unsupported array offset: </span><span class="si">{</span><span class="n">offset</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator.bracket_sql-892"><a href="#BigQuery.Generator.bracket_sql-892"><span class="linenos">892</span></a>
-</span><span id="BigQuery.Generator.bracket_sql-893"><a href="#BigQuery.Generator.bracket_sql-893"><span class="linenos">893</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;safe&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator.bracket_sql-894"><a href="#BigQuery.Generator.bracket_sql-894"><span class="linenos">894</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SAFE_</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">&quot;</span>
-</span><span id="BigQuery.Generator.bracket_sql-895"><a href="#BigQuery.Generator.bracket_sql-895"><span class="linenos">895</span></a>
-</span><span id="BigQuery.Generator.bracket_sql-896"><a href="#BigQuery.Generator.bracket_sql-896"><span class="linenos">896</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">[</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">]&quot;</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.bracket_sql-869"><a href="#BigQuery.Generator.bracket_sql-869"><span class="linenos">869</span></a> <span class="k">def</span> <span class="nf">bracket_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Bracket</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.bracket_sql-870"><a href="#BigQuery.Generator.bracket_sql-870"><span class="linenos">870</span></a> <span class="n">this</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">this</span>
+</span><span id="BigQuery.Generator.bracket_sql-871"><a href="#BigQuery.Generator.bracket_sql-871"><span class="linenos">871</span></a> <span class="n">expressions</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">expressions</span>
+</span><span id="BigQuery.Generator.bracket_sql-872"><a href="#BigQuery.Generator.bracket_sql-872"><span class="linenos">872</span></a>
+</span><span id="BigQuery.Generator.bracket_sql-873"><a href="#BigQuery.Generator.bracket_sql-873"><span class="linenos">873</span></a> <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">expressions</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> <span class="ow">and</span> <span class="n">this</span> <span class="ow">and</span> <span class="n">this</span><span class="o">.</span><span class="n">is_type</span><span class="p">(</span><span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">Type</span><span class="o">.</span><span class="n">STRUCT</span><span class="p">):</span>
+</span><span id="BigQuery.Generator.bracket_sql-874"><a href="#BigQuery.Generator.bracket_sql-874"><span class="linenos">874</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">expressions</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
+</span><span id="BigQuery.Generator.bracket_sql-875"><a href="#BigQuery.Generator.bracket_sql-875"><span class="linenos">875</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">is</span> <span class="kc">None</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.bracket_sql-876"><a href="#BigQuery.Generator.bracket_sql-876"><span class="linenos">876</span></a> <span class="kn">from</span> <span class="nn">sqlglot.optimizer.annotate_types</span> <span class="kn">import</span> <span class="n">annotate_types</span>
+</span><span id="BigQuery.Generator.bracket_sql-877"><a href="#BigQuery.Generator.bracket_sql-877"><span class="linenos">877</span></a>
+</span><span id="BigQuery.Generator.bracket_sql-878"><a href="#BigQuery.Generator.bracket_sql-878"><span class="linenos">878</span></a> <span class="n">arg</span> <span class="o">=</span> <span class="n">annotate_types</span><span class="p">(</span><span class="n">arg</span><span class="p">)</span>
+</span><span id="BigQuery.Generator.bracket_sql-879"><a href="#BigQuery.Generator.bracket_sql-879"><span class="linenos">879</span></a>
+</span><span id="BigQuery.Generator.bracket_sql-880"><a href="#BigQuery.Generator.bracket_sql-880"><span class="linenos">880</span></a> <span class="k">if</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span> <span class="ow">and</span> <span class="n">arg</span><span class="o">.</span><span class="n">type</span><span class="o">.</span><span class="n">this</span> <span class="ow">in</span> <span class="n">exp</span><span class="o">.</span><span class="n">DataType</span><span class="o">.</span><span class="n">TEXT_TYPES</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.bracket_sql-881"><a href="#BigQuery.Generator.bracket_sql-881"><span class="linenos">881</span></a> <span class="c1"># BQ doesn&#39;t support bracket syntax with string values for structs</span>
+</span><span id="BigQuery.Generator.bracket_sql-882"><a href="#BigQuery.Generator.bracket_sql-882"><span class="linenos">882</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">.</span><span class="si">{</span><span class="n">arg</span><span class="o">.</span><span class="n">name</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery.Generator.bracket_sql-883"><a href="#BigQuery.Generator.bracket_sql-883"><span class="linenos">883</span></a>
+</span><span id="BigQuery.Generator.bracket_sql-884"><a href="#BigQuery.Generator.bracket_sql-884"><span class="linenos">884</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">expressions</span><span class="p">(</span><span class="n">expression</span><span class="p">,</span> <span class="n">flat</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
+</span><span id="BigQuery.Generator.bracket_sql-885"><a href="#BigQuery.Generator.bracket_sql-885"><span class="linenos">885</span></a> <span class="n">offset</span> <span class="o">=</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;offset&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator.bracket_sql-886"><a href="#BigQuery.Generator.bracket_sql-886"><span class="linenos">886</span></a>
+</span><span id="BigQuery.Generator.bracket_sql-887"><a href="#BigQuery.Generator.bracket_sql-887"><span class="linenos">887</span></a> <span class="k">if</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.bracket_sql-888"><a href="#BigQuery.Generator.bracket_sql-888"><span class="linenos">888</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;OFFSET(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
+</span><span id="BigQuery.Generator.bracket_sql-889"><a href="#BigQuery.Generator.bracket_sql-889"><span class="linenos">889</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.bracket_sql-890"><a href="#BigQuery.Generator.bracket_sql-890"><span class="linenos">890</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;ORDINAL(</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">)&quot;</span>
+</span><span id="BigQuery.Generator.bracket_sql-891"><a href="#BigQuery.Generator.bracket_sql-891"><span class="linenos">891</span></a> <span class="k">elif</span> <span class="n">offset</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.bracket_sql-892"><a href="#BigQuery.Generator.bracket_sql-892"><span class="linenos">892</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Unsupported array offset: </span><span class="si">{</span><span class="n">offset</span><span class="si">}</span><span class="s2">&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator.bracket_sql-893"><a href="#BigQuery.Generator.bracket_sql-893"><span class="linenos">893</span></a>
+</span><span id="BigQuery.Generator.bracket_sql-894"><a href="#BigQuery.Generator.bracket_sql-894"><span class="linenos">894</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;safe&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator.bracket_sql-895"><a href="#BigQuery.Generator.bracket_sql-895"><span class="linenos">895</span></a> <span class="n">expressions_sql</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">&quot;SAFE_</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">&quot;</span>
+</span><span id="BigQuery.Generator.bracket_sql-896"><a href="#BigQuery.Generator.bracket_sql-896"><span class="linenos">896</span></a>
+</span><span id="BigQuery.Generator.bracket_sql-897"><a href="#BigQuery.Generator.bracket_sql-897"><span class="linenos">897</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;</span><span class="si">{</span><span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">this</span><span class="p">)</span><span class="si">}</span><span class="s2">[</span><span class="si">{</span><span class="n">expressions_sql</span><span class="si">}</span><span class="s2">]&quot;</span>
</span></pre></div>
@@ -4284,8 +4291,8 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.in_unnest_op"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.in_unnest_op-898"><a href="#BigQuery.Generator.in_unnest_op-898"><span class="linenos">898</span></a> <span class="k">def</span> <span class="nf">in_unnest_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Unnest</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.in_unnest_op-899"><a href="#BigQuery.Generator.in_unnest_op-899"><span class="linenos">899</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.in_unnest_op-899"><a href="#BigQuery.Generator.in_unnest_op-899"><span class="linenos">899</span></a> <span class="k">def</span> <span class="nf">in_unnest_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Unnest</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.in_unnest_op-900"><a href="#BigQuery.Generator.in_unnest_op-900"><span class="linenos">900</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
</span></pre></div>
@@ -4303,10 +4310,10 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.except_op"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.except_op-901"><a href="#BigQuery.Generator.except_op-901"><span class="linenos">901</span></a> <span class="k">def</span> <span class="nf">except_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Except</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.except_op-902"><a href="#BigQuery.Generator.except_op-902"><span class="linenos">902</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator.except_op-903"><a href="#BigQuery.Generator.except_op-903"><span class="linenos">903</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;EXCEPT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator.except_op-904"><a href="#BigQuery.Generator.except_op-904"><span class="linenos">904</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;EXCEPT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.except_op-902"><a href="#BigQuery.Generator.except_op-902"><span class="linenos">902</span></a> <span class="k">def</span> <span class="nf">except_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Except</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.except_op-903"><a href="#BigQuery.Generator.except_op-903"><span class="linenos">903</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator.except_op-904"><a href="#BigQuery.Generator.except_op-904"><span class="linenos">904</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;EXCEPT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator.except_op-905"><a href="#BigQuery.Generator.except_op-905"><span class="linenos">905</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;EXCEPT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
</span></pre></div>
@@ -4324,29 +4331,10 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.intersect_op"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.intersect_op-906"><a href="#BigQuery.Generator.intersect_op-906"><span class="linenos">906</span></a> <span class="k">def</span> <span class="nf">intersect_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Intersect</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.intersect_op-907"><a href="#BigQuery.Generator.intersect_op-907"><span class="linenos">907</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
-</span><span id="BigQuery.Generator.intersect_op-908"><a href="#BigQuery.Generator.intersect_op-908"><span class="linenos">908</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;INTERSECT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator.intersect_op-909"><a href="#BigQuery.Generator.intersect_op-909"><span class="linenos">909</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;INTERSECT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
-</span></pre></div>
-
-
-
-
- </div>
- <div id="BigQuery.Generator.with_properties" class="classattr">
- <input id="BigQuery.Generator.with_properties-view-source" class="view-source-toggle-state" type="checkbox" aria-hidden="true" tabindex="-1">
-<div class="attr function">
-
- <span class="def">def</span>
- <span class="name">with_properties</span><span class="signature pdoc-code condensed">(<span class="param"><span class="bp">self</span>, </span><span class="param"><span class="n">properties</span><span class="p">:</span> <span class="n"><a href="../expressions.html#Properties">sqlglot.expressions.Properties</a></span></span><span class="return-annotation">) -> <span class="nb">str</span>:</span></span>
-
- <label class="view-source-button" for="BigQuery.Generator.with_properties-view-source"><span>View Source</span></label>
-
- </div>
- <a class="headerlink" href="#BigQuery.Generator.with_properties"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.with_properties-911"><a href="#BigQuery.Generator.with_properties-911"><span class="linenos">911</span></a> <span class="k">def</span> <span class="nf">with_properties</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">properties</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Properties</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.with_properties-912"><a href="#BigQuery.Generator.with_properties-912"><span class="linenos">912</span></a> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">properties</span><span class="p">(</span><span class="n">properties</span><span class="p">,</span> <span class="n">prefix</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">seg</span><span class="p">(</span><span class="s2">&quot;OPTIONS&quot;</span><span class="p">))</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.intersect_op-907"><a href="#BigQuery.Generator.intersect_op-907"><span class="linenos">907</span></a> <span class="k">def</span> <span class="nf">intersect_op</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Intersect</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.intersect_op-908"><a href="#BigQuery.Generator.intersect_op-908"><span class="linenos">908</span></a> <span class="k">if</span> <span class="ow">not</span> <span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">&quot;distinct&quot;</span><span class="p">):</span>
+</span><span id="BigQuery.Generator.intersect_op-909"><a href="#BigQuery.Generator.intersect_op-909"><span class="linenos">909</span></a> <span class="bp">self</span><span class="o">.</span><span class="n">unsupported</span><span class="p">(</span><span class="s2">&quot;INTERSECT without DISTINCT is not supported in BigQuery&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator.intersect_op-910"><a href="#BigQuery.Generator.intersect_op-910"><span class="linenos">910</span></a> <span class="k">return</span> <span class="sa">f</span><span class="s2">&quot;INTERSECT</span><span class="si">{</span><span class="s1">&#39; DISTINCT&#39;</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">expression</span><span class="o">.</span><span class="n">args</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;distinct&#39;</span><span class="p">)</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="s1">&#39; ALL&#39;</span><span class="si">}</span><span class="s2">&quot;</span>
</span></pre></div>
@@ -4364,10 +4352,10 @@ Default: True</li>
</div>
<a class="headerlink" href="#BigQuery.Generator.version_sql"></a>
- <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.version_sql-914"><a href="#BigQuery.Generator.version_sql-914"><span class="linenos">914</span></a> <span class="k">def</span> <span class="nf">version_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Version</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.version_sql-915"><a href="#BigQuery.Generator.version_sql-915"><span class="linenos">915</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">:</span>
-</span><span id="BigQuery.Generator.version_sql-916"><a href="#BigQuery.Generator.version_sql-916"><span class="linenos">916</span></a> <span class="n">expression</span><span class="o">.</span><span class="n">set</span><span class="p">(</span><span class="s2">&quot;this&quot;</span><span class="p">,</span> <span class="s2">&quot;SYSTEM_TIME&quot;</span><span class="p">)</span>
-</span><span id="BigQuery.Generator.version_sql-917"><a href="#BigQuery.Generator.version_sql-917"><span class="linenos">917</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">version_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
+ <div class="pdoc-code codehilite"><pre><span></span><span id="BigQuery.Generator.version_sql-912"><a href="#BigQuery.Generator.version_sql-912"><span class="linenos">912</span></a> <span class="k">def</span> <span class="nf">version_sql</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">expression</span><span class="p">:</span> <span class="n">exp</span><span class="o">.</span><span class="n">Version</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">str</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.version_sql-913"><a href="#BigQuery.Generator.version_sql-913"><span class="linenos">913</span></a> <span class="k">if</span> <span class="n">expression</span><span class="o">.</span><span class="n">name</span> <span class="o">==</span> <span class="s2">&quot;TIMESTAMP&quot;</span><span class="p">:</span>
+</span><span id="BigQuery.Generator.version_sql-914"><a href="#BigQuery.Generator.version_sql-914"><span class="linenos">914</span></a> <span class="n">expression</span><span class="o">.</span><span class="n">set</span><span class="p">(</span><span class="s2">&quot;this&quot;</span><span class="p">,</span> <span class="s2">&quot;SYSTEM_TIME&quot;</span><span class="p">)</span>
+</span><span id="BigQuery.Generator.version_sql-915"><a href="#BigQuery.Generator.version_sql-915"><span class="linenos">915</span></a> <span class="k">return</span> <span class="nb">super</span><span class="p">()</span><span class="o">.</span><span class="n">version_sql</span><span class="p">(</span><span class="n">expression</span><span class="p">)</span>
</span></pre></div>
@@ -4534,6 +4522,7 @@ Default: True</li>
<dd id="BigQuery.Generator.properties_sql" class="function"><a href="../generator.html#Generator.properties_sql">properties_sql</a></dd>
<dd id="BigQuery.Generator.root_properties" class="function"><a href="../generator.html#Generator.root_properties">root_properties</a></dd>
<dd id="BigQuery.Generator.properties" class="function"><a href="../generator.html#Generator.properties">properties</a></dd>
+ <dd id="BigQuery.Generator.with_properties" class="function"><a href="../generator.html#Generator.with_properties">with_properties</a></dd>
<dd id="BigQuery.Generator.locate_properties" class="function"><a href="../generator.html#Generator.locate_properties">locate_properties</a></dd>
<dd id="BigQuery.Generator.property_name" class="function"><a href="../generator.html#Generator.property_name">property_name</a></dd>
<dd id="BigQuery.Generator.property_sql" class="function"><a href="../generator.html#Generator.property_sql">property_sql</a></dd>
@@ -4693,6 +4682,7 @@ Default: True</li>
<dd id="BigQuery.Generator.altersortkey_sql" class="function"><a href="../generator.html#Generator.altersortkey_sql">altersortkey_sql</a></dd>
<dd id="BigQuery.Generator.renametable_sql" class="function"><a href="../generator.html#Generator.renametable_sql">renametable_sql</a></dd>
<dd id="BigQuery.Generator.renamecolumn_sql" class="function"><a href="../generator.html#Generator.renamecolumn_sql">renamecolumn_sql</a></dd>
+ <dd id="BigQuery.Generator.alterset_sql" class="function"><a href="../generator.html#Generator.alterset_sql">alterset_sql</a></dd>
<dd id="BigQuery.Generator.altertable_sql" class="function"><a href="../generator.html#Generator.altertable_sql">altertable_sql</a></dd>
<dd id="BigQuery.Generator.add_column_sql" class="function"><a href="../generator.html#Generator.add_column_sql">add_column_sql</a></dd>
<dd id="BigQuery.Generator.droppartition_sql" class="function"><a href="../generator.html#Generator.droppartition_sql">droppartition_sql</a></dd>
@@ -4782,6 +4772,7 @@ Default: True</li>
<dd id="BigQuery.Generator.credentials_sql" class="function"><a href="../generator.html#Generator.credentials_sql">credentials_sql</a></dd>
<dd id="BigQuery.Generator.copy_sql" class="function"><a href="../generator.html#Generator.copy_sql">copy_sql</a></dd>
<dd id="BigQuery.Generator.semicolon_sql" class="function"><a href="../generator.html#Generator.semicolon_sql">semicolon_sql</a></dd>
+ <dd id="BigQuery.Generator.datadeletionproperty_sql" class="function"><a href="../generator.html#Generator.datadeletionproperty_sql">datadeletionproperty_sql</a></dd>
</div>
</dl>