當前位置: 首頁>>代碼示例>>Python>>正文


Python migrations.AlterModelTable方法代碼示例

本文整理匯總了Python中django.db.migrations.AlterModelTable方法的典型用法代碼示例。如果您正苦於以下問題:Python migrations.AlterModelTable方法的具體用法?Python migrations.AlterModelTable怎麽用?Python migrations.AlterModelTable使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在django.db.migrations的用法示例。


在下文中一共展示了migrations.AlterModelTable方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_alter_model_table_noop

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import AlterModelTable [as 別名]
def test_alter_model_table_noop(self):
        """
        Tests the AlterModelTable operation if the table name is not changed.
        """
        project_state = self.set_up_test_model("test_almota")
        # Test the state alteration
        operation = migrations.AlterModelTable("Pony", "test_almota_pony")
        new_state = project_state.clone()
        operation.state_forwards("test_almota", new_state)
        self.assertEqual(new_state.models["test_almota", "pony"].options["db_table"], "test_almota_pony")
        # Test the database alteration
        self.assertTableExists("test_almota_pony")
        with connection.schema_editor() as editor:
            operation.database_forwards("test_almota", editor, project_state, new_state)
        self.assertTableExists("test_almota_pony")
        # And test reversal
        with connection.schema_editor() as editor:
            operation.database_backwards("test_almota", editor, new_state, project_state)
        self.assertTableExists("test_almota_pony") 
開發者ID:denisenkom,項目名稱:django-sqlserver,代碼行數:21,代碼來源:test_operations.py

示例2: _test_create_alter_foo_delete_model

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import AlterModelTable [as 別名]
def _test_create_alter_foo_delete_model(self, alter_foo):
        """
        CreateModel, AlterModelTable, AlterUniqueTogether/AlterIndexTogether/
        AlterOrderWithRespectTo, and DeleteModel should collapse into nothing.
        """
        self.assertOptimizesTo(
            [
                migrations.CreateModel("Foo", [("name", models.CharField(max_length=255))]),
                migrations.AlterModelTable("Foo", "woohoo"),
                alter_foo,
                migrations.DeleteModel("Foo"),
            ],
            [],
        ) 
開發者ID:denisenkom,項目名稱:django-sqlserver,代碼行數:16,代碼來源:test_optimizer.py

示例3: test_alter_alter_table_model

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import AlterModelTable [as 別名]
def test_alter_alter_table_model(self):
        self._test_alter_alter_model(
            migrations.AlterModelTable("Foo", "a"),
            migrations.AlterModelTable("Foo", "b"),
        ) 
開發者ID:denisenkom,項目名稱:django-sqlserver,代碼行數:7,代碼來源:test_optimizer.py

示例4: test_alter_model_table

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import AlterModelTable [as 別名]
def test_alter_model_table(self):
        """
        Tests the AlterModelTable operation.
        """
        project_state = self.set_up_test_model("test_almota")
        # Test the state alteration
        operation = migrations.AlterModelTable("Pony", "test_almota_pony_2")
        self.assertEqual(operation.describe(), "Rename table for Pony to test_almota_pony_2")
        new_state = project_state.clone()
        operation.state_forwards("test_almota", new_state)
        self.assertEqual(new_state.models["test_almota", "pony"].options["db_table"], "test_almota_pony_2")
        # Test the database alteration
        self.assertTableExists("test_almota_pony")
        self.assertTableNotExists("test_almota_pony_2")
        with connection.schema_editor() as editor:
            operation.database_forwards("test_almota", editor, project_state, new_state)
        self.assertTableNotExists("test_almota_pony")
        self.assertTableExists("test_almota_pony_2")
        # And test reversal
        with connection.schema_editor() as editor:
            operation.database_backwards("test_almota", editor, new_state, project_state)
        self.assertTableExists("test_almota_pony")
        self.assertTableNotExists("test_almota_pony_2")
        # And deconstruction
        definition = operation.deconstruct()
        self.assertEqual(definition[0], "AlterModelTable")
        self.assertEqual(definition[1], [])
        self.assertEqual(definition[2], {'name': "Pony", 'table': "test_almota_pony_2"}) 
開發者ID:denisenkom,項目名稱:django-sqlserver,代碼行數:30,代碼來源:test_operations.py

示例5: test_alter_model_table_none

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import AlterModelTable [as 別名]
def test_alter_model_table_none(self):
        """
        Tests the AlterModelTable operation if the table name is set to None.
        """
        operation = migrations.AlterModelTable("Pony", None)
        self.assertEqual(operation.describe(), "Rename table for Pony to (default)") 
開發者ID:denisenkom,項目名稱:django-sqlserver,代碼行數:8,代碼來源:test_operations.py

示例6: alter_db_table

# 需要導入模塊: from django.db import migrations [as 別名]
# 或者: from django.db.migrations import AlterModelTable [as 別名]
def alter_db_table(field, filters: List[str]):
    """Creates a model with the specified field and then renames the database
    table.

    Arguments:
        field:
            The field to include into the
            model.

        filters:
            List of strings to filter
            SQL statements on.
    """

    model = define_fake_model()
    state = migrations.state.ProjectState.from_apps(apps)

    apply_migration(
        [
            migrations.CreateModel(
                model.__name__, fields=[("title", field.clone())]
            )
        ],
        state,
    )

    with filtered_schema_editor(*filters) as calls:
        apply_migration(
            [migrations.AlterModelTable(model.__name__, "NewTableName")], state
        )

    yield calls 
開發者ID:SectorLabs,項目名稱:django-postgres-extra,代碼行數:34,代碼來源:migrations.py


注:本文中的django.db.migrations.AlterModelTable方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。