diff --git a/superset/connectors/sqla/models.py b/superset/connectors/sqla/models.py index 61483cc349df8..648bff44e8492 100644 --- a/superset/connectors/sqla/models.py +++ b/superset/connectors/sqla/models.py @@ -47,8 +47,10 @@ def query(self, query_obj): error_message = None qry = db.session.query(Annotation) qry = qry.filter(Annotation.layer_id == query_obj['filter'][0]['val']) - qry = qry.filter(Annotation.start_dttm >= query_obj['from_dttm']) - qry = qry.filter(Annotation.end_dttm <= query_obj['to_dttm']) + if query_obj['from_dttm']: + qry = qry.filter(Annotation.start_dttm >= query_obj['from_dttm']) + if query_obj['to_dttm']: + qry = qry.filter(Annotation.end_dttm <= query_obj['to_dttm']) status = QueryStatus.SUCCESS try: df = pd.read_sql_query(qry.statement, db.engine) diff --git a/superset/viz.py b/superset/viz.py index c295e5a88abcb..e50ee1b77a16a 100644 --- a/superset/viz.py +++ b/superset/viz.py @@ -379,7 +379,8 @@ def get_df_payload(self, query_obj=None): if query_obj and not is_loaded: try: df = self.get_df(query_obj) - if hasattr(self.datasource.database, 'db_engine_spec'): + if hasattr(self.datasource, 'database') and \ + hasattr(self.datasource.database, 'db_engine_spec'): db_engine_spec = self.datasource.database.db_engine_spec df = db_engine_spec.adjust_df_column_names(df, self.form_data) if self.status != utils.QueryStatus.FAILED: