Django入门-5:模型的基本使用3-模型成员&创建对象

简介: Django入门-5:模型的基本使用3-模型成员&创建对象

类的属性

  1. objects:是Manager类型的对象,用于与数据库进行交互
  2. 当定义模型类时没有指定管理器,则Django会为模型类提供一个名为objects的管理器
  3. 支持明确指定模型类的管理器
  1. classBookInfo(models.Model):
  2.    ...
  3.    books = models.Manager()
  • 当为模型类指定管理器后,django不再为模型类生成名为objects的默认管理器


管理器Manager

  1. 管理器是Django的模型进行数据库的查询操作的接口,Django应用的每个模型都拥有至少一个管理器
  2. 自定义管理器类主要用于两种情况
  3. 情况一:向管理器类中添加额外的方法:见下面“创建对象”中的方式二
  4. 情况二:修改管理器返回的原始查询集:重写get_queryset()方法


  1. classBookInfoManager(models.Manager):
  2.    defget_queryset(self):
  3.        returnsuper(BookInfoManager, self).get_queryset().filter(isDelete=False)
  4. classBookInfo(models.Model):
  5.    ...
  6.    books = BookInfoManager()


创建对象

  1. 当创建对象时,django不会对数据库进行读写操作
  2. 调用save()方法才与数据库交互,将对象保存到数据库中
  3. 使用关键字参数构造模型对象很麻烦,推荐使用下面的两种之式
  4. 说明: _init _方法已经在基类models.Model中使用,在自定义模型中无法使用,



  • 方式一:在模型类中增加一个类方法
  1. classBookInfo(models.Model):
  2.    ...
  3.    @classmethod
  4.    defcreate(cls, title, pub_date):
  5.        book = cls(btitle=title, bpub_date=pub_date)
  6.        book.bread=0
  7.        book.bcommet=0
  8.        book.isDelete = False
  9.        return book
  10. 引入时间包:from datetime import *
  11. 调用:book=BookInfo.create("hello",datetime(1980,10,11));
  12. 保存:book.save()


  • 方式二:自定义管理器中添加一个方法
  • 在管理器的方法中,可以通过self.model来得到它所属的模型类


  1. classBookInfoManager(models.Manager):
  2.    defcreate_book(self, title, pub_date):
  3.        book = self.model()
  4.        book.btitle = title
  5.        book.bpub_date = pub_date
  6.        book.bread=0
  7.        book.bcommet=0
  8.        book.isDelete = False
  9.        return book
  10. classBookInfo(models.Model):
  11.    ...
  12.    books = BookInfoManager()
  13. 调用:book=BookInfo.books.create_book("abc",datetime(1980,1,1))
  14. 保存:book.save()
  • 在方式二中,可以调用self.create()创建并保存对象,不需要再手动save()
  1. classBookInfoManager(models.Manager):
  2.    defcreate_book(self, title, pub_date):
  3.        book = self.create(btitle = title,bpub_date = pub_date,bread=0,bcommet=0,isDelete = False)
  4.        return book
  5. classBookInfo(models.Model):
  6.    ...
  7.    books = BookInfoManager()
  8. 调用:book=Book.books.create_book("abc",datetime(1980,1,1))
  9. 查看:book.pk


实例的属性

  1. DoesNotExist:在进行单个查询时,模型的对象不存在时会引发此异常,结合try/except使用


实例的方法

  1. str (self):重写object方法,此方法在将对象转换成字符串时会被调用
  2. save():将模型对象保存到数据表中
  3. delete():将模型对象从数据表中删除


目录
相关文章
|
26天前
|
关系型数据库 MySQL 数据库
数据迁移脚本优化过程:从 MySQL 到 Django 模型表
在大规模的数据迁移过程中,性能问题往往是开发者面临的主要挑战之一。本文将分析一个数据迁移脚本的优化过程,展示如何从 MySQL 数据库迁移数据到 Django 模型表,并探讨优化前后的性能差异。
|
27天前
|
JSON API 数据格式
Django REST framework序列化器详解:普通序列化器与模型序列化器的选择与运用
Django REST framework序列化器详解:普通序列化器与模型序列化器的选择与运用
|
25天前
|
关系型数据库 MySQL 数据库
『Django』模型入门教程-操作MySQL
一个后台如果没有数据库可以说废了一半。日常开发中大多数时候都在与数据库打交道。Django 为我们提供了一种更简单的操作数据库的方式。 在 Django 中,模型(Model)是用来定义数据库结构的类。每个模型类通常对应数据库中的一个表,类的属性对应表中的列。通过定义模型,Django 的 ORM(Object-Relational Mapping)可以将 Python 对象映射到数据库表,并提供一套 API 来进行数据库操作。 本文介绍模型的用法。
|
1月前
|
关系型数据库 MySQL 数据库连接
数据迁移到 Django 模型表:详尽指南
数据迁移是许多应用程序开发过程中必不可少的一部分。在这篇文章中,我们将详细分析和总结如何通过一个定制的 Django 管理命令,将数据从 MySQL 数据库迁移到 Django 模型表中。这种方法可以确保数据在多个数据库之间有效且安全地迁移,同时避免了手动操作的繁琐和错误。
|
27天前
|
存储 SQL 数据处理
Django ORM实战:模型字段与元选项配置,以及链式过滤与QF查询详解
Django ORM实战:模型字段与元选项配置,以及链式过滤与QF查询详解
|
27天前
|
数据库 开发者 Python
Django ORM入门指南:从概念到实践,掌握模型创建、迁移与视图操作
Django ORM入门指南:从概念到实践,掌握模型创建、迁移与视图操作
|
27天前
|
前端开发 数据库 Python
Django入门全攻略:从零搭建你的第一个Web项目
Django入门全攻略:从零搭建你的第一个Web项目
|
1月前
|
Linux 数据库管理 Python
CentOS7编译安装Python3.10(含OpenSSL1.1.1安装),创建虚拟环境,运行Django项目(含sqlite版本报错)
CentOS7编译安装Python3.10(含OpenSSL1.1.1安装),创建虚拟环境,运行Django项目(含sqlite版本报错)
217 4
|
1月前
|
开发框架 数据库 开发者
Web开发新境界:用Python玩转Django和Flask!
【6月更文挑战第12天】Python的Web开发框架Django和Flask各有千秋。Django是全能型框架,适合快速开发大型应用,提供ORM、模板引擎、URL路由和后台管理等全面功能。Flask则轻量级且灵活,适用于小型到中型应用,以其简单易用、高度可扩展和灵活路由著称。两者结合使用,能应对各种Web开发需求。
|
1月前
|
前端开发 JavaScript 数据安全/隐私保护
计算机Python项目|django学生成绩管理系统
计算机Python项目|django学生成绩管理系统