south与mysql问题

0 投票
1 回答
613 浏览
提问于 2025-04-17 03:05

有没有人能帮我一下?我最近安装了south,用来在我的django项目中更新变更,这个项目是在生产服务器上运行的(使用的是Appache 2.0、MySql 5.0、python 2.5、Mysqldb for python、django 1.3,还有south 0.7.3)。

我把一个叫做signature的应用转换成了south,转换成功了。然后我运行了命令manage migrate signature,结果输出了以下内容:

C:\python projects\suivireal>manage.py migrate signature

Running migrations for signature:
- Migrating forwards to 0002_auto__del_field_agent_titre_en__add_field_agent_ni

veau__add_field_agen.

> signature:0002_auto__del_field_agent_titre_en__add_field_agent_niveau__add_fi

eld_agen

Traceback (most recent call last):
File "C:\python projects\suivireal\manage.py", line 14, in <module>

    execute_manager(settings)

File "C:\Python26\Lib\site-packages\django\core\management\__init__.py", line

438, in execute_manager

    utility.execute()

File "C:\Python26\Lib\site-packages\django\core\management\__init__.py", line

379, in execute

    self.fetch_command(subcommand).run_from_argv(self.argv)

File "C:\Python26\Lib\site-packages\django\core\management\base.py", line 191,

in run_from_argv

    self.execute(*args, **options.__dict__)

File "C:\Python26\Lib\site-packages\django\core\management\base.py", line 220,

in execute

    output = self.handle(*args, **options)

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\management\comma

nds\migrate.py", line 102, in handle

    delete_ghosts = delete_ghosts,

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\migration\__init

__.py", line 202, in migrate_app

    success = migrator.migrate_many(target, workplan, database)

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\migration\migrat

ors.py", line 215, in migrate_many

    result = migrator.__class__.migrate_many(migrator, target, migrations, datab

ase)

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\migration\migrat

ors.py", line 284, in migrate_many

    result = self.migrate(migration, database)

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\migration\migrat

ors.py", line 121, in migrate

    result = self.run(migration)

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\migration\migrat

ors.py", line 94, in run

    dry_run.run_migration(migration)

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\migration\migrat

ors.py", line 172, in run_migration

    self._run_migration(migration)

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\migration\migrat

ors.py", line 162, in _run_migration

    raise exceptions.FailedDryRun(migration, sys.exc_info())

south.exceptions.FailedDryRun:  ! Error found during dry run of '0002_auto__del_

field_agent_titre_en__add_field_agent_niveau__add_field_agen'! Aborting.

Traceback (most recent call last):

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\migration\migrat

ors.py", line 159, in _run_migration

    migration_function()

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\migration\migrat

ors.py", line 56, in <lambda>

    return (lambda: direction(orm))

File "C:\python projects\suivireal\..\suivireal\signature\migrations\0002_auto

__del_field_agent_titre_en__add_field_agent_niveau__add_field_agen.py", line 12,

in forwards

    db.delete_column('signature_agent', 'titre_en')

File "c:\python26\lib\site-packages\South-0.7-py2.6.egg\south\db\mysql.py", li

ne 90, in delete_column

    result = cursor.execute(get_fkeyname_query % (db_name, table_name, name))

File "C:\Python26\Lib\site-packages\django\db\backends\util.py", line 34, in e

xecute

    return self.cursor.execute(sql,     params)

File "C:\Python26\Lib\site-packages\django\db\backends\mysql\base.py", line 86

, in execute

    return self.cursor.execute(query, args)

File "C:\Python26\Lib\site-packages\MySQLdb\cursors.py", line 176, in execute

    if not self._defer_warnings: self._warning_check()

File "C:\Python26\Lib\site-packages\MySQLdb\cursors.py", line 92, in _warning_

check     warn(w[-1], self.Warning, 3)

Warning: Table 'chold.signupsetup' doesn't exist

我在网上查了查,想看看这个问题是否和mysql有关,但我找不到解决办法。

1 个回答

0

这个错误提示是说你的数据库里缺少一个叫“chold.signupsetup”的表。

你需要检查一下这个表是否存在,如果不存在,就要创建它。通常在django应用中创建表的方法是运行syncdb:

$ python manage.py syncdb

然后再试着重新运行迁移。

撰写回答