En primer lugar, aquí está mi configuración actual:syncdb de Django falla con MySQL Error: 150
Django: la versión 1.3
MySQL: Versión 4.0.18 (no es mi primera opción ...)
cuando corro syncdb, me sale el siguiente error:
Creating tables ...
Creating table auth_permission
Creating table auth_group_permissions
Traceback (most recent call last):
File "C:\path_to_app\manage.py", line 14, in <module>
execute_manager(settings)
File "C:\Python27\lib\site-packages\django\core\management\__init__.py", line 438, in execute_manager
utility.execute()
File "C:\Python27\lib\site-packages\django\core\management\__init__.py", line 379, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "C:\Python27\lib\site-packages\django\core\management\base.py", line 191, in run_from_argv
self.execute(*args, **options.__dict__)
File "C:\Python27\lib\site-packages\django\core\management\base.py", line 220, in execute
output = self.handle(*args, **options)
File "C:\Python27\lib\site-packages\django\core\management\base.py", line 351, in handle
return self.handle_noargs(**options)
File "C:\Python27\lib\site-packages\django\core\management\commands\syncdb.py", line 101, in handle_noargs
cursor.execute(statement)
File "C:\Python27\lib\site-packages\django\db\backends\util.py", line 34, in execute
return self.cursor.execute(sql, params)
File "C:\Python27\lib\site-packages\django\db\backends\mysql\base.py", line 86, in execute
return self.cursor.execute(query, args)
File "C:\Python27\lib\site-packages\MySQLdb\cursors.py", line 174, in execute
self.errorhandler(self, exc, value)
File "C:\Python27\lib\site-packages\MySQLdb\connections.py", line 36, in defaulterrorhandler
raise errorclass, errorvalue
_mysql_exceptions.OperationalError: (1005, "Can't create table '.\\database_name\\#sql-d64_e75f2.frm' (errno: 150)")
por lo que entiendo que tiene algo que ver con la forma en InnoDB maneja las claves externas. Esto es lo que se ve mi archivo de configuración como:
DATABASES = {
'default': {
....
'OPTIONS': { 'init_command': 'SET table_type=INNODB;', 'charset': 'latin1'},
},
}
Cuando no se specfied "SET table_type = INNODB", todo funciona sin problemas. He buscado en la red y parece que el motor InnoDB no le gusta algo sobre the SQL Django is generating
Por ahora, el único trabajo que encontré fue crear las tablas yo mismo, y usar inspectDB para generar los modelos. ..
¿Hay una solución para esto? ¡Gracias!
Para crear sus tablas manualmente con un mínimo esfuerzo, copie y edite el resultado de ['django-admin.py sql'] (https://docs.djangoproject.com/en/dev/ref/django-admin/#sql- appname-appname) o use el comando ['django-admin.py customsql'] (https://docs.djangoproject.com/en/dev/ref/django-admin/#sqlcustom-appname-appname). –