zoukankan      html  css  js  c++  java
  • Django中的Object Relational Mapping(ORM)

    ORM 介绍

    ORM 概念

    对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。

    简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据库中。

    ORM在业务逻辑层和数据库层之间充当了桥梁的作用。

    ORM 由来

    字母O起源于"对象"(Object),而R则来自于"关系"(Relational)。

    几乎所有的软件开发过程中都会涉及到对象和关系数据库。在用户层面和业务逻辑层面,我们是面向对象的。当对象的信息发生变化的时候,我们就需要把对象的信息保存在关系数据库中。

    按照之前的方式来进行开发就会出现程序员会在自己的业务逻辑代码中夹杂很多SQL语句用来增加、读取、修改、删除相关数据,而这些代码通常都是重复的。

    ORM 优势

    ORM解决的主要问题是对象和关系的映射。它通常把一个类和一个表一一对应,类的每个实例对应表中的一条记录,类的每个属性对应表中的每个字段。 

    ORM提供了对数据库的映射,不用直接编写SQL代码,只需像操作对象一样从数据库操作数据。

    让软件开发人员专注于业务逻辑的处理,提高了开发效率。

    ORM 劣势

    ORM的缺点是会在一定程度上牺牲程序的执行效率。

    ORM用多了SQL语句就不会写了,关系数据库相关技能退化...

    ORM 总结

    ORM只是一种工具,工具确实能解决一些重复,简单的劳动。这是不可否认的。

    但我们不能指望某个工具能一劳永逸地解决所有问题,一些特殊问题还是需要特殊处理的。

    但是在整个软件开发过程中需要特殊处理的情况应该都是很少的,否则所谓的工具也就失去了它存在的意义。

    Django中的ORM

    Django项目中使用MySQL数据库

    1. 在Django项目的settings.py文件中,配置数据库连接信息:

    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',    # 链接数据库类型
            'NAME': 'orm',    # 数据库名
            'HOST': '127.0.0.1',    # 数据库主机地址
            'PORT': 3306,    # 数据库端口号
            'USER': 'root',    # 用户名
            'PASSWORD': '',    # 密码
        }
    }

    2. 在Django项目的settings.py文件同目录下的__init__.py文件中,告诉Django使用pymysql模块连接MySQL数据库:

    import pymysql
    
    
    pymysql.install_as_MySQLdb()

    Model

    在Django中model是数据的单一、明确的信息来源。它包含了存储的数据的重要字段和行为。

    通常,一个模型(model)映射到一个数据库表. 

    基本情况:

    • 每个模型都是一个Python类,它是django.db.models.Model的子类。
    • 模型的每个属性都代表一个数据库字段。
    • Django为您提供了一个自动生成的数据库访问API,详见官方文档链接

     

    详情见:  Django官网文档

  • 相关阅读:
    ASP字符串16进制互转
    LINQ Dictionary加速查询(TryGetValue)
    ASP中将UTF8格式的URL进行解码。函数
    C# 保护进程不被结束(源代码)防任务管理器结束进程
    用WebBrowser做web 打印时的权限不足。。。。
    .net 2.0 中 ‘注册为 allowDefinition='MachineToApplication' 的节是错误的’
    sql 2005 中分页
    BitComet web 插件和 flash get web 插件 对脚本的影响
    同时使用 C# and VB.NET 在 .net 2.0 中
    用触发器实现主从表关系(主表更改从表更改 )
  • 原文地址:https://www.cnblogs.com/lpgit/p/10946172.html
Copyright © 2011-2022 走看看