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

你可能感兴趣的文章
Objective-C实现9×9二维数组数独算法(附完整源码)
查看>>
Objective-C实现A*(A-Star)算法(附完整源码)
查看>>
Objective-C实现A-Star算法(附完整源码)
查看>>
Objective-C实现abbreviation缩写算法(附完整源码)
查看>>
Objective-C实现ABC人工蜂群算法(附完整源码)
查看>>
Objective-C实现activity selection活动选择问题算法(附完整源码)
查看>>
Objective-C实现AC算法(Aho-Corasick) 算法(附完整源码)
查看>>
Objective-C实现adaboost算法(附完整源码)
查看>>
Objective-C实现Adler32算法(附完整源码)
查看>>
Objective-C实现AES算法(附完整源码)
查看>>
Objective-C实现AffineCipher仿射密码算法(附完整源码)
查看>>
Objective-C实现aliquot sum等分求和算法(附完整源码)
查看>>
Objective-C实现all combinations所有组合算法(附完整源码)
查看>>
Objective-C实现all permutations所有排列算法(附完整源码)
查看>>
Objective-C实现all subsequences所有子序列算法(附完整源码)
查看>>
Objective-C实现AlphaNumericalSort字母数字排序算法(附完整源码)
查看>>
Objective-C实现alternate disjoint set不相交集算法(附完整源码)
查看>>
Objective-C实现alternative list arrange备选列表排列算法(附完整源码)
查看>>
Objective-C实现An Armstrong number阿姆斯特朗数算法(附完整源码)
查看>>
Objective-C实现anagrams字谜算法(附完整源码)
查看>>