我想询问有关使用 Python 3.X 从 Postgresql 查询中提取表名的问题。
这是我的条件。
1.Python 3.X 包sqlparse 2.Postgresql
这是我的 sql 代码。
$postgresql
With
a as (
select x,y
from g
)
select x, y,z
from b
left join a on b.id = a.id
我想通过 Python3.X 使用 sqlparse 从上述查询中获取结果。
#table name : g, b
如何改进我的以下代码?
$Python3
import sqlparse
from sqlparse.sql import Where, Comparison, Parenthesis, Identifier
class RecursiveTokenParser(object):
def __init__(self, query):
self.query = query
self.names = []
def get_table_names(self):
elements = sqlparse.parse(self.query)
for token in elements[0].tokens:
if isinstance(token, Identifier):
self.identifier(token)
elif isinstance(token, Parenthesis):
self.parenthesis(token)
elif isinstance(token, Where):
self.where(token)
return [str(name) for name in self.names]
def where(self, token):
for subtoken in token.tokens:
if isinstance(subtoken, Comparison):
self.comparison(subtoken)
def comparison(self, token):
for subtoken in token.tokens:
if isinstance(subtoken, Parenthesis):
self.parenthesis(subtoken)
def parenthesis(self, token):
for subtoken in token.tokens:
if isinstance(subtoken, Identifier):
self.identifier(subtoken)
elif isinstance(subtoken, Parenthesis):
self.parenthesis(subtoken)
def identifier(self, token):
self.names.append(token)
def get_query(self):
return self.query
sql = """
WITH a as
(
SELECT
id, x, y
FROM d
)
SELECT
x,y, z
FROM e
left join a c
ON a.id = e.id
"""
t = RecursiveTokenParser(sql)
print(t.get_query())
print(t.get_table_names())