值类型变化的值太长(N) [英] value too long for type character varying(N)

查看:190
本文介绍了值类型变化的值太长(N)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我的模型有一个SlugField。当我尝试保存这个模型的一个实例,其中slug字段设置为比字段的 max_length 参数(默认为50)的字符串,我得到以下错误Postgresql:值太长,类型字符变化(50)



不是Django(或Postgresql )应该在保存时截断字符串?除了每次手动截断以外,我还能做些什么?

解决方案

安装 south 并调整列(最佳选项),或创建一个 pre_save信号,并在保存之前添加代码将其截断为50个字符。如下所示:

  from django.db.models.signals import pre_save 
from app.model import mymodel

def truncater(发件人,实例,** kwargs):
如果发件人是mymodel:
如果len(instance.fieldname)> 50:
instance.fieldname = instance .fieldname [:50]
pre_save.connect(truncater,sender = mymodel)


My model has a SlugField. When I try to save an instance of this model with the slug field set to a string which is longer than the field's max_length parameter (which is 50 by default), I get the following error from Postgresql: value too long for type character varying(50).

Is not Django (or Postgresql) supposed to truncate the string when saving? What can I do to fix it other than truncating it manually every time?

解决方案

Either install south and resize the column (best option), or create a pre_save signal and add code to truncate the field to 50 characters before it is saved. Something like:

from django.db.models.signals import pre_save
from app.model import mymodel

def truncater(sender, instance, **kwargs):
    if sender is mymodel:
        if len(instance.fieldname)>50:
            instance.fieldname = instance.fieldname[:50]
pre_save.connect(truncater, sender=mymodel)

这篇关于值类型变化的值太长(N)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆