모델의 특정 필드 이름을 변경하고 싶습니다.
class Foo(models.Model):
name = models.CharField()
rel = models.ForeignKey(Bar)
로 변경해야합니다.
class Foo(models.Model):
full_name = models.CharField()
odd_relation = models.ForeignKey(Bar)
South를 사용하여 가장 쉬운 방법은 무엇입니까?
답변
db.rename_column
기능을 사용할 수 있습니다 .
class Migration:
def forwards(self, orm):
# Rename 'name' field to 'full_name'
db.rename_column('app_foo', 'name', 'full_name')
def backwards(self, orm):
# Rename 'full_name' field to 'name'
db.rename_column('app_foo', 'full_name', 'name')
첫 번째 인수 db.rename_column
는 테이블 이름이므로 Django가 테이블 이름을 만드는 방법을 기억하는 것이 중요 합니다 .
Django는 모델 클래스의 이름과이를 포함하는 앱에서 데이터베이스 테이블의 이름을 자동으로 파생시킵니다. 모델의 데이터베이스 테이블 이름은 모델의 “앱 레이블”(manage.py startapp에 사용 된 이름)을 모델의 클래스 이름에 밑줄로 결합하여 구성됩니다.
같은 프로젝트 아이템으로 사용하여 멀티 말로, 낙타 맡았다 모델 이름을 가지고있는 경우에, 테이블 이름이 될 것입니다 app_projectitem
(즉, 밑줄 사이에 삽입되지 않습니다 project
및 item
비록 그들이 낙타 맡았다 있습니다).
답변
내가하는 일은 다음과 같습니다.
- 모델에서 열 이름을 변경하십시오 (이 예에서는
myapp/models.py
). - 운영
./manage.py schemamigration myapp renaming_column_x --auto
참고 renaming_column_x
로 원하는 것을 지정할 수 있습니다. 마이그레이션 파일에 설명적인 이름을 지정하는 방법 일뿐입니다.
그러면 myapp/migrations/000x_renaming_column_x.py
이전 열을 삭제하고 새 열을 추가하는 파일이 생성 됩니다.
이 파일의 코드를 수정하여 마이그레이션 동작을 간단한 이름 바꾸기로 변경하십시오.
class Migration(SchemaMigration):
def forwards(self, orm):
# Renaming column 'mymodel.old_column_name' to 'mymodel.new_column_name'
db.rename_column(u'myapp_mymodel', 'old_column_name', 'new_column_name')
def backwards(self, orm):
# Renaming column 'mymodel.new_column_name' to 'mymodel.old_column_name'
db.rename_column(u'myapp_mymodel', 'new_column_name', 'old_column_name')
답변
db.rename 열에 대해 몰랐지만 편리하게 들리지만 과거에는 새 열을 하나의 스키마 마이그레이션으로 추가 한 다음 값을 새 필드로 이동하기 위해 데이터 마이그레이션을 만든 다음 이전 열을 제거하는 두 번째 스키마 마이그레이션을 만들었습니다.
답변
Django 1.7에는 마이그레이션 이 도입 되었으므로 이제 마이그레이션 을 관리하기 위해 추가 패키지를 설치할 필요가 없습니다.
모델 이름을 바꾸려면 먼저 빈 마이그레이션을 만들어야합니다.
$ manage.py makemigrations <app_name> --empty
그런 다음 마이그레이션 코드를 다음과 같이 편집해야합니다.
from django.db import models, migrations
class Migration(migrations.Migration):
dependencies = [
('yourapp', 'XXXX_your_previous_migration'),
]
operations = [
migrations.RenameField(
model_name='Foo',
old_name='name',
new_name='full_name'
),
migrations.RenameField(
model_name='Foo',
old_name='rel',
new_name='odd_relation'
),
]
그리고 나서 다음을 실행해야합니다.
$ manage.py migrate <app_name>
답변
그냥 모델을 변경하고 makemigrations
1.9에서 실행하십시오 .
Django는 사용자가 단일 필드를 삭제하고 생성했음을 자동으로 감지하여 다음을 묻습니다.
Did you rename model.old to model.new (a IntegerField)? [y/N]
예라고 말하면 올바른 마이그레이션이 생성됩니다. 마법.
답변
south
프로젝트 설정 파일에서 설치된 앱에 추가 하십시오.- 추가 / 수정 된 필드 / 테이블을 주석 처리하십시오.
$ manage.py Schemamigration <app_name> --initial
$ manage.py migrate <app_name> --Fake
- 필드의 주석을 해제하고 수정 된 필드를 작성하십시오
$ manage.py Schemamigration --auto
$ manage.py migrate <app_name>
‘pycharm’을 사용하는 경우 ‘manage.py’대신 ‘ctrl + shift + r’을 사용하고 매개 변수에 ‘shift’를 사용할 수 있습니다.