mirror of
https://github.com/apache/superset.git
synced 2026-04-18 23:55:00 +00:00
Speed up all CRUD list views (#2747)
Load times on list view pages like Slices, Dashboards, Tables and Database have grown to be terrible over time. After a bit of digging, I found that the not specifying `search_columns` in ModelViews actually means "all columns" and that for each filter, FAB goes and fetches a list of all values to prepopulate the filter dropdowns. That means that the list of tables would fetch all slices and all users upfront which is horrible. Worse, database list view would fetch all queries with is insane. This picks a subset of columns for search/filters and changes the default to show only 100 elements per page instead of 500
This commit is contained in:
committed by
GitHub
parent
d5e9d5d045
commit
e5584440ce
@@ -119,6 +119,7 @@ class DruidClusterModelView(SupersetModelView, DeleteMixin): # noqa
|
||||
]
|
||||
edit_columns = add_columns
|
||||
list_columns = ['cluster_name', 'metadata_last_refreshed']
|
||||
search_columns = ('cluster_name',)
|
||||
label_columns = {
|
||||
'cluster_name': _("Cluster"),
|
||||
'coordinator_host': _("Coordinator Host"),
|
||||
@@ -150,7 +151,7 @@ class DruidDatasourceModelView(SupersetModelView, DeleteMixin): # noqa
|
||||
datamodel = SQLAInterface(models.DruidDatasource)
|
||||
list_widget = ListWidgetWithCheckboxes
|
||||
list_columns = [
|
||||
'datasource_link', 'cluster', 'changed_by_', 'changed_on_', 'offset']
|
||||
'datasource_link', 'cluster', 'changed_by_', 'modified']
|
||||
order_columns = [
|
||||
'datasource_link', 'changed_on_', 'offset']
|
||||
related_views = [DruidColumnInlineView, DruidMetricInlineView]
|
||||
@@ -159,6 +160,9 @@ class DruidDatasourceModelView(SupersetModelView, DeleteMixin): # noqa
|
||||
'is_hidden',
|
||||
'filter_select_enabled', 'fetch_values_from',
|
||||
'default_endpoint', 'offset', 'cache_timeout']
|
||||
search_columns = (
|
||||
'datasource_name', 'cluster', 'description', 'owner'
|
||||
)
|
||||
add_columns = edit_columns
|
||||
show_columns = add_columns + ['perm']
|
||||
page_size = 500
|
||||
|
||||
@@ -137,7 +137,7 @@ class TableModelView(SupersetModelView, DeleteMixin): # noqa
|
||||
datamodel = SQLAInterface(models.SqlaTable)
|
||||
list_columns = [
|
||||
'link', 'database',
|
||||
'changed_by_', 'changed_on_']
|
||||
'changed_by_', 'modified']
|
||||
order_columns = [
|
||||
'link', 'database', 'changed_on_']
|
||||
add_columns = ['database', 'schema', 'table_name']
|
||||
@@ -149,6 +149,9 @@ class TableModelView(SupersetModelView, DeleteMixin): # noqa
|
||||
show_columns = edit_columns + ['perm']
|
||||
related_views = [TableColumnInlineView, SqlMetricInlineView]
|
||||
base_order = ('changed_on', 'desc')
|
||||
search_columns = (
|
||||
'database', 'schema', 'table_name', 'owner',
|
||||
)
|
||||
description_columns = {
|
||||
'slices': _(
|
||||
"The list of slices associated with this table. By "
|
||||
|
||||
@@ -188,7 +188,7 @@ class BaseSupersetView(BaseView):
|
||||
|
||||
|
||||
class SupersetModelView(ModelView):
|
||||
page_size = 500
|
||||
page_size = 100
|
||||
|
||||
|
||||
class ListWidgetWithCheckboxes(ListWidget):
|
||||
|
||||
@@ -175,7 +175,9 @@ class DatabaseView(SupersetModelView, DeleteMixin): # noqa
|
||||
'database_name', 'sqlalchemy_uri', 'cache_timeout', 'extra',
|
||||
'expose_in_sqllab', 'allow_run_sync', 'allow_run_async',
|
||||
'allow_ctas', 'allow_dml', 'force_ctas_schema']
|
||||
search_exclude_columns = ('password',)
|
||||
search_exclude_columns = (
|
||||
'password', 'tables', 'created_by', 'changed_by', 'queries',
|
||||
'saved_queries', )
|
||||
edit_columns = add_columns
|
||||
show_columns = [
|
||||
'tables',
|
||||
@@ -317,6 +319,9 @@ class SliceModelView(SupersetModelView, DeleteMixin): # noqa
|
||||
label_columns = {
|
||||
'datasource_link': 'Datasource',
|
||||
}
|
||||
search_columns = (
|
||||
'slice_name', 'description', 'viz_type', 'owners',
|
||||
)
|
||||
list_columns = [
|
||||
'slice_link', 'viz_type', 'datasource_link', 'creator', 'modified']
|
||||
edit_columns = [
|
||||
@@ -405,6 +410,7 @@ class DashboardModelView(SupersetModelView, DeleteMixin): # noqa
|
||||
'dashboard_title', 'slug', 'slices', 'owners', 'position_json', 'css',
|
||||
'json_metadata']
|
||||
show_columns = edit_columns + ['table_names']
|
||||
search_columns = ('dashboard_title', 'slug', 'owners')
|
||||
add_columns = edit_columns
|
||||
base_order = ('changed_on', 'desc')
|
||||
description_columns = {
|
||||
|
||||
@@ -31,6 +31,7 @@ class SavedQueryView(SupersetModelView, DeleteMixin):
|
||||
show_columns = [
|
||||
'id', 'label', 'user', 'database',
|
||||
'description', 'sql', 'pop_tab_link']
|
||||
search_columns = ('label', 'user', 'database', 'schema', 'changed_on')
|
||||
add_columns = ['label', 'database', 'description', 'sql']
|
||||
edit_columns = add_columns
|
||||
base_order = ('changed_on', 'desc')
|
||||
|
||||
Reference in New Issue
Block a user