Skip to content
This repository has been archived by the owner on Nov 3, 2023. It is now read-only.

Commit

Permalink
[get_df] Adding support for multi-statement SQL (apache#5086)
Browse files Browse the repository at this point in the history
  • Loading branch information
john-bodley authored and timifasubaa committed Jul 25, 2018
1 parent 43e852c commit c495c28
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 2 deletions.
8 changes: 6 additions & 2 deletions superset/models/core.py
Original file line number Diff line number Diff line change
Expand Up @@ -691,9 +691,13 @@ def get_quoter(self):
return self.get_dialect().identifier_preparer.quote

def get_df(self, sql, schema):
sql = sql.strip().strip(';')
sqls = [str(s).strip().strip(';') for s in sqlparse.parse(sql)]
eng = self.get_sqla_engine(schema=schema)
df = pd.read_sql_query(sql, eng)

for i in range(len(sqls) - 1):
eng.execute(sqls[i])

df = pd.read_sql_query(sqls[-1], eng)

def needs_conversion(df_series):
if df_series.empty:
Expand Down
10 changes: 10 additions & 0 deletions tests/model_tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,9 @@ def test_single_statement(self):
main_db = self.get_main_database(db.session)

if main_db.backend == 'mysql':
df = main_db.get_df('SELECT 1', None)
self.assertEquals(df.iat[0, 0], 1)

df = main_db.get_df('SELECT 1;', None)
self.assertEquals(df.iat[0, 0], 1)

Expand All @@ -120,6 +123,13 @@ def test_multi_statement(self):
df = main_db.get_df("USE superset; SELECT ';';", None)
self.assertEquals(df.iat[0, 0], ';')

df = main_db.get_df('USE superset; SELECT 1', None)
self.assertEquals(df.iat[0, 0], 1)

df = main_db.get_df("USE superset; SELECT ';';", None)
self.assertEquals(df.iat[0, 0], ';')


class SqlaTableModelTestCase(SupersetTestCase):

def test_get_timestamp_expression(self):
Expand Down

0 comments on commit c495c28

Please sign in to comment.