博客
关于我
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/

你可能感兴趣的文章
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>
mysql中的字段如何选择合适的数据类型呢?
查看>>
MySQL中的字符集陷阱:为何避免使用UTF-8
查看>>
mysql中的数据导入与导出
查看>>
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>
Mysql中触发器的使用示例
查看>>
Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
查看>>
mysql中还有窗口函数?这是什么东西?
查看>>
mysql中间件
查看>>
MYSQL中频繁的乱码问题终极解决
查看>>
MySQL为Null会导致5个问题,个个致命!
查看>>
MySQL为什么不建议使用delete删除数据?
查看>>