一丶模型是什么

模型(model)是唯一个确定数据库源头数据的类,它储存数据必要字段和行为,通常一个模型(model)单一映射到一张数据库的表.
1.每个模型都是一个python类,它们都是django.db.models.Model的子类.
2.每一个模型的属性代表数据库中的一个字段.
3.通过模型,Django为你提供一个方便的数据库访问API.

有如下特点:

1.Django遵循DRY原理.本质是通过滚动模型流来更新数据
2.每个models用python的类来表示数据表(数据表)
3.每个models变量代表一个数据库字段(数据库字段)
4.每个字段的实例表示一个数据(即数据库的数据)
5.实例名称是字段名称(即数据库列名)
6.类中加入__str__()自动进行交互

二丶创建模型

0.创建一个数据库,对应models.py(模型文件对应一个数据库)
1.从django.db包中导入models类
from django.db import models
2.创建类继承models.Model(每个类单独对应一张表)(数据库中的表)
class Person(models.Model):
3.创建模型的属性(每个属性代表数据库中的一个字段)(数据库中的列)
first_name = models.CharField(max_length=30)
last_name = models.CharField(max_length=30)

完整代码:
from django.db import models class Person(models.Model): first_name = models.CharField(max_length=30) last_name = models.CharField(max_length=30)

等同于表:

CREATE TABLE myapp_person (
"id" serial NOT NULL PRIMARY KEY,
"first_name" varchar(30) NOT NULL,
"last_name" varchar(30) NOT NULL
);

创建字段:

from django.db import models

class Musician(models.Model):
    first_name = models.CharField(max_length=50)
    last_name = models.CharField(max_length=50)
    instrument = models.CharField(max_length=100)

class Album(models.Model):
    artist = models.ForeignKey(Musician, on_delete=models.CASCADE)
    name = models.CharField(max_length=100)
    release_date = models.DateField()
    num_stars = models.IntegerField()

字段有字段类型字段选项.

1.字段类型确定三件事情:

第一件,告诉数据库储存什么样的数据类型,例如:VARCHAR,TEXT

第二件,定义默认使用的HTML窗口部件(widget)

第三件,在管理员(admin)和自动生成的表单()forms)中提供最基本的验证字段功能,

内置字段没有达到理想效果的话,能够通过自定义字段来实现心中最理想的字段类型.

2.字段选项:每一个字段都接受一组特殊的参数来定制字段行为.

从技术上说,模型(models)定义与 django.db.models.fields,单位了方便用django.db.models也可以,公认惯例:

导入:from django.db import models

引用:modelsmodels.<Foo>Field

三丶使用模型

1.在设置中导入app(应用)

项目settings.py文件下
INSTALLED_APPS = [
#...
'myapp',等同于'myapp.apps.MyappConfig'(推荐后者),
#...
]

2.迁移数据库

1.生成迁移文件
manage.py makemigrations
2.将迁移文件注入数据库
manage.py migrate
posted on 2018-07-12 18:44  仓鼠大人爱吃肉  阅读(182)  评论(0编辑  收藏  举报