博客
关于我
Django(十)模型:django模型类对数据库的:增/删/改/查、自关联、管理器、元选项(指定表名)
阅读量:757 次
发布时间:2019-03-23

本文共 1524 字,大约阅读时间需要 5 分钟。

Django ORM操作指南

一、_INSERT、_UPDATE _&_DELETE

在 Django 中,通过模型类对象的 save() 方法可以对数据库进行插入、更新和删除操作。具体来说:

  • 调用 save() 方法可以自动对数据库进行插入或更新操作,这取决于模型类对象是否已经存在于数据库中。
  • 对于删除操作,推荐使用 _delete() 方法,避免直接从数据库中删除记录,以防 storyboard warenaminder。

二、自关联关系

自关联是一种特殊的一对多关系,适用于父级和子级的数据管理。在广州市的案例中,我们需要一个地区表来存储上级和下级地区信息。

地区表结构

id | atitle | aParent_id

数据导入

将数据从 area.sql 文件导入至数据库,确保表名为 app1_areainfo

模型类定义

该模型类通过自关联关系实现一对多的关系:

class AreaInfo(models.Model):    '''地区模型类'''    atitle = models.CharField(max_length=20)    aParent = models.ForeignKey('self', null=True, blank=True)    class Meta:        db_table = 'areas'

三、管理器(Manager)

使用 BookInfo.objects.all() 会返回一个 manager 对象。this manager 提供了对数据库中 BookInfo 实体进行查询的能力。

自定义 manager 类

通过自定义 manager 类,可以对数据进行更复杂的筛选和操作。

管理器方法示例

class BookInfoManager(models.Manager):    def all(self):        return super().filter(isDelete=False)    def create_book(cls, btitle, bpub_date):        obj = cls()        obj.btitle = btitle        obj.bpub_date = bpub_date        obj.save()        return obj

调用方式:

BookInfo.objects.create(btitle='xxx', bpub_date='xxxx-xx-xx')

四、数据库表名设置

Django 默认会为模型类生成表名。为了定制表名,可以在模型类中定义一个 Meta 类,并设置 db_table 属性。

例子

app1/models.py 中定义:

class AreaInfo(models.Model):    '''地区模型类'''    atitle = models.CharField(max_length=20)    aParent = models.ForeignKey('self', null=True, blank=True)    class Meta:        db_table = 'areas'

表名优化案例

如果需要修改默认表名,可以通过 db_table 属性进行设置。例如,对于需要以 area 代替 app1_area 表名的情况,以上方法能够有效实现。


通过以上方法,可以高效地管理 Django应用中的数据操作、自关联关系以及数据库表名设置。如果需要更详细的操作指导,可以参考 official Django 文档。

转载地址:http://ezkzk.baihongyu.com/

你可能感兴趣的文章
NFS共享文件系统搭建
查看>>
ng 指令的自定义、使用
查看>>
nginx + etcd 动态负载均衡实践(二)—— 组件安装
查看>>
Nginx + uWSGI + Flask + Vhost
查看>>
Nginx Location配置总结
查看>>
Nginx 动静分离与负载均衡的实现
查看>>
Nginx 反向代理解决跨域问题
查看>>
Nginx 反向代理配置去除前缀
查看>>
nginx 后端获取真实ip
查看>>
Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
查看>>
nginx 常用配置记录
查看>>
Nginx 我们必须知道的那些事
查看>>
Nginx 的 proxy_pass 使用简介
查看>>
Nginx 的配置文件中的 keepalive 介绍
查看>>
nginx 配置 单页面应用的解决方案
查看>>
nginx 配置~~~本身就是一个静态资源的服务器
查看>>
Nginx下配置codeigniter框架方法
查看>>
nginx添加模块与https支持
查看>>
Nginx的Rewrite正则表达式,匹配非某单词
查看>>
Nginx的使用总结(一)
查看>>