前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Django源码学习-3-Model-中

Django源码学习-3-Model-中

作者头像
小团子
发布2019-07-30 15:17:09
6920
发布2019-07-30 15:17:09
举报
文章被收录于专栏:数据云团数据云团

Django源码学习-3-Model-上

Django网络应用开发的5项基础核心技术包括模型(Model)的设计,URL 的设计与配置,View(视图)的编写,Template(模板)的设计和Form(表单)的使用。

在上一篇中介绍到 models 的字段类型,会发现 Django 要生成数据库的表字段,只需要在 Django 项目的 app 应用的 models.py 文件中编写需要的数据表字段,便可以在数据库中生成数据库表。

在 linux 虚拟机的终端中找到 Django 项目路径下的 manage.py 文件,进入 Python 环境,输入 python manage.py shell,便可以查看 models 的源码。

代码语言:javascript
复制
>>>python manage.py shell
>>> from django.db import models
>>> help(models)

参数类型

代码语言:javascript
复制
1、null=True 数据库中字段是否可以为空
代码语言:javascript
复制
2、blank=True django的Admin中添加数据时是否可允许空值
代码语言:javascript
复制
主键,对AutoField设置主键后,就会代替原来默认的自增id列
3、primary_key=False 
代码语言:javascript
复制
4、auto_now和auto_now_add
  auto_now  自动创建---无论添加或修改,都是当前操作的时间
  auto_now_add  自动创建---永远是创建时的时间
代码语言:javascript
复制
5、choices
     GENDER_CHOICE = (
          (u'M', u'Male'),
          (u'F', u'Female'),
      )
     gender = models.CharField(max_length=2,choices=GENDER_CHOICE)
代码语言:javascript
复制
6、max_length 最大长度
代码语言:javascript
复制
7、default  默认值
代码语言:javascript
复制
8、verbose_name  Admin中字段的显示名称
代码语言:javascript
复制
9、name|db_column 数据库中的字段名称
代码语言:javascript
复制
10、unique=True  不允许重复
代码语言:javascript
复制
11、db_index = True  数据库索引
代码语言:javascript
复制
12、editable=True  在Admin里是否可编辑
代码语言:javascript
复制
13、error_messages=None  错误提示
代码语言:javascript
复制
14、auto_created=False  自动创建
代码语言:javascript
复制
15、help_text  在Admin中提示帮助信息
代码语言:javascript
复制
16、validators=[]  验证
代码语言:javascript
复制
17、upload-to  文件上传路径
代码语言:javascript
复制
from django.db import models
代码语言:javascript
复制
class UserInfo(models.Model):
    name = models.CharField(max_length=32)
    ctime = models.DateTimeField(auto_now=True) #每当创建一行数据时,Django就会在该行数据中增加一个ctime字段
    uptime = models.DateTimeField(auto_now_add=True) #当前表任何一行数据有更新时,Django就会自动更新该字段.
    #下面两项是新增的字段,注意新增时参数的设置,否则在命令行创建数据库时报错,null=True表示在数据库中该字段可以为空,default='xxx'表示默认值
     email_1 = models.EmailField(max_length=32,null=True)
    email_2 = models.EmailField(max_length=32,default='aaa@qq.com')
    #新增字段,blank=True表示admin后台可以为空
     ip = models.GenericIPAddressField(protocol='ipv4',null=True,blank=True)
    #upload_to='upload'表示用户上传数据存储的位置,这里需要注意:在数据库中实际保存的并不是文件,而是文件存放的路径
    img = models.ImageField(null=True,blank=True,upload_to='upload')
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-07-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 数据云团 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档