mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06: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:
		
							
								
								
									
										1
									
								
								AUTHORS
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								AUTHORS
									
									
									
									
									
								
							| @@ -74,6 +74,7 @@ answer newbie questions, and generally made Django that much better: | |||||||
|     David Schein |     David Schein | ||||||
|     sopel |     sopel | ||||||
|     Radek Švarz <http://www.svarz.cz/translate/> |     Radek Švarz <http://www.svarz.cz/translate/> | ||||||
|  |     Swaroop C H <http://www.swaroopch.info> | ||||||
|     Aaron Swartz <http://www.aaronsw.com/> |     Aaron Swartz <http://www.aaronsw.com/> | ||||||
|     Tom Tobin |     Tom Tobin | ||||||
|     Joe Topjian <http://joe.terrarum.net/geek/code/python/django/> |     Joe Topjian <http://joe.terrarum.net/geek/code/python/django/> | ||||||
|   | |||||||
| @@ -35,6 +35,7 @@ get_date_trunc_sql = dbmod.get_date_trunc_sql | |||||||
| get_limit_offset_sql = dbmod.get_limit_offset_sql | get_limit_offset_sql = dbmod.get_limit_offset_sql | ||||||
| get_random_function_sql = dbmod.get_random_function_sql | get_random_function_sql = dbmod.get_random_function_sql | ||||||
| get_table_list = dbmod.get_table_list | get_table_list = dbmod.get_table_list | ||||||
|  | get_table_description = dbmod.get_table_description | ||||||
| get_relations = dbmod.get_relations | get_relations = dbmod.get_relations | ||||||
| OPERATOR_MAPPING = dbmod.OPERATOR_MAPPING | OPERATOR_MAPPING = dbmod.OPERATOR_MAPPING | ||||||
| DATA_TYPES = dbmod.DATA_TYPES | DATA_TYPES = dbmod.DATA_TYPES | ||||||
|   | |||||||
| @@ -112,6 +112,9 @@ def get_random_function_sql(): | |||||||
| def get_table_list(cursor): | def get_table_list(cursor): | ||||||
|     raise NotImplementedError |     raise NotImplementedError | ||||||
|  |  | ||||||
|  | def get_table_description(cursor, table_name): | ||||||
|  |     raise NotImplementedError | ||||||
|  |  | ||||||
| def get_relations(cursor, table_name): | def get_relations(cursor, table_name): | ||||||
|     raise NotImplementedError |     raise NotImplementedError | ||||||
|  |  | ||||||
|   | |||||||
| @@ -124,6 +124,11 @@ def get_table_list(cursor): | |||||||
|     cursor.execute("SHOW TABLES") |     cursor.execute("SHOW TABLES") | ||||||
|     return [row[0] for row in cursor.fetchall()] |     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): | def get_relations(cursor, table_name): | ||||||
|     raise NotImplementedError |     raise NotImplementedError | ||||||
|  |  | ||||||
|   | |||||||
| @@ -100,6 +100,11 @@ def get_table_list(cursor): | |||||||
|             AND pg_catalog.pg_table_is_visible(c.oid)""") |             AND pg_catalog.pg_table_is_visible(c.oid)""") | ||||||
|     return [row[0] for row in cursor.fetchall()] |     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): | def get_relations(cursor, table_name): | ||||||
|     """ |     """ | ||||||
|     Returns a dictionary of {field_index: (field_index_other_table, other_table)} |     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) |         return "%i-%02i-%02i 00:00:00" % (dt.year, dt.month, dt.day) | ||||||
|  |  | ||||||
| def get_table_list(cursor): | 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): | def get_relations(cursor, table_name): | ||||||
|     raise NotImplementedError |     raise NotImplementedError | ||||||
|   | |||||||
| @@ -571,8 +571,7 @@ def inspectdb(db_name): | |||||||
|             relations = db.get_relations(cursor, table_name) |             relations = db.get_relations(cursor, table_name) | ||||||
|         except NotImplementedError: |         except NotImplementedError: | ||||||
|             relations = {} |             relations = {} | ||||||
|         cursor.execute("SELECT * FROM %s LIMIT 1" % table_name) |         for i, row in enumerate(db.get_table_description(cursor, table_name)): | ||||||
|         for i, row in enumerate(cursor.description): |  | ||||||
|             column_name = row[0] |             column_name = row[0] | ||||||
|             if relations.has_key(i): |             if relations.has_key(i): | ||||||
|                 rel = relations[i] |                 rel = relations[i] | ||||||
| @@ -586,12 +585,16 @@ def inspectdb(db_name): | |||||||
|                     field_type = db.DATA_TYPES_REVERSE[row[1]] |                     field_type = db.DATA_TYPES_REVERSE[row[1]] | ||||||
|                 except KeyError: |                 except KeyError: | ||||||
|                     field_type = 'TextField' |                     field_type = 'TextField' | ||||||
|                     yield "    # The model-creator script used TextField by default, because" |                     field_type_was_guessed = True | ||||||
|                     yield "    # it couldn't recognize your field type." |                 else: | ||||||
|  |                     field_type_was_guessed = False | ||||||
|                 field_desc = '%s = meta.%s(' % (column_name, field_type) |                 field_desc = '%s = meta.%s(' % (column_name, field_type) | ||||||
|                 if field_type == 'CharField': |                 if field_type == 'CharField': | ||||||
|                     field_desc += 'maxlength=%s' % (row[3]) |                     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 '    class META:' | ||||||
|         yield '        db_table = %r' % table_name |         yield '        db_table = %r' % table_name | ||||||
|         yield '' |         yield '' | ||||||
|   | |||||||
| @@ -86,8 +86,9 @@ customizations. In particular, you'll need to do this: | |||||||
|     * Add ``primary_key=True`` to one field in each model. The ``inspectdb`` |     * Add ``primary_key=True`` to one field in each model. The ``inspectdb`` | ||||||
|       doesn't yet introspect primary keys. |       doesn't yet introspect primary keys. | ||||||
|  |  | ||||||
| ``inspectdb`` only works with PostgreSQL and MySQL. Foreign-key detection only | ``inspectdb`` works with PostgreSQL, MySQL and SQLite. Foreign-key detection | ||||||
| works in PostgreSQL. | only works in PostgreSQL. In SQLite, it cannot detect column types; it'll | ||||||
|  | use ``TextField`` for each column. | ||||||
|  |  | ||||||
| install [modelmodule modelmodule ...] | install [modelmodule modelmodule ...] | ||||||
| ------------------------------------- | ------------------------------------- | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user