免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 8913 | 回复: 5
打印 上一主题 下一主题

Django模型下CharField的长度和数据库Varchar长度变长问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-07-26 16:09 |只看该作者 |倒序浏览
mysql 5.1中
表字段类型和长度为 VARCHAR(16),但是使用manage.py inspectdb 出来的模型CharField(max_length=48)
max_length和数据库中的长度基本都增大了3倍?
怎么会是这样?跟字符集设置有关吗?

mysql表字符集为utf8

论坛徽章:
24
15-16赛季CBA联赛之北京
日期:2018-08-17 18:43:33技术图书徽章
日期:2018-08-22 12:53:57技术图书徽章
日期:2018-08-22 12:54:20技术图书徽章
日期:2018-08-22 12:54:3015-16赛季CBA联赛之福建
日期:2018-10-19 16:58:1619周年集字徽章-庆
日期:2019-08-27 13:28:5619周年集字徽章-19
日期:2019-08-27 13:31:2619周年集字徽章-19
日期:2019-08-27 13:31:2615-16赛季CBA联赛之同曦
日期:2019-09-05 12:03:2819周年集字徽章-周
日期:2019-09-06 18:54:5415-16赛季CBA联赛之上海
日期:2018-07-25 11:55:2615-16赛季CBA联赛之青岛
日期:2018-07-10 14:13:18
2 [报告]
发表于 2012-07-26 16:26 |只看该作者
这么高深的问题.
我也只是会用到 query的一些皮毛

论坛徽章:
0
3 [报告]
发表于 2012-07-26 17:04 |只看该作者
不是吧!各位大侠!

测试charset=gbk也是一样是 长度X3

论坛徽章:
0
4 [报告]
发表于 2012-07-26 17:41 |只看该作者
同时,我用inspectdb出来的模型文件,重新syncdb时,
因为字段长度,报如下错误:
Error: One or more models did not validate:
books.djangocontenttype: "app_label": CharField cannot have a "max_length" great
er than 255 when using "unique=True".
books.djangocontenttype: "model": CharField cannot have a "max_length" greater t
han 255 when using "unique=True".
books.authpermission: "codename": CharField cannot have a "max_length" greater t
han 255 when using "unique=True".

而原表中字段类型、长度为varchar(100);
inspectdb 有哪些设置和要求呢,在manage.py inspectdb官方文档部分,没有看到关于此部分的描述!

论坛徽章:
0
5 [报告]
发表于 2012-07-27 09:17 |只看该作者
我到不怎么用manage.py inspectdb,
直接使用manage.py syncdb
没发现你说的问题。
这个跟字符集没什么关系,主要看你的数据库的字符集是什么,我一般使用的是utf-8格式
max_length=50,数据表对应的就是50。

论坛徽章:
0
6 [报告]
发表于 2012-07-27 11:09 |只看该作者
回复 5# ragkk

syncdb 同步到db中的的新建表字段长度是没有变化的;
但是对于已经存在表结构导出来的时候,用inspectdb方面一些。
但,遇到了这种奇怪的问题。应该是哪方面字符集的配置问题。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP