mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #460 -- Added 'django-admin.py inspectdb' support for SQLite. Thanks, Swaroop
git-svn-id: http://code.djangoproject.com/svn/django/trunk@1484 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -35,6 +35,7 @@ get_date_trunc_sql = dbmod.get_date_trunc_sql | ||||
| get_limit_offset_sql = dbmod.get_limit_offset_sql | ||||
| get_random_function_sql = dbmod.get_random_function_sql | ||||
| get_table_list = dbmod.get_table_list | ||||
| get_table_description = dbmod.get_table_description | ||||
| get_relations = dbmod.get_relations | ||||
| OPERATOR_MAPPING = dbmod.OPERATOR_MAPPING | ||||
| DATA_TYPES = dbmod.DATA_TYPES | ||||
|   | ||||
| @@ -112,6 +112,9 @@ def get_random_function_sql(): | ||||
| def get_table_list(cursor): | ||||
|     raise NotImplementedError | ||||
|  | ||||
| def get_table_description(cursor, table_name): | ||||
|     raise NotImplementedError | ||||
|  | ||||
| def get_relations(cursor, table_name): | ||||
|     raise NotImplementedError | ||||
|  | ||||
|   | ||||
| @@ -124,6 +124,11 @@ def get_table_list(cursor): | ||||
|     cursor.execute("SHOW TABLES") | ||||
|     return [row[0] for row in cursor.fetchall()] | ||||
|  | ||||
| def get_table_description(cursor, table_name): | ||||
|     "Returns a description of the table, with the DB-API cursor.description interface." | ||||
|     cursor.execute("SELECT * FROM %s LIMIT 1" % table_name) | ||||
|     return cursor.description | ||||
|  | ||||
| def get_relations(cursor, table_name): | ||||
|     raise NotImplementedError | ||||
|  | ||||
|   | ||||
| @@ -100,6 +100,11 @@ def get_table_list(cursor): | ||||
|             AND pg_catalog.pg_table_is_visible(c.oid)""") | ||||
|     return [row[0] for row in cursor.fetchall()] | ||||
|  | ||||
| def get_table_description(cursor, table_name): | ||||
|     "Returns a description of the table, with the DB-API cursor.description interface." | ||||
|     cursor.execute("SELECT * FROM %s LIMIT 1" % table_name) | ||||
|     return cursor.description | ||||
|  | ||||
| def get_relations(cursor, table_name): | ||||
|     """ | ||||
|     Returns a dictionary of {field_index: (field_index_other_table, other_table)} | ||||
|   | ||||
| @@ -124,7 +124,12 @@ def _sqlite_date_trunc(lookup_type, dt): | ||||
|         return "%i-%02i-%02i 00:00:00" % (dt.year, dt.month, dt.day) | ||||
|  | ||||
| def get_table_list(cursor): | ||||
|     raise NotImplementedError | ||||
|     cursor.execute("SELECT name FROM sqlite_master WHERE type='table' ORDER BY name") | ||||
|     return [row[0] for row in cursor.fetchall()] | ||||
|  | ||||
| def get_table_description(cursor, table_name): | ||||
|     cursor.execute("PRAGMA table_info(%s)" % table_name) | ||||
|     return [(row[1], row[2], None, None) for row in cursor.fetchall()] | ||||
|  | ||||
| def get_relations(cursor, table_name): | ||||
|     raise NotImplementedError | ||||
|   | ||||
| @@ -571,8 +571,7 @@ def inspectdb(db_name): | ||||
|             relations = db.get_relations(cursor, table_name) | ||||
|         except NotImplementedError: | ||||
|             relations = {} | ||||
|         cursor.execute("SELECT * FROM %s LIMIT 1" % table_name) | ||||
|         for i, row in enumerate(cursor.description): | ||||
|         for i, row in enumerate(db.get_table_description(cursor, table_name)): | ||||
|             column_name = row[0] | ||||
|             if relations.has_key(i): | ||||
|                 rel = relations[i] | ||||
| @@ -586,12 +585,16 @@ def inspectdb(db_name): | ||||
|                     field_type = db.DATA_TYPES_REVERSE[row[1]] | ||||
|                 except KeyError: | ||||
|                     field_type = 'TextField' | ||||
|                     yield "    # The model-creator script used TextField by default, because" | ||||
|                     yield "    # it couldn't recognize your field type." | ||||
|                     field_type_was_guessed = True | ||||
|                 else: | ||||
|                     field_type_was_guessed = False | ||||
|                 field_desc = '%s = meta.%s(' % (column_name, field_type) | ||||
|                 if field_type == 'CharField': | ||||
|                     field_desc += 'maxlength=%s' % (row[3]) | ||||
|             yield '    %s)' % field_desc | ||||
|                 field_desc += ')' | ||||
|                 if field_type_was_guessed: | ||||
|                     field_desc += ' # This is a guess!' | ||||
|             yield '    %s' % field_desc | ||||
|         yield '    class META:' | ||||
|         yield '        db_table = %r' % table_name | ||||
|         yield '' | ||||
|   | ||||
		Reference in New Issue
	
	Block a user