最近想把写了一部分的博客部署到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