详细内容请参考这里 Django框架教程(非常细)
Django 提供了ORM功能,我们可以直接在model中定义数据库表字段,然后通过python命令来帮助我们创建数据库表和对应的字段,这个过程就叫应用数据库迁移。例如我在model下创建了如下的内容;
class Book(models.Model): # 创建 book 表
title = models.CharField(max_length=30, unique=True, verbose_name='书名')
public = models.CharField(max_length=50, verbose_name='出版社')
price = models.DecimalField(max_digits=7, decimal_places=2, verbose_name='定价')
retail_price = models.DecimalField(max_digits=7, decimal_places=2, verbose_name='零售价', default='¥30')
def __str__(self):
return "title:%s pub:%s price:%s" % (self.title, self.public, self.price)
class Author(models.Model): # 创建作者表
name = models.CharField(max_length=30, verbose_name='姓名')
email = models.EmailField(verbose_name='邮箱')
def __str__(self):
return '作者:%s' % (self.name)
class UserInfo(models.Model): # 创建用户信息表
username = models.CharField(max_length=24, verbose_name='用户注册')
password = models.CharField(max_length=24, verbose_name='密码')
执行迁移的命令如下:
python manage.py makemigrations
和
python manage.py migrate
但是执行第一行的时候发现一直提示:No changes detected
导致这个问题的原因有多个,根据各类材料总结应该满足以下几项:
创建的app为index,要将其添加到配置文件里,也就是这样子:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'index',
]
然后运行的时候可以指定app名称,也就是这样:python manage.py makemigrations index
然后再执行python manage.py migrate就可以了,此时创建的数据表都加了index前缀,也就是index_author,index_book这样子,但是至少能work了。