Django博客开发笔记摘要之MySQL表名大小写问题

最近想把写了一部分的博客部署到SAE上去,本来以为几分钟的事情,结果坑了半天。

首先是数据库导入问题,从本来导出的数据库不知怎么就是导入不进SAE上数据库里,只能一个个表导入,真麻烦。

好不容易都导完了,进个主页看看吧,报错Blog_blogpost这个表不存在。问题是这表必须存在,我一个个手动导的,除了有点不一样,数据库里的是blog_blogpost,可能是大小写敏感的问题。但是在本地时,却没有这样的问题,在syncdb的时候生成的表确实是以大写开头的,而本地数据库里的表则是小写开头,但在运行页面却毫无问题。

Google下发现据说MySQL在winodws下不区分表名大小写,但在linux下是区分的。

那怎么办呢,Django Documentation 有提到这方面的东西。

就是在生成数据表的时候,Django默认会结合你的app的名字以及model名来作为数据表名,而我的app名是Blog, 于是就出现了Blog_blogpost这个表名,但是改动app名显然比较麻烦。

其实只要在class Meta里设定db_table,就可以自定义表名,这样就无需去改动app的名字了。

比如像这个tag。

class Tag(models.Model):
	name = models.CharField(max_length=20)	
	
	class Meta: 
		ordering = ['name']	
		db_table = 'tag'
	
	def __unicode__(self):
		return self.name

转载于:https://my.oschina.net/zhudibrian/blog/132061

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值