zoukankan      html  css  js  c++  java
  • (16)模型层Models

    需求:通过orm创建user表

    先配置settings文件夹

    连接数据库和配置数据库

    Django的模块有两种

    1、mysqlDB  django内置的模块,只能在python2.X版本下用

    2、pymysql  python2.X和3.X下都能用,如果使用python3就只能用pymsql

    为了能用pymysql,需要在app下的__init__.py文件夹内做替换操作,可以是项目下的app,也可以是项目自身下的

    PS:一般情况写在app的目录下的__init__

    创建表:在models.py中写

    新建的表同步到数据库:

    有两部,第一步就是创建记录,第二部是同步记录,原理是根据记录来修改数据库

    1、python3 manage.py makemigrations  数据表变化的记录

    2、python3 manage.py migrate   同步数据记录

    PS:创建表的名字就是app_类名小写

    在表中增加字段:直接在

    models.py中的表名类下写即可

    PS:当再次执行创建记录的时候,会有一个提示

    1 就表示提供一个默认字段

    2 就是直接退出

    PS:要删除相关的字段直接注释掉,然后同步即可

    PS:要删除表只要把整个类注释,然后同步即可

    blank

    设置为True时,字段可以为空。设置为False时,字段是必须填写的。字符型字段CharField和TextField是用空字符串来存储空值的。

    null

    设置为True时,django用Null来存储空值。日期型、时间型和数字型字段不接受空字符串。所以设置IntegerField,DateTimeField型字段可以为空时,需要将blank,null均设为True。

    如果想设置BooleanField为空时可以选用NullBooleanField型字段。

    max_length

    为CharField型字段设置最大长度。

    choices

    由元素为2-tuples的序列(list或者tuple)作为字段的choices。2-tuple的第一个元素存储在数据库中,第二个元素可由get_FOO_display方法得到。

    >>>p=Person(name='Sam',gender=1)
    >>>p.save()
    >>>p.gender
    1
    >>>p.get_gender_display()
    u'Male'
    

    如果choices的选项过多的话,最好考虑使用ForiegnKey。

    default

    为字段设定默认值。

    默认值不能是一个可变对象(模型实例,列表,集合等),作为到同一个实例的参考,该对象将用作所有新的模型实例中的默认值。相反,在一个可调用的对象中封装所需的默认值。例如,如果你有一个自定义JSONField,并希望指定一个作为默认的字典,使用一个lambda表达式如下:

    contact_info = JSONField("ContactInfo", default=lambda:{"email": "to1@example.com"})

    verbose_name

    设置此字段在admin界面上的显示名称。

    unique

    设置为True,此字段在数据库中必须是唯一的。

    >>>p=Person(name='Sam',gender=1)
    >>>p.save()
    >>>p=Person(name='Sam',gender=2)
    >>>p.save()
    IntergrityError: column name is not unique

    primary_key

    如果设置为True,则此字段成为Model的主键。一般情况下,django会为Model自动添加一个叫id的IntegerField字段作为主键。

    AutoField(Field)
            - int自增列,必须填入参数 primary_key=True
        BigAutoField(AutoField)
            - bigint自增列,必须填入参数 primary_key=True
            注:当model中如果没有自增列,则自动会创建一个列名为id的列
            from django.db import models
            class UserInfo(models.Model):
                # 自动创建一个列名为id的且为自增的整数列
                username = models.CharField(max_length=32)
            class Group(models.Model):
                # 自定义自增列
                nid = models.AutoField(primary_key=True)
                name = models.CharField(max_length=32)
        SmallIntegerField(IntegerField):
            - 小整数 -32768 ~ 32767
        PositiveSmallIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField)
            - 正小整数 0 ~ 32767
        IntegerField(Field)
            - 整数列(有符号的) -2147483648 ~ 2147483647
        PositiveIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField)
            - 正整数 0 ~ 2147483647
        BigIntegerField(IntegerField):
            - 长整型(有符号的) -9223372036854775808 ~ 9223372036854775807
        BooleanField(Field)
            - 布尔值类型
        NullBooleanField(Field):
            - 可以为空的布尔值
        CharField(Field)
            - 字符类型
            - 必须提供max_length参数, max_length表示字符长度
        TextField(Field)
            - 文本类型
        EmailField(CharField):
            - 字符串类型,Django Admin以及ModelForm中提供验证机制
        IPAddressField(Field)
            - 字符串类型,Django Admin以及ModelForm中提供验证 IPV4 机制
        GenericIPAddressField(Field)
            - 字符串类型,Django Admin以及ModelForm中提供验证 Ipv4和Ipv6
            - 参数:
                protocol,用于指定Ipv4或Ipv6, 'both',"ipv4","ipv6"
                unpack_ipv4, 如果指定为True,则输入::ffff:192.0.2.1时候,可解析为192.0.2.1,开启刺功能,需要protocol="both"
        URLField(CharField)
            - 字符串类型,Django Admin以及ModelForm中提供验证 URL
        SlugField(CharField)
            - 字符串类型,Django Admin以及ModelForm中提供验证支持 字母、数字、下划线、连接符(减号)
        CommaSeparatedIntegerField(CharField)
            - 字符串类型,格式必须为逗号分割的数字
        UUIDField(Field)
            - 字符串类型,Django Admin以及ModelForm中提供对UUID格式的验证
        FilePathField(Field)
            - 字符串,Django Admin以及ModelForm中提供读取文件夹下文件的功能
            - 参数:
                    path,                      文件夹路径
                    match=None,                正则匹配
                    recursive=False,           递归下面的文件夹
                    allow_files=True,          允许文件
                    allow_folders=False,       允许文件夹
        FileField(Field)
            - 字符串,路径保存在数据库,文件上传到指定目录
            - 参数:
                upload_to = ""      上传文件的保存路径
                storage = None      存储组件,默认django.core.files.storage.FileSystemStorage
        ImageField(FileField)
            - 字符串,路径保存在数据库,文件上传到指定目录
            - 参数:
                upload_to = ""      上传文件的保存路径
                storage = None      存储组件,默认django.core.files.storage.FileSystemStorage
                width_field=None,   上传图片的高度保存的数据库字段名(字符串)
                height_field=None   上传图片的宽度保存的数据库字段名(字符串)
        DateTimeField(DateField)
            - 日期+时间格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ]
        DateField(DateTimeCheckMixin, Field)
            - 日期格式      YYYY-MM-DD
        TimeField(DateTimeCheckMixin, Field)
            - 时间格式      HH:MM[:ss[.uuuuuu]]
        DurationField(Field)
            - 长整数,时间间隔,数据库中按照bigint存储,ORM中获取的值为datetime.timedelta类型
        FloatField(Field)
            - 浮点型
        DecimalField(Field)
            - 10进制小数
            - 参数:
                max_digits,小数总长度
                decimal_places,小数位长度
        BinaryField(Field)
            - 二进制类型
     

    字段的参数

        null                数据库中字段是否可以为空
        db_column           数据库中字段的列名
        db_tablespace
        default             数据库中字段的默认值
        primary_key         数据库中字段是否为主键
        db_index            数据库中字段是否可以建立索引
        unique              数据库中字段是否可以建立唯一索引
        unique_for_date     数据库中字段【日期】部分是否可以建立唯一索引
        unique_for_month    数据库中字段【月】部分是否可以建立唯一索引
        unique_for_year     数据库中字段【年】部分是否可以建立唯一索引
        verbose_name        Admin中显示的字段名称
        blank               Admin中是否允许用户输入为空
        editable            Admin中是否可以编辑
        help_text           Admin中该字段的提示信息
        choices             Admin中显示选择框的内容,用不变动的数据放在内存中从而避免跨表操作
                            如:gf = models.IntegerField(choices=[(0, '何穗'),(1, '大表姐'),],default=1)
        error_messages      自定义错误信息(字典类型),从而定制想要显示的错误信息;
                            字典健:null, blank, invalid, invalid_choice, unique, and unique_for_date
                            如:{'null': "不能为空.", 'invalid': '格式错误'}
        validators          自定义错误验证(列表类型),从而定制想要的验证规则
                            from django.core.validators import RegexValidator
                            from django.core.validators import EmailValidator,URLValidator,DecimalValidator,
                            MaxLengthValidator,MinLengthValidator,MaxValueValidator,MinValueValidator
                            如:
                                test = models.CharField(
                                    max_length=32,
                                    error_messages={
                                        'c1': '优先错信息1',
                                        'c2': '优先错信息2',
                                        'c3': '优先错信息3',
                                    },
                                    validators=[
                                        RegexValidator(regex='root_d+', message='错误了', code='c1'),
                                        RegexValidator(regex='root_112233d+', message='又错误了', code='c2'),
                                        EmailValidator(message='又错误了', code='c3'), ]
                                )
  • 相关阅读:
    Linux学习50 进程优先级、网络客户端工具、shell循环(续Linux学习49)
    Linux学习51 CentOS系统启动流程介绍
    Linux学习49 资源管理三板斧-htop、vmstat、dstat实战
    【Kafka】CAP理论以及CAP定律
    【Kafka】Flume整合Kafka
    【Kafka】配置文件说明
    【Kafka】JavaAPI操作
    【Kafka】Stream API
    【Kafka】Consumer API
    【Kafka】Producer API
  • 原文地址:https://www.cnblogs.com/shizhengquan/p/10516775.html
Copyright © 2011-2022 走看看