ORM的数据库操作

1.字段类型:

类型说明
BooleanField布尔字段,值为True或False
CharField字符串,参数max_length表示最大字符个数
TextField大文本字段,一般超过4000个字符时使用
IntegerField整数
DecimalField十进制浮点数, 参数max_digits表示总位数, 参数decimal_places表示小数位数
FloatField浮点数
DateField日期, 参数auto_now表示每次保存对象时,自动设置该字段为当前时间,用于"最后一次修改"的时间戳,它总是使用当前日期,默认为False; 参数auto_now_add表示当对象第一次被创建时自动设置当前时间,用于创建的时间戳,它总是使用当前日期,默认为False; 参数auto_now_add和auto_now是相互排斥的,组合将会发生错误
TimeField时间,参数同DateField
DateTimeField日期时间,参数同DateField
FileField上传文件字段
ImageField继承于FileField,对上传的内容进行校验,确保是有效的图片

2.限制:

选项说明
null如果为True,表示允许为空,默认值是False
blank如果为True,则该字段允许为空白,默认值是False
db_column字段的名称,如果未指定,则使用属性的名称
db_index若值为True, 则在表中会为此字段创建索引,默认值是False
default默认
primary_key若为True,则该字段会成为模型的主键字段,默认值是False,一般作为AutoField的选项使用
unique如果为True, 这个字段在表中必须有唯一值,默认值是False
verbose_name对于字段的一个可读性更高的名称

3.shell工具

Django的manage工具提供了shell命令,帮助我们配置好当前工程的运行环境(如连接好数据库等),以便可以直接在终端中执行测试python语句。

通过如下命令进入shell

python manage.py shell

4.数据库操作-增、删、改、查:

1.增加

1.save

book = BookInfo(
    name='python',
    pub_date='2020-11-11',
    read_count=200,
    comment_count=100,
    sale_out=False,
)
book.save()

2.create

BookInfo.objects.create(
    name='Js',
    pub_date='2010-12-12',
    read_count=500,
    comment_count=200,
    sale_out=False,
)

2.删

# 方式1 delete
book = BookInfo.objects.get(name='python')  # 获取对象
book.delete()  # 删除对象
# 方式2 模型类.objects.filter().delete()
BookInfo.objects.filter(name='JavaScript').delete()

3.改

# 方式1 save
book = BookInfo.objects.get(name='python')  # 获取对象
book.read_count = 300  # 修改属性值
book.save()  # 保存生效
# 方式2 update
BookInfo.objects.filter(name='Js').update(name='JavaScript')

4.查:

1. 基本查询

get 查询单一结果,如果不存在会抛出模型类.DoesNotExist异常。
all 查询多个结果。
count 查询结果数量。

2. 过滤查询
  • filter过滤出多个结果
  • exclude排除掉符合条件剩下的结果
  • get过滤单一结果
3. 聚合函数

使用aggregate()过滤器调用聚合函数。聚合函数包括:Avg平均,Count数量,Max最大,Min最小,Sum求和,被定义在django.db.models中。

3. 排序
Bookinfo.objects.all().order_by('read_count')
Bookinfo.objects.all().order_by('-read_count')#降序

查询集QuerySet

Django的ORM中存在查询集的概念。

查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。
当调用如下过滤器方法时,Django会返回查询集(而不是简单的列表):

  • all():返回所有数据。
  • filter():返回满足条件的数据。
  • exclude():返回满足条件之外的数据。
  • order_by():对结果进行排序。
    对查询集可以再次调用过滤器进行过滤
    从SQL的角度讲,查询集与select语句等价,过滤器像where、limit、order by子句。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值