Django中ORM模板常用属性讲解
- 学习了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。
- 以上。
Django中ORM模板常用属性讲解的更多相关文章
- Django中ORM介绍和字段及其参数
ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...
- Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM)
Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简 ...
- Django中ORM的使用
Django中ORM的使用 ORM orm(object-relation-mapping)对象关系映射,即用对象来表示关系数据库中的表: 类 --> 表, 对象-->一行数据 对象的属性 ...
- Django中ORM对数据库的增删改查
Django中ORM对数据库数据的增删改查 模板语言 {% for line in press %} {% line.name %} {% endfor %} {% if 条件 %}{% else % ...
- 6月20日 Django中ORM介绍和字段、字段参数、相关操作
一.Django中ORM介绍和字段及字段参数 二.Django ORM 常用字段和参数 三.Django ORM执行原生SQL.在Python脚本中调用Django环境.Django终端打印SQL语句 ...
- Django中ORM对数据库的增删改查操作
前言 什么是ORM? ORM(对象关系映射)指用面向对象的方法处理数据库中的创建表以及数据的增删改查等操作. 简而言之,就是将数据库的一张表当作一个类,数据库中的每一条记录当作一个对象.在 ...
- Django中ORM创建表关系
一:django中ORM创建表关系 ORM创建外键关系 1.表与表之间的关系 1.表与表之间的关系 一对多 一对一 多对多 2.操作目标条件: 图书表 出版社表 作者表 作者详情表 3.外键关联 一对 ...
- Delphi中TStringList类常用属性方法详解
TStrings是一个抽象类,在实际开发中,是除了基本类型外,应用得最多的. 常规的用法大家都知道,现在来讨论它的一些高级的用法. 先把要讨论的几个属性列出来: 1.CommaText 2.Delim ...
- Django中ORM实际应用
1. Django中ORM的使用 1. 手动新建一个数据库 2. 告诉Django连接哪个数据库 settings.py里面配置数据库连接信息: # 数据库相关的配置项 DATABASES = { ' ...
随机推荐
- 面试常见的selenium问题
1.如何切换iframe 问题:如果你在一个default content中查找一个在iframe中的元素,那肯定是找不到的.反之你在一个iframe中查找另一个iframe元素或default co ...
- MongoDB-4: 查询(二-数组、内嵌文档)
一.简介 我们上一篇介绍了db.collection.find()可以实现根据条件查询和指定使用投影运算符返回的字段省略此参数返回匹配文档中的所有字段,我们今天介绍了对数组和内嵌文档的查询操作,尤其是 ...
- 使用npm构建前端项目基本流程
现在各种前端框架, 库文件基本都托管到npm上, 我们平常下载到别人的项目文件, 也基本是用npm 构建的, 不了解点node和npm那是寸步难行. 下面介绍的代码示例不敢说是最佳实践, 但都是我亲自 ...
- 吴超老师课程--Hive的执行语句
为什么选择Hive? (1)基于Hadoop的大数据的计算/扩展能力(2)支持SQL like查询语言(3)统一的元数据管理(4)简单编程 一:Hive的数据类型(1)基本数据类型tinyint/sm ...
- Codeforces Round #468(div2)
A Friends Meeting 题意:有两个人在数轴上的不同位置,现在他们需要到一个位置碰面.每次每人只能向左或向右走1个单位,轮流进行.每个人第一次走时疲劳度+1,第二次走时疲劳度+2,以此类推 ...
- MiniGUI 显示中文
修改/usr/local/etc/MiniGUI.cfg # The first system font must be a logical font using RBF device font.[s ...
- Spring 配置log4j和简单介绍Log4J的使用
Log4j 是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件.甚至是套接口服务器.NT的事 件记录器.UNIX Syslog守护进程等 ...
- win7解压的软件开机自启动
win7让你一个可执行程序开机启动. 运行-->regedit-->HKEY_LOCAL_MACHINE-->SOFTWARE-->Microsoft-->Windows ...
- Linux系统启动管理 系统启动流程
概述 linux启动时我们会看到许多启动信息,其过程可以分为5个阶段: BIOS自检 读取MBR 通过Boot Loader引导系统加载 加载initramfe虚拟文件系统 加载内核 运行system ...
- koa2.0富文本编辑器的选择历程
本人学习vue和koa2.0,做了一个简单的个人博客,博客自然会需要富文本编辑器的选择,由于nodejs和koa2.0,于是便开始了不断尝试的历程. 一.ueditor 刚开始在百度搜索,自然第一个发 ...