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

你可能感兴趣的文章
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>