django test数据库乱码

在Django项目运行test时遇到数据库乱码问题,由于test生成的临时数据库默认非UTF8编码。通过在settings.py中配置数据库字符编码为UTF8,如:`DEFAULT_CHARSET='utf8'`,可以解决该问题。参考Django官方文档和相关博客文章进行设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

在django项目中添加test测试,出现数据库乱码的现象,报错:
SyncError: (1366, "Incorrect string value: '\\xE9\\x85\\x92\\xE5\\xBA\\x97' for column 'organization' at row 1")
其中organization这个字段加入了中文,导致乱码

分析

问题原因在于test生成的临时数据库默认不是utf8,不支持中文,导致错误。
尝试过修改项目数据库的字符编码,并没有效果,因为test使用的数据库数据是临时生成的,并不适用项目配置的数据库

解决方法

在settings.py中添加对database的描述,设置字符编码默认设置
如下:

'TEST_CHARSET': 'utf8',        
'TEST_COLLATION': 'utf8_general_ci',

比如一个项目中database设置:

DATABASES = {
    'default': {              
        'ENGINE': 'django.db.backends.mysql'
Django中,如果你想在单元测试(unit tests)中更新数据库并保持数据的一致性,通常不直接在测试代码里操作真实的数据库,因为这可能会破坏测试的隔离性和可靠性。Django提供了一个名为`TransactionTestCase`的类,它会自动为每个测试用例开启一个新的事务,并在测试结束后回滚事务,以此防止数据污染。 如果你确实需要在测试过程中更改数据库状态(比如模拟真实的数据变化),你可以使用`TestCase`下的`setUpTestData()`方法,或在测试方法前使用`@override_settings(TEST_DATABASE_NAME...)`装饰器来临时设置一个独立的数据库实例。然后,你可以使用Django ORM提供的方法(如`.create()`, `.update()`或`.save()`等)来操作模型实例。 但是,为了维护良好的测试实践,建议尽量避免直接在测试中修改数据库,而是编写隔离的场景模拟代码。如果真的需要,记得在`tearDown()`方法中清理数据。 示例代码片段: ```python from django.test import TransactionTestCase from .models import MyModel class MyTest(TransactionTestCase): def setUp(self): # 在这里创建或更新数据,不会影响其他测试 self.my_model = MyModel.objects.create(field1='value1') def test_something(self): # 使用Django ORM进行测试 self.my_model.field2 = 'new value' self.my_model.save() def tearDown(self): # 在测试结束时删除之前创建的数据 MyModel.objects.all().delete() ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值