对象关系映射(Object-Relational Mapping)

简介: 【8月更文挑战第17天】

ORM,即对象关系映射(Object-Relational Mapping),是一种在编程中用于将对象模型表示的程序数据结构转化为关系数据库的形式,反之亦然的方法。简单来说,ORM允许开发者使用面向对象的方式来操作数据库——创建、查询、更新和删除数据,而不需要编写复杂的SQL语句。

ORM:

  • 抽象层:ORM提供了一个抽象层,将数据库的底层细节隐藏起来,让开发者能够用熟悉的对象操作来处理数据存储。
  • 减少冗余:通过ORM,开发者不需要重复编写相同的SQL语句,可以减少代码冗余和潜在的错误。
  • 提高效率:ORM可以自动处理很多常见的数据库操作,提高开发效率。
  • 数据一致性:使用ORM时,所有的数据库操作都通过模型来进行,有助于保持数据的一致性和完整性。

ORM的主要功能:

  1. 对象映射:将数据库表映射为Python类,表中的字段映射为类的属性。
  2. 查询构建:使用链式调用构建查询,支持条件过滤、排序、分组、聚合等操作。
  3. 数据操作:提供API来添加、修改、删除数据库记录。
  4. 关系处理:支持处理表之间的关系,如一对一、一对多、多对多等。

Django ORM的代码示例:

  1. 定义模型

    # models.py
    from django.db import models
    
    class Author(models.Model):
        name = models.CharField(max_length=100)
        email = models.EmailField()
    
    class Book(models.Model):
        title = models.CharField(max_length=200)
        author = models.ForeignKey(Author, on_delete=models.CASCADE)
        published_date = models.DateField()
        pages = models.IntegerField()
    
  2. 创建记录

    # 导入模型
    from myapp.models import Author, Book
    
    # 创建Author实例并保存
    author = Author(name='Jane Doe', email='jane.doe@example.com')
    author.save()
    
    # 创建Book实例并保存,同时设置外键关联
    book = Book(title='My Book', author=author, published_date='2023-01-01', pages=300)
    book.save()
    
  3. 查询记录

    # 获取所有书籍
    books = Book.objects.all()
    
    # 过滤查询,获取特定作者的书籍
    jane_books = Book.objects.filter(author__name='Jane Doe')
    
    # 获取特定书籍的详细信息
    book = Book.objects.get(pk=1)
    print(book.title)  # 输出: My Book
    
  4. 更新记录

    # 更新书籍的标题
    book.title = 'Updated Book Title'
    book.save()
    
  5. 删除记录

    # 删除书籍
    book.delete()
    
  6. 使用关联

    # 通过书籍获取作者
    book = Book.objects.get(pk=1)
    author = book.author
    
    # 通过作者获取书籍列表
    authors_books = author.book_set.all()
    
  7. 查询优化

    # 选择特定字段
    books = Book.objects.values('title', 'published_date')
    
    # 使用select_related优化查询,避免N+1问题
    author = Author.objects.select_related('book_set').get(pk=1)
    for book in author.book_set.all():
        print(book.title)
    
目录
相关文章
|
24天前
|
安全 Java
Object取值转java对象
通过本文的介绍,我们了解了几种将 `Object`类型转换为Java对象的方法,包括强制类型转换、使用 `instanceof`检查类型和泛型方法等。此外,还探讨了在集合、反射和序列化等常见场景中的应用。掌握这些方法和技巧,有助于编写更健壮和类型安全的Java代码。
38 17
|
5月前
ES6中map对象的使用,确实比Object好使哈
ES6中Map对象的使用优势,包括任意类型作为键、直接获取大小、增删查改操作等。Map的键可以是函数、对象、NaN等,支持forEach循环和for...of循环。
48 1
ES6中map对象的使用,确实比Object好使哈
|
4月前
|
Python
通过 type 和 object 之间的关联,进一步分析类型对象
通过 type 和 object 之间的关联,进一步分析类型对象
89 3
|
4月前
|
JavaScript 前端开发 大数据
在JavaScript中,Object.assign()方法或展开语法(...)来合并对象,Object.freeze()方法来冻结对象,防止对象被修改
在JavaScript中,Object.assign()方法或展开语法(...)来合并对象,Object.freeze()方法来冻结对象,防止对象被修改
90 0
|
6月前
|
数据安全/隐私保护
作用域通信对象:session用户在登录时通过`void setAttribute(String name,Object value)`方法设置用户名和密码。点击登录按钮后,跳转到另外一个页面显示用户
该博客文章通过示例演示了如何使用session对象的`setAttribute`和`getAttribute`方法在不同页面间传递和显示用户的用户名和密码信息,并说明了如何设置会话的有效期。
作用域通信对象:session用户在登录时通过`void setAttribute(String name,Object value)`方法设置用户名和密码。点击登录按钮后,跳转到另外一个页面显示用户
|
6月前
【Azure Developer】使用PowerShell Where-Object方法过滤多维ArrayList时候,遇见的诡异问题 -- 当查找结果只有一个对象时,返回结果修改了对象结构,把多维变为一维
【Azure Developer】使用PowerShell Where-Object方法过滤多维ArrayList时候,遇见的诡异问题 -- 当查找结果只有一个对象时,返回结果修改了对象结构,把多维变为一维
网易:所有的对象最终都会继承自 Object.prototype ? ——原型链(二)详细讲解!
网易:所有的对象最终都会继承自 Object.prototype ? ——原型链(二)详细讲解!
|
6月前
|
JavaScript
网易:所有的对象最终都会继承自 Object.prototype ? ——原型链(一)详细讲解!
网易:所有的对象最终都会继承自 Object.prototype ? ——原型链(一)详细讲解!
|
9月前
|
存储 算法 Java
滚雪球学Java(42):探索对象的奥秘:解析Java中的Object类
【5月更文挑战第17天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
68 2
|
8月前
|
Java 编译器 数据处理
JavaSE——面相对象高级一(4/4)-继承相关的注意事项:权限修饰符、单继承、Object类、方法重写、子类访问成员的特点......
JavaSE——面相对象高级一(4/4)-继承相关的注意事项:权限修饰符、单继承、Object类、方法重写、子类访问成员的特点......
73 0