- 学习了ORM模板中常用的字段以及使用方法,具体如下:
-
from django.db import models # Create your models here.
# 如果要将一个普通的类映射到数据库,必须设置其父类为models.Model
class Book(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=100, null=False)
author = models.CharField(max_length=100, null=False)
price = models.FloatField(null=False, default=0) def __str__(self):
# 定义返回字符串的格式
return "<Book:{name},{author},{price}>".format(name=self.name, author=self.author, price=self.price) class Publisher(models.Model):
name = models.CharField(max_length=100, null=False)
address = models.CharField(max_length=100, null=False) class Article(models.Model):
# 如果想自己定义主键,primary_key=True,否则会自动生成id主键
id = models.BigAutoField(primary_key=True)
# removed = models.BooleanField(default=True)
# 如果没有指明null=True,那么默认null=False,
# 如果想要使用可以为null的BooleanField,那么应该使用NullBooleanField
removed = models.NullBooleanField()
# CharField 如果超过254个,不建议使用
title = models.CharField(max_length=200, null=True) '''
naive time: 不知道自己的时间是表示那个时区的时间
aware time: 知道自己的时间表示的是那个时区的
pytz: 库在安装django的时候默认安装,专门用来处理时区的库
astimezone:将一个时区的时间转化为另一个时区的时间,只能被aware time类型时间使用
replace: 可以将上述的两种时间表示相互转换(now = now.replace(tzinfo= pytz.timezone(Asia/Shanghai)))
django.utils.timezone.now(): 会根据’setting.py’中是否设置了‘USE_TZ=True’获取当前时间,如果设置了,那么就会获取到一个‘aware’类型的‘UTC’时间,如果没有,就会获取到一个‘navie’时间。
django.utils.timezone.localtime(): 会根据’setting.py’中的‘TIME_ZONE'来将一个’aware‘类型的时间转化为‘TIME_ZONE'指定的时区的时间
'''
# auto_now_add=True:在第一添加数据的时候会自动获取当前时间
# auto_now: 每次这个对象调用save方法的时候(更改数据的时候会用到save),都会将当前的时间更新,在更新时间字段用得到
create_time = models.DateTimeField(auto_now_add=True) class Person(models.Model):
# EmailField在数据库层面不会限制你存储的格式
email = models.EmailField()
context = models.TextField()建立迁移文件命令:python manage.py makemigrations 迁移文件:python manage.py migrate
- 常用字段: 在 Django 中,定义了一些 Field 来与数据库表中的字段类型来进行映射。以下将介绍那些常用 的字段类型。
- AutoField: 映射到数据库中是 int 类型,可以有自动增长的特性。一般不需要使用这个类型,如果不指定主 键,那么模型会自动的生成一个叫做 id 的自动增长的主键。如果你想指定一个其他名字的并且具 有自动增长的主键,使用 AutoField 也是可以的。
- BigAutoField: 64位的整形,类似于 AutoField ,只不过是产生的数据的范围是从 1-9223372036854775807 。
- BooleanField: 在模型层面接收的是 True/False 。在数据库层面是 tinyint 类型。如果没有指定默认值,默认值 是 None 。
- CharField: 在数据库层面是 varchar 类型。在 Python 层面就是普通的字符串。这个类型在使用的时候必须 要指定最大的长度,也即必须要传递 max_length 这个关键字参数进去。
- DateField: 日期类型。在 Python 中是 datetime.date 类型,可以记录年月日。在映射到数据库中也 是 date 类型。使用这个 Field 可以传递以下几个参数: 1. auto_now :在每次这个数据保存的时候,都使用当前的时间。比如作为一个记录修改日期的 字段,可以将这个属性设置为 True 。 2. auto_now_add :在每次数据第一次被添加进去的时候,都使用当前的时间。比如作为一个记 录第一次入库的字段,可以将这个属性设置为 True 。
- DateTimeField:日期时间类型,类似于 DateField 。不仅仅可以存储日期,还可以存储时间。映射到数据库中 是 datetime 类型。这个 Field 也可以使用 auto_now 和 auto_now_add 两个属性。 TimeField: 时间类型。在数据库中是 time 类型。在 Python 中是 datetime.time 类型。
- EmailField: 类似于 CharField 。在数据库底层也是一个 varchar 类型。最大长度是254个字符。
- FloatField: 浮点类型。映射到数据库中是 float 类型。
- IntegerField: 整形。值的区间是 -2147483648——2147483647 。
- BigIntegerField: 大整形。值的区间是 -9223372036854775808——9223372036854775807 。
- PositiveIntegerField: 正整形。值的区间是 0——2147483647 。 SmallIntegerField: 小整形。值的区间是 -32768——32767 。
- PositiveSmallIntegerField:正小整形。值的区间是 0——32767 。
- TextField: 大量的文本类型。映射到数据库中是longtext类型。
- UUIDField: 只能存储 uuid 格式的字符串。 uuid 是一个32位的全球唯一的字符串,一般用来作为主键。
- URLField: 类似于 CharField ,只不过只能用来存储 url 格式的字符串。并且默认的 max_length 是200。
- 以上。
相关文章
- 08-17聚合查询、分组查询、F与Q查询、django中如何开启事务、orm中常用字段及参数、数据库查询优化(only与defer、select_related与prefetch_related)
- 08-1759 Django基础三件套 , 模板{{}}语言 , 程序连mysql Django项目app Django中ORM的使用
- 08-17python3开发进阶-Django框架中的ORM的常用(增,删,改,查)操作
- 08-17python3开发进阶-Django框架中的ORM的常用操作的补充(F查询和Q查询,事务)
- 08-17聚合查询、分组查询、F与Q查询、django中如何开启事务、orm中常用字段及参数、数据库查询优化(only与defer、select_related与prefetch_related)
- 08-17Django中ORM模板常用属性讲解