orm字段和参数
charfield varchar
integerfield int
bigintegerfield bigint
emailfield varchar(254)
datefield
datetimefield
auto_now:时间实时更新
auto_now_add:只保存注册时间,后面不修改不会改变
autofield auto_increment
booleanfield 布尔值,自动存0或1
textfield 专门用来存大段文本
filefield 专门用来存文件路径 '/etc/data/a.txt'
upload_to = '/etc/data'
给该字段传值的时候,直接传文件对象
会自动将文件对象保存到upload_to后面指定的文件路径中,
然后将路径保存到数据库。
decimalfield(Field)
10进制小数
参数:
max_digits:小数总长度
decimal_places:小数位长度
自定义char字段:
如何自定义字段类型
class MycharField(models.Field):
def __init__(self,max_length,*args,**kwargs):
self.max_length=max_length
重新调用父类的方法
super().__init__(max_length=max_length,*args,**kwargs)
def db_type(self,connection):
return 'char(%s)'%self.max_length
orm中的事务操作:
django中如何开启事务??
需要导入事务模块开启事务,from django.db import transaction
from django.db import transaction
with transaction.atomic():
在缩进的代码中书写数据库操作
该缩进内的所有代码,都是一个事务
pass
代码运行结束,即代表事务的结束
什么是事务:
事务:是数据库操作的最小工作单元,是作为单个逻辑工作单元执行的一系列操作;
这些操作作为一个整体一起向系统提交,要么都执行、要么都不执行;
事务是一组不可再分割的操作集合(工作逻辑单元);
事务的四大特性:
1 、原子性
一个事务是一个不可分割的工作单位,事务中包含的各操作要么都做,要么都不做
2 、一致性
事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,
就说数据库处于一致性状态。如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,
这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是不一致的状态。
3 、隔离性
一个事务的执行不能其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,
并发执行的各个事务之间不能互相干扰。
4 、持续性
也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。
接下来的其它操作或故障不应该对其执行结果有任何影响。