From 5edf71c0815b6495ea6d4cfc68f13e18b35242a3 Mon Sep 17 00:00:00 2001 From: longfengpili <398745129@qq.com> Date: Sat, 12 Oct 2024 14:15:12 +0800 Subject: [PATCH] =?UTF-8?q?[=E4=BF=AE=E5=A4=8D]subtokens=E9=80=92=E5=BD=92?= =?UTF-8?q?=E9=87=8D=E5=A4=8D=E8=B5=8B=E5=80=BC=E7=9A=84=E6=93=8D=E4=BD=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pydbapi/sql/parse.py | 16 ++++++++-------- requirements.txt | 1 + 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/pydbapi/sql/parse.py b/pydbapi/sql/parse.py index 04dbccc..c277770 100644 --- a/pydbapi/sql/parse.py +++ b/pydbapi/sql/parse.py @@ -2,7 +2,7 @@ # @Author: longfengpili # @Date: 2024-10-09 16:33:05 # @Last Modified by: longfengpili -# @Last Modified time: 2024-10-12 10:12:45 +# @Last Modified time: 2024-10-12 14:13:22 # @github: https://github.com/longfengpili @@ -107,12 +107,14 @@ def tablename(self): if tables: return tables[0] - def get_subqueries(self, tokens: list, subtokens: list[Token] = None, subqueries: list[list[Token, ]] = None, keep_last: bool = True): + def get_subqueries(self, tokens: list, subtokens: list[Token] = None, subqueries: list[TokenList, ] = None, keep_last: bool = True): def append_subquery(subtokens: list, subqueries: list): - subtokens = TokenList(subtokens) - subtoken_first = subtokens.token_first(skip_cm=True) + _subqueries = subtokens.copy() + sub_tokenlist = TokenList(_subqueries) + subtoken_first = sub_tokenlist.token_first(skip_cm=True) if subtoken_first: - subqueries.append(subtokens) + subqueries.append(sub_tokenlist) + subtokens.clear() if subqueries is None: subqueries = [] @@ -125,19 +127,17 @@ def append_subquery(subtokens: list, subqueries: list): continue elif token.ttype in (DML, DDL, CTE): append_subquery(subtokens, subqueries) + subtokens.append(token) if token.value.lower() == 'select': islast = True - subtokens = [token] elif token.ttype == Punctuation and not islast: append_subquery(subtokens, subqueries) - subtokens = [] elif isinstance(token, Identifier): # Identifier 也是 TokenList, 所有必须在下个判断之前 subtokens.append(token) elif isinstance(token, TokenList) or isinstance(token, IdentifierList): self.get_subqueries(token.tokens, subtokens, subqueries) else: subtokens.append(token) - if keep_last: append_subquery(subtokens, subqueries) diff --git a/requirements.txt b/requirements.txt index f4a6041..42d9084 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,3 +1,4 @@ +sqlparse psycopg2-binary pandas pymysql