• Django中的Model(字段)


    Model

    Django中的model是用来操作数据库的,Model是一个ORM框架,我们只需要关心model的操作,而不需要关心到底是哪一种数据库。

    一、基本知识:

    数据库引擎:

    Django中自带的数据库为sqlite,如果需要修改数据库引擎,可以再settings.py中修改:

    1 DATABASES = {
    2     'default': {
    3         'ENGINE': 'django.db.backends.sqlite3',
    4         'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    5     }
    6 }

    使用方法:

     我们只需要在models.py文件中写入代码即可:

    表结构对照图:

    ORM框架中,类class表示数据库的表
    根据类创建的对象,代表数据库表中的一行数据。
    对象.id 对象.value 代表行里面的数据

    二、model里的字段

    1、models.AutoField  自增列 = int(11)
      如果没有的话,默认会生成一个名称为 id 的列,如果要显示的自定义一个自增列,必须将给列设置为主键 primary_key=True。
    2models.CharField  字符串字段
      必须 max_length 参数
    3、models.BooleanField  布尔类型=tinyint(1)
      不能为空,Blank=True
    4、models.ComaSeparatedIntegerField  用逗号分割的数字=varchar
      继承CharField,所以必须 max_lenght 参数
    5models.DateField  日期类型 date
      对于参数,auto_now = True 则每次更新都会更新这个时间;auto_now_add 则只是第一次创建添加,之后的更新不再改变。
    6models.DateTimeField  日期类型 datetime
      同DateField的参数
    7、models.Decimal  十进制小数类型 = decimal
      必须指定整数位max_digits和小数位decimal_places
    8、models.EmailField  字符串类型(正则表达式邮箱) =varchar
      对字符串进行正则表达式
    9、models.FloatField  浮点类型 = double
    10models.IntegerField  整形
    11、models.BigIntegerField  长整形
      integer_field_ranges = {
        'SmallIntegerField': (-32768, 32767),
        'IntegerField': (-2147483648, 2147483647),
        'BigIntegerField': (-9223372036854775808, 9223372036854775807),
        'PositiveSmallIntegerField': (0, 32767),
        'PositiveIntegerField': (0, 2147483647),
      }
    12、models.IPAddressField  字符串类型(ip4正则表达式)
    13、models.GenericIPAddressField  字符串类型(ip4和ip6是可选的)
      参数protocol可以是:both、ipv4、ipv6
      验证时,会根据设置报错
    14、models.NullBooleanField  允许为空的布尔类型
    15、models.PositiveIntegerFiel  正Integer
    16、models.PositiveSmallIntegerField  正smallInteger
    17、models.SlugField  减号、下划线、字母、数字
    18、models.SmallIntegerField  数字
      数据库中的字段有:tinyint、smallint、int、bigint
    19、models.TextField  字符串=longtext
    20、models.TimeField  时间 HH:MM[:ss[.uuuuuu]]
    21、models.URLField  字符串,地址正则表达式
    22、models.BinaryField  二进制
    23models.ImageField   图片  在数据库中保存的是文件的路径
    24、models.FilePathField 文件

    三、字段中的参数

    1、null=True
      数据库中字段是否可以为空
    2、blank=True
      django的 Admin 中添加数据时是否可允许空值
    3、primary_key = False
      主键,对AutoField设置主键后,就会代替原来的自增 id 列
    4auto_now 和 auto_now_add
      auto_now   自动创建---无论添加或修改,都是当前操作的时间
      auto_now_add  自动创建---永远是创建时的时间
    5choices
    GENDER_CHOICE = (
            (u'M', u'Male'),
            (u'F', u'Female'),
        )
    gender = models.CharField(max_length=2,choices = GENDER_CHOICE)
    6max_length
    7default  默认值
    8、verbose_name  Admin中字段的显示名称
    9、name|db_column  数据库中的字段名称
    10、unique=True  不允许重复
    11、db_index = True  数据库索引
    12、editable=True  在Admin里是否可编辑
    13、error_messages=None  错误提示
    14、auto_created=False  自动创建
    15、help_text  在Admin中提示帮助信息
    16、validators=[]
    17、upload-to  上传路径

    四、上传文件

    根据上传文件的契机,来写一个简单的上传文件的例子

    html文件

    前端代码
     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title></title>
     6 </head>
     7 <body>
     8 
     9 <form action="/upload/" method="POST" enctype="multipart/form-data">
    10 
    11     <p><input type="file" name="f1"></p>
    12     <p><input type="file" name="f2"></p>
    13     <p><input type="text" name="hostname"></p>
    14     <input type="submit" value="上传">
    15 
    16 </form>
    17 
    18 </body>
    19 </html>

    views.py

     1 def upload(request):
     2 
     3     if request.method == "POST":
     4         inp_file = request.FILES          # 上传的文件会在request.FILES里
     5         file_obj1 = inp_file.get('f1')    # 根据前端设置的name属性值获取相对应的文件
     6 
     7         print inp_file
     8         print file_obj1.name              # 获取文件名
     9         print file_obj1.size
    10         f = open(file_obj1.name, 'wb')    # 以获取的文件名 按‘wb’的方式打开一个文件
    11         for line in file_obj1.chunks():   # chunks方法读取文件,默认每次读取64kb
    12             f.write(line)
    13         f.close()
    14     return render(request, 'home/upload.html')

     

  • 相关阅读:
    Spring Boot整合Freemarker
    Spring Boot异常处理
    CSAPP缓冲区溢出攻击实验(下)
    SparkSQL基础应用(1.3.1)
    程序员的自我修养:(1)目标文件
    CSAPP缓冲区溢出攻击实验(上)
    Redis源码学习:字符串
    六星经典CSAPP-笔记(7)加载与链接(上)
    Redis源码学习:Lua脚本
    六星经典CSAPP-笔记(10)系统IO
  • 原文地址:https://www.cnblogs.com/chenchao1990/p/5307373.html
Copyright © 2020-2023  润新知