Add basic table listing view, with rough estimate row counts
This commit is contained in:
		
							parent
							
								
									73c0d02b9a
								
							
						
					
					
						commit
						5a2f20e489
					
				
					 1 changed files with 72 additions and 0 deletions
				
			
		
							
								
								
									
										72
									
								
								tailbone/views/tables.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								tailbone/views/tables.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,72 @@ | |||
| # -*- coding: utf-8; -*- | ||||
| ################################################################################ | ||||
| # | ||||
| #  Rattail -- Retail Software Framework | ||||
| #  Copyright © 2010-2017 Lance Edgar | ||||
| # | ||||
| #  This file is part of Rattail. | ||||
| # | ||||
| #  Rattail is free software: you can redistribute it and/or modify it under the | ||||
| #  terms of the GNU Affero General Public License as published by the Free | ||||
| #  Software Foundation, either version 3 of the License, or (at your option) | ||||
| #  any later version. | ||||
| # | ||||
| #  Rattail is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| #  WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS | ||||
| #  FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for | ||||
| #  more details. | ||||
| # | ||||
| #  You should have received a copy of the GNU Affero General Public License | ||||
| #  along with Rattail.  If not, see <http://www.gnu.org/licenses/>. | ||||
| # | ||||
| ################################################################################ | ||||
| """ | ||||
| Views with info about the underlying Rattail tables | ||||
| """ | ||||
| 
 | ||||
| from __future__ import unicode_literals, absolute_import | ||||
| 
 | ||||
| from tailbone.views import MasterView | ||||
| from tailbone.newgrids import Grid, GridColumn | ||||
| 
 | ||||
| 
 | ||||
| class TablesView(MasterView): | ||||
|     """ | ||||
|     Master view for tables | ||||
|     """ | ||||
|     normalized_model_name = 'table' | ||||
|     model_key = 'name' | ||||
|     model_title = "Table" | ||||
|     creatable = False | ||||
|     editable = False | ||||
|     deletable = False | ||||
|     viewable = False | ||||
|     grid_factory = Grid | ||||
|     filterable = False | ||||
|     pageable = False | ||||
| 
 | ||||
|     def get_data(self, **kwargs): | ||||
|         """ | ||||
|         Fetch existing table names and estimate row counts via PG SQL | ||||
|         """ | ||||
|         sql = """ | ||||
|         select schemaname, relname, n_live_tup | ||||
|         from pg_stat_user_tables | ||||
|         order by n_live_tup desc; | ||||
|         """ | ||||
|         result = self.Session.execute(sql) | ||||
|         return [dict(name=row[1], row_count=row[2]) for row in result] | ||||
| 
 | ||||
|     def configure_grid(self, g): | ||||
|         g.columns = [ | ||||
|             GridColumn('name'), | ||||
|             GridColumn('row_count'), | ||||
|         ] | ||||
| 
 | ||||
|         g.sorters['name'] = g.make_sorter('name', foldcase=True) | ||||
|         g.sorters['row_count'] = g.make_sorter('row_count') | ||||
|         g.default_sortkey = 'name' | ||||
| 
 | ||||
| 
 | ||||
| def includeme(config): | ||||
|     TablesView.defaults(config) | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lance Edgar
						Lance Edgar