Django

Posted dontgiveup

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django相关的知识,希望对你有一定的参考价值。

Python的WEB框架有Django、Tornado、Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM、模型绑定、模板引擎、缓存、Session等诸多功能。

 

基本配置

 

一、创建django程序

  • 终端命令:django-admin startproject sitename
  • IDE创建Django程序时,本质上都是自动执行上述命令

其他常用命令:

  python manage.py runserver 0.0.0.0  //运行服务
  python manage.py startapp appname  //创建app实例
  python manage.py syncdb      // 会创建在settings 下的INSTALL_APPS所有app,创建其对应的数据表到指定的数据库,但只创建 不存在的表
  python manage.py makemigrations  //在migrations文件夹创建对应的表数据,但没有在数据库中创建相应数据。
  python manage.py migrate      //将migrations文件夹创建的表数据迁移到数据库并创建相应字段等。

  python manage.py createsuperuser  //创建admin用户

 

配置数据库:

 

DATABASES = {
    ‘default‘: {
    ‘ENGINE‘: ‘django.db.backends.mysql,
    ‘NAME‘:‘dbname‘,
    ‘USER‘: ‘root‘,
    ‘PASSWORD‘: ‘xxx‘,
    ‘HOST‘: ‘‘,
    ‘PORT‘: ‘‘,
    }
}
 
模板:
TEMPLATE_DIRS = (
        os.path.join(BASE_DIR,‘templates‘),
    )
 
静态文件:
STATICFILES_DIRS = (
        os.path.join(BASE_DIR,‘static‘),
    )

 

路由系统

1、单一路由对应

  url(r‘^index$‘, views.index),

 

2、基于正则的路由

  url(r‘^index/(d*)‘, views.index),
  url(r‘^manage/(?P<name>w*)/(?P<id>d*)‘, views.manage),
 
3、添加额外的参数
  url(r‘^manage/(?P<name>w*)‘, views.manage,{‘id‘:333}),
 
4、为路由映射设置名称
  url(r‘^home‘, views.home, name=‘h1‘),
  url(r‘^index/(d*)‘, views.index, name=‘h2‘),
 
5、根据app对路由规则进行分类
  url(r‘^web/‘,include(‘web.urls‘)),
 
6、命名空间
  a. project.urls.py    
    from django.conf.urls import url,include
 
    urlpatterns = [
        url(r‘^a/‘, include(‘app01.urls‘, namespace=‘author-polls‘)),
        url(r‘^b/‘, include(‘app01.urls‘, namespace=‘publisher-polls‘)),
    ]
b. app01.urls.py
  from django.conf.urls import url
  from app01 import views
 
  app_name = ‘app01‘
  urlpatterns = [
      url(r‘^(?P<pk>d+)/$‘, views.detail, name=‘detail‘)
  ]
 
c. app01.views.py
  def detail(request, pk):
    print(request.resolver_match)
    return HttpResponse(pk)
 

以上定义带命名空间的url之后,使用name生成URL时候,应该如下:

  • v = reverse(‘app01:detail‘, kwargs={‘pk‘:11})
  • {% url ‘app01:detail‘ pk=12 pp=99 %}

django中的路由系统和其他语言的框架有所不同,在django中每一个请求的url都要有一条路由映射,这样才能将请求交给对一个的view中的函数去处理。其他大部分的Web框架则是对一类的url请求做一条路由映射,从而是路由系统变得简洁。

自定义simple_tag

a、在app中创建templatetags模块

b、创建任意 .py 文件,如:xx.py

技术分享图片
 1 #!/usr/bin/env python
 2 #coding:utf-8
 3 from django import template
 4 from django.utils.safestring import mark_safe
 5    
 6 register = template.Library()
 7    
 8 @register.simple_tag
 9 def my_simple_time(v1,v2,v3):
10     return  v1 + v2 + v3
11    
12 @register.simple_tag
13 def my_input(id,arg):
14     result = "<input type=‘text‘ id=‘%s‘ class=‘%s‘ />" %(id,arg,)
15     return mark_safe(result)
View Code

c、在使用自定义simple_tag的html文件中导入之前创建的 xx.py 文件名

  {% load xx %}
d、使用simple_tag
  {% my_simple_time 1 2 3%}
  {% my_input ‘id_username‘ ‘hide‘%}
 
e、在settings中配置当前app,不然django无法找到自定义的simple_tag
 

中间件

django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法。

在django项目的settings模块中,有一个 MIDDLEWARE_CLASSES 变量,其中每一个元素就是一个中间件,如下图。

技术分享图片

与mange.py在同一目录下的文件夹 wupeiqi/middleware下的auth.py文件中的Authentication类

中间件中可以定义四个方法,分别是:

  • process_request(self,request)
  • process_view(self, request, callback, callback_args, callback_kwargs)
  • process_template_response(self,request,response)
  • process_exception(self, request, exception)
  • process_response(self, request, response)

以上方法的返回值可以是None和HttpResonse对象,如果是None,则继续按照django定义的规则向下执行,如果是HttpResonse对象,则直接将该对象返回给用户。

技术分享图片

自定义中间件

1、创建中间件类

class RequestExeute(object):
      
    def process_request(self,request):
        pass
    def process_view(self, request, callback, callback_args, callback_kwargs):
        i =1
        pass
    def process_exception(self, request, exception):
        pass
      
    def process_response(self, request, response):
        return response
2、注册中间件
MIDDLEWARE_CLASSES = (
    ‘django.contrib.sessions.middleware.SessionMiddleware‘,
    ‘django.middleware.common.CommonMiddleware‘,
    ‘django.middleware.csrf.CsrfViewMiddleware‘,
    ‘django.contrib.auth.middleware.AuthenticationMiddleware‘,
    ‘django.contrib.auth.middleware.SessionAuthenticationMiddleware‘,
    ‘django.contrib.messages.middleware.MessageMiddleware‘,
    ‘django.middleware.clickjacking.XFrameOptionsMiddleware‘,
    ‘wupeiqi.middleware.auth.RequestExeute‘,
)
 

admin

  • 配置url
  • 注册和配置django admin后台管理页面

1、创建后台管理员

1
python manage.py createsuperuser

2、配置后台管理url

1
url(r‘^admin/‘, include(admin.site.urls))

3、注册和配置django admin 后台管理页面

a、在admin中执行如下配置

 

from django.contrib import admin
  
from app01 import  models
  
admin.site.register(models.UserType)
admin.site.register(models.UserInfo)
admin.site.register(models.UserGroup)
admin.site.register(models.Asset)
 
b、设置数据表名称
class UserType(models.Model):
    name = models.CharField(max_length=50)
  
    class Meta:
        verbose_name = ‘用户类型‘
        verbose_name_plural = ‘用户类型‘
 
c、打开表之后,设定默认显示,需要在model中作如下配置
class UserType(models.Model):
    name = models.CharField(max_length=50)
  
    def __unicode__(self):
        return self.name
 
---------------
from django.contrib import admin
  
from app01 import  models
  
class UserInfoAdmin(admin.ModelAdmin):
    list_display = (‘username‘, ‘password‘, ‘email‘)
  
  
admin.site.register(models.UserType)
admin.site.register(models.UserInfo,UserInfoAdmin)
admin.site.register(models.UserGroup)
admin.site.register(models.Asset)
 
d、为数据表添加搜索功能  
技术分享图片
 1 from django.contrib import admin
 2   
 3 from app01 import  models
 4   
 5 class UserInfoAdmin(admin.ModelAdmin):
 6     list_display = (username, password, email)
 7     search_fields = (username, email)
 8   
 9 admin.site.register(models.UserType)
10 admin.site.register(models.UserInfo,UserInfoAdmin)
11 admin.site.register(models.UserGroup)
12 admin.site.register(models.Asset)
View Code

e、添加快速过滤

技术分享图片
 1 from django.contrib import admin
 2   
 3 from app01 import  models
 4   
 5 class UserInfoAdmin(admin.ModelAdmin):
 6     list_display = (username, password, email)
 7     search_fields = (username, email)
 8     list_filter = (username, email)
 9       
10   
11   
12 admin.site.register(models.UserType)
13 admin.site.register(models.UserInfo,UserInfoAdmin)
14 admin.site.register(models.UserGroup)
15 admin.site.register(models.Asset)
View Code

 

 

Model

到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞:

  • 创建数据库,设计表结构和字段
  • 使用 MySQLdb 来连接数据库,并编写数据访问层代码
  • 业务逻辑层去调用数据访问层执行数据库操作
  • 技术分享图片
     1 import MySQLdb
     2  
     3 def GetList(sql):
     4     db = MySQLdb.connect(user=root, db=wupeiqidb, passwd=1234, host=localhost)
     5     cursor = db.cursor()
     6     cursor.execute(sql)
     7     data = cursor.fetchall()
     8     db.close()
     9     return data
    10  
    11 def GetSingle(sql):
    12     db = MySQLdb.connect(user=root, db=wupeiqidb, passwd=1234, host=localhost)
    13     cursor = db.cursor()
    14     cursor.execute(sql)
    15     data = cursor.fetchone()
    16     db.close()
    17     return data
    View Code

django为使用一种新的方式,即:关系对象映射(Object Relational Mapping,简称ORM)。

  php:activerecord

  Java:Hibernate 

    C#:Entity Framework

django中遵循 Code Frist 的原则,即:根据代码中定义的类来自动生成数据库表。

 

一、创建表

1、基本结构

  

1 from django.db import models
2    
3 class userinfo(models.Model):
4     name = models.CharField(max_length=30)
5     email = models.EmailField()
6     memo = models.TextField()
技术分享图片
  1 AutoField(Field)
  2         - int自增列,必须填入参数 primary_key=True
  3 
  4     BigAutoField(AutoField)
  5         - bigint自增列,必须填入参数 primary_key=True
  6 
  7         注:当model中如果没有自增列,则自动会创建一个列名为id的列
  8         from django.db import models
  9 
 10         class UserInfo(models.Model):
 11             # 自动创建一个列名为id的且为自增的整数列
 12             username = models.CharField(max_length=32)
 13 
 14         class Group(models.Model):
 15             # 自定义自增列
 16             nid = models.AutoField(primary_key=True)
 17             name = models.CharField(max_length=32)
 18 
 19     SmallIntegerField(IntegerField):
 20         - 小整数 -32768 ~ 32767
 21 
 22     PositiveSmallIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField)
 23         - 正小整数 0 ~ 32767
 24     IntegerField(Field)
 25         - 整数列(有符号的) -2147483648 ~ 2147483647
 26 
 27     PositiveIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField)
 28         - 正整数 0 ~ 2147483647
 29 
 30     BigIntegerField(IntegerField):
 31         - 长整型(有符号的) -9223372036854775808 ~ 9223372036854775807
 32 
 33     自定义无符号整数字段
 34 
 35         class UnsignedIntegerField(models.IntegerField):
 36             def db_type(self, connection):
 37                 return integer UNSIGNED
 38 
 39         PS: 返回值为字段在数据库中的属性,Django字段默认的值为:
 40             AutoField: integer AUTO_INCREMENT,
 41             BigAutoField: bigint AUTO_INCREMENT,
 42             BinaryField: longblob,
 43             BooleanField: bool,
 44             CharField: varchar(%(max_length)s),
 45             CommaSeparatedIntegerField: varchar(%(max_length)s),
 46             DateField: date,
 47             DateTimeField: datetime,
 48             DecimalField: numeric(%(max_digits)s, %(decimal_places)s),
 49             DurationField: bigint,
 50             FileField: varchar(%(max_length)s),
 51             FilePathField: varchar(%(max_length)s),
 52             FloatField: double precision,
 53             IntegerField: integer,
 54             BigIntegerField: bigint,
 55             IPAddressField: char(15),
 56             GenericIPAddressField: char(39),
 57             NullBooleanField: bool,
 58             OneToOneField: integer,
 59             PositiveIntegerField: integer UNSIGNED,
 60             PositiveSmallIntegerField: smallint UNSIGNED,
 61             SlugField: varchar(%(max_length)s),
 62             SmallIntegerField: smallint,
 63             TextField: longtext,
 64             TimeField: time,
 65             UUIDField: char(32),
 66 
 67     BooleanField(Field)
 68         - 布尔值类型
 69 
 70     NullBooleanField(Field):
 71         - 可以为空的布尔值
 72 
 73     CharField(Field)
 74         - 字符类型
 75         - 必须提供max_length参数, max_length表示字符长度
 76 
 77     TextField(Field)
 78         - 文本类型
 79 
 80     EmailField(CharField):
 81         - 字符串类型,Django Admin以及ModelForm中提供验证机制
 82 
 83     IPAddressField(Field)
 84         - 字符串类型,Django Admin以及ModelForm中提供验证 IPV4 机制
 85 
 86     GenericIPAddressField(Field)
 87         - 字符串类型,Django Admin以及ModelForm中提供验证 Ipv4和Ipv6
 88         - 参数:
 89             protocol,用于指定Ipv4或Ipv6, both,"ipv4","ipv6"
 90             unpack_ipv4, 如果指定为True,则输入::ffff:192.0.2.1时候,可解析为192.0.2.1,开启刺功能,需要protocol="both"
 91 
 92     URLField(CharField)
 93         - 字符串类型,Django Admin以及ModelForm中提供验证 URL
 94 
 95     SlugField(CharField)
 96         - 字符串类型,Django Admin以及ModelForm中提供验证支持 字母、数字、下划线、连接符(减号)
 97 
 98     CommaSeparatedIntegerField(CharField)
 99         - 字符串类型,格式必须为逗号分割的数字
100 
101     UUIDField(Field)
102         - 字符串类型,Django Admin以及ModelForm中提供对UUID格式的验证
103 
104     FilePathField(Field)
105         - 字符串,Django Admin以及ModelForm中提供读取文件夹下文件的功能
106         - 参数:
107                 path,                      文件夹路径
108                 match=None,                正则匹配
109                 recursive=False,           递归下面的文件夹
110                 allow_files=True,          允许文件
111                 allow_folders=False,       允许文件夹
112 
113     FileField(Field)
114         - 字符串,路径保存在数据库,文件上传到指定目录
115         - 参数:
116             upload_to = ""      上传文件的保存路径
117             storage = None      存储组件,默认django.core.files.storage.FileSystemStorage
118 
119     ImageField(FileField)
120         - 字符串,路径保存在数据库,文件上传到指定目录
121         - 参数:
122             upload_to = ""      上传文件的保存路径
123             storage = None      存储组件,默认django.core.files.storage.FileSystemStorage
124             width_field=None,   上传图片的高度保存的数据库字段名(字符串)
125             height_field=None   上传图片的宽度保存的数据库字段名(字符串)
126 
127     DateTimeField(DateField)
128         - 日期+时间格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ]
129 
130     DateField(DateTimeCheckMixin, Field)
131         - 日期格式      YYYY-MM-DD
132 
133     TimeField(DateTimeCheckMixin, Field)
134         - 时间格式      HH:MM[:ss[.uuuuuu]]
135 
136     DurationField(Field)
137         - 长整数,时间间隔,数据库中按照bigint存储,ORM中获取的值为datetime.timedelta类型
138 
139     FloatField(Field)
140         - 浮点型
141 
142     DecimalField(Field)
143         - 10进制小数
144         - 参数:
145             max_digits,小数总长度
146             decimal_places,小数位长度
147 
148     BinaryField(Field)
149         - 二进制类型
150 
151 字段
字段
技术分享图片
 1 null                数据库中字段是否可以为空
 2     db_column           数据库中字段的列名
 3     db_tablespace
 4     default             数据库中字段的默认值
 5     primary_key         数据库中字段是否为主键
 6     db_index            数据库中字段是否可以建立索引
 7     unique              数据库中字段是否可以建立唯一索引
 8     unique_for_date     数据库中字段【日期】部分是否可以建立唯一索引
 9     unique_for_month    数据库中字段【月】部分是否可以建立唯一索引
10     unique_for_year     数据库中字段【年】部分是否可以建立唯一索引
11 
12     verbose_name        Admin中显示的字段名称
13     blank               Admin中是否允许用户输入为空
14     editable            Admin中是否可以编辑
15     help_text           Admin中该字段的提示信息
16     choices             Admin中显示选择框的内容,用不变动的数据放在内存中从而避免跨表操作
17                         如:gf = models.IntegerField(choices=[(0, 何穗),(1, 大表姐),],default=1)
18 
19     error_messages      自定义错误信息(字典类型),从而定制想要显示的错误信息;
20                         字典健:null, blank, invalid, invalid_choice, unique, and unique_for_date
21                         如:{null: "不能为空.", invalid: 格式错误}
22 
23     validators          自定义错误验证(列表类型),从而定制想要的验证规则
24                         from django.core.validators import RegexValidator
25                         from django.core.validators import EmailValidator,URLValidator,DecimalValidator,26                         MaxLengthValidator,MinLengthValidator,MaxValueValidator,MinValueValidator
27                         如:
28                             test = models.CharField(
29                                 max_length=32,
30                                 error_messages={
31                                     c1: 优先错信息1,
32                                     c2: 优先错信息2,
33                                     c3: 优先错信息3,
34                                 },
35                                 validators=[
36                                     RegexValidator(regex=root_d+, message=错误了, code=c1),
37                                     RegexValidator(regex=root_112233d+, message=又错误了, code=c2),
38                                     EmailValidator(message=又错误了, code=c3), ]
39                             )
40 
41 参数
参数
技术分享图片
 1 class UserInfo(models.Model):
 2         nid = models.AutoField(primary_key=True)
 3         username = models.CharField(max_length=32)
 4         class Meta:
 5             # 数据库中生成的表名称 默认 app名称 + 下划线 + 类名
 6             db_table = "table_name"
 7 
 8             # 联合索引
 9             index_together = [
10                 ("pub_date", "deadline"),
11             ]
12 
13             # 联合唯一索引
14             unique_together = (("driver", "restaurant"),)
15 
16             # admin中显示的表名称
17             verbose_name
18 
19             # verbose_name加s
20             verbose_name_plural
21         
22     更多:https://docs.djangoproject.com/en/1.10/ref/models/options/
23 
24 元信息
元信息
技术分享图片
 1 1.触发Model中的验证和错误提示有两种方式:
 2         a. Django Admin中的错误信息会优先根据Admiin内部的ModelForm错误信息提示,如果都成功,才来检查Model的字段并显示指定错误信息
 3         b. 调用Model对象的 clean_fields 方法,如:
 4             # models.py
 5             class UserInfo(models.Model):
 6                 nid = models.AutoField(primary_key=True)
 7                 username = models.CharField(max_length=32)
 8 
 9                 email = models.EmailField(error_messages={invalid: 格式错了.})
10 
11             # views.py
12             def index(request):
13                 obj = models.UserInfo(username=11234, email=uu)
14                 try:
15                     print(obj.clean_fields())
16                 except Exception as e:
17                     print(e)
18                 return HttpResponse(ok)
19 
20            # Model的clean方法是一个钩子,可用于定制操作,如:上述的异常处理。
21 
22     2.Admin中修改错误提示
23         # admin.py
24         from django.contrib import admin
25         from model_club import models
26         from django import forms
27 
28 
29         class UserInfoForm(forms.ModelForm):
30             username = forms.CharField(error_messages={required: 用户名不能为空.})
31             email = forms.EmailField(error_messages={invalid: 邮箱格式错误.})
32             age = forms.IntegerField(initial=1, error_messages={required: 请输入数值., invalid: 年龄必须为数值.})
33 
34             class Meta:
35                 model = models.UserInfo
36                 # fields = (‘username‘,)
37                 fields = "__all__"
38 
39 
40         class UserInfoAdmin(admin.ModelAdmin):
41             form = UserInfoForm
42 
43 
44         admin.site.register(models.UserInfo, UserInfoAdmin)
45 
46 拓展知识
拓展

 

表操作:

技术分享图片
 1 #
 2     #
 3     # models.Tb1.objects.create(c1=‘xx‘, c2=‘oo‘)  增加一条数据,可以接受字典类型数据 **kwargs
 4 
 5     # obj = models.Tb1(c1=‘xx‘, c2=‘oo‘)
 6     # obj.save()
 7 
 8     #
 9     #
10     # models.Tb1.objects.get(id=123)         # 获取单条数据,不存在则报错(不建议)
11     # models.Tb1.objects.all()               # 获取全部
12     # models.Tb1.objects.filter(name=‘seven‘) # 获取指定条件的数据
13 
14     #
15     #
16     # models.Tb1.objects.filter(name=‘seven‘).delete() # 删除指定条件的数据
17 
18     #
19     # models.Tb1.objects.filter(name=‘seven‘).update(gender=‘0‘)  # 将指定条件的数据更新,均支持 **kwargs
20     # obj = models.Tb1.objects.get(id=1)
21     # obj.c1 = ‘111‘
22     # obj.save()                                                 # 修改单条数据
23 
24 基本操作
View Code

进阶操作(了不起的双下划线)

利用双下划线将字段和对应的操作连接起来

技术分享图片
# 获取个数
        #
        # models.Tb1.objects.filter(name=‘seven‘).count()

        # 大于,小于
        #
        # models.Tb1.objects.filter(id__gt=1)              # 获取id大于1的值
        # models.Tb1.objects.filter(id__gte=1)              # 获取id大于等于1的值
        # models.Tb1.objects.filter(id__lt=10)             # 获取id小于10的值
        # models.Tb1.objects.filter(id__lte=10)             # 获取id小于10的值
        # models.Tb1.objects.filter(id__lt=10, id__gt=1)   # 获取id大于1 且 小于10的值

        # in
        #
        # models.Tb1.objects.filter(id__in=[11, 22, 33])   # 获取id等于11、22、33的数据
        # models.Tb1.objects.exclude(id__in=[11, 22, 33])  # not in

        # isnull
        # Entry.objects.filter(pub_date__isnull=True)

        # contains
        #
        # models.Tb1.objects.filter(name__contains="ven")
        # models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
        # models.Tb1.objects.exclude(name__icontains="ven")

        # range
        #
        # models.Tb1.objects.filter(id__range=[1, 2])   # 范围bettwen and

        # 其他类似
        #
        # startswith,istartswith, endswith, iendswith,

        # order by
        #
        # models.Tb1.objects.filter(name=‘seven‘).order_by(‘id‘)    # asc
        # models.Tb1.objects.filter(name=‘seven‘).order_by(‘-id‘)   # desc

        # group by
        #
        # from django.db.models import Count, Min, Max, Sum
        # models.Tb1.objects.filter(c1=1).values(‘id‘).annotate(c=Count(‘num‘))
        # SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" = 1 GROUP BY "app01_tb1"."id"

        # limit 、offset
        #
        # models.Tb1.objects.all()[10:20]

        # regex正则匹配,iregex 不区分大小写
        #
        # Entry.objects.get(title__regex=r‘^(An?|The) +‘)
        # Entry.objects.get(title__iregex=r‘^(an?|the) +‘)

        # date
        #
        # Entry.objects.filter(pub_date__date=datetime.date(2005, 1, 1))
        # Entry.objects.filter(pub_date__date__gt=datetime.date(2005, 1, 1))

        # year
        #
        # Entry.objects.filter(pub_date__year=2005)
        # Entry.objects.filter(pub_date__year__gte=2005)

        # month
        #
        # Entry.objects.filter(pub_date__month=12)
        # Entry.objects.filter(pub_date__month__gte=6)

        # day
        #
        # Entry.objects.filter(pub_date__day=3)
        # Entry.objects.filter(pub_date__day__gte=3)

        # week_day
        #
        # Entry.objects.filter(pub_date__week_day=2)
        # Entry.objects.filter(pub_date__week_day__gte=2)

        # hour
        #
        # Event.objects.filter(timestamp__hour=23)
        # Event.objects.filter(time__hour=5)
        # Event.objects.filter(timestamp__hour__gte=12)

        # minute
        #
        # Event.objects.filter(timestamp__minute=29)
        # Event.objects.filter(time__minute=46)
        # Event.objects.filter(timestamp__minute__gte=29)

        # second
        #
        # Event.objects.filter(timestamp__second=31)
        # Event.objects.filter(time__second=2)
        # Event.objects.filter(timestamp__second__gte=31)

进阶操作
View Code

连表操作(了不起的双下划线)

利用双下划线和 _set 将表之间的操作连接起来

技术分享图片
 1 class UserProfile(models.Model):
 2     user_info = models.OneToOneField(UserInfo)
 3     username = models.CharField(max_length=64)
 4     password = models.CharField(max_length=64)
 5 
 6     def __unicode__(self):
 7         return self.username
 8 
 9 
10 class UserInfo(models.Model):
11     user_type_choice = (
12         (0, u普通用户),
13         (1, u高级用户),
14     )
15     user_type = models.IntegerField(choices=user_type_choice)
16     name = models.CharField(max_length=32)
17     email = models.CharField(max_length=32)
18     address = models.CharField(max_length=128)
19 
20     def __unicode__(self):
21         return self.name
22 
23 
24 class UserGroup(models.Model):
25 
26     caption = models.CharField(max_length=64)
27 
28     user_info = models.ManyToManyField(UserInfo)
29 
30     def __unicode__(self):
31         return self.caption
32 
33 
34 class Host(models.Model):
35     hostname = models.CharField(max_length=64)
36     ip = models.GenericIPAddressField()
37     user_group = models.ForeignKey(UserGroup)
38 
39     def __unicode__(self):
40         return self.hostname
41 
42 表结构实例
View Code

 

参考:

https://www.cnblogs.com/wupeiqi/articles/5237704.html

 





以上是关于Django的主要内容,如果未能解决你的问题,请参考以下文章

django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_TABLESPACE的解决办法(转)(代码片段

Django REST框架--认证和权限

如何在 Django 中显式重置模板片段缓存?

使用 Django 模板作为片段

python 通过django片段很多很多

JavaScript 片段在 Django 模板中不起作用