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

你可能感兴趣的文章
OpenMMLab | 【全网首发】Llama 3 微调项目实践与教程(XTuner 版)
查看>>
Oracle11G基本操作
查看>>
PayPal网站付款标准版(for PHP)
查看>>
Paystack Android SDK 集成与使用指南
查看>>
PC端编辑 但能在PC端模拟移动端预览的富文本编辑器
查看>>
Penetration Testing、Security Testing、Automation Testing
查看>>
php -- 魔术方法 之 判断属性是否存在或为空:__isset()
查看>>
php csv 导出
查看>>
php include和require
查看>>
php mysql优化方法_MySQL优化常用方法
查看>>
PHP OAuth 2.0 Server
查看>>
php odbc驱动,php常用ODBC函数集(详细)
查看>>
php openssl aes ecb,php openssl_encrypt AES-128-ECB iOS
查看>>
php paypal rest api,PayPal REST API指定网络配置文件PHP
查看>>
PHP pcntl_fork不能在web服务器中使用的变通方法
查看>>
php private ,public protected三者的区别
查看>>
php PSR规范
查看>>
php rand() 重复,array_rand()函数从另外一个数组中随机取得的一定数量的数组的元素是否会重复?...
查看>>
php redis(2)
查看>>
PHP Redis分布式锁
查看>>