广告
返回顶部
首页 > 资讯 > 后端开发 > Python >ORM初探(一)
  • 315
分享到

ORM初探(一)

ORM 2023-01-31 00:01:44 315人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

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

Object Relational Mapping(ORM):

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

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

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

ORM的优势:

  • ORM解决的主要问题是对象和关系的映射。它通常将一个类和一张表一一对应,类的每个实例对应表中的一条记录,类的每个属性对应表中的每个字段。
  • ORM提供了对数据库的映射,不用直接编写sql代码,只需操作对象就能对数据库操作数据。
  • 软件开发人员专注于业务逻辑的处理,提高了开发效率。

ORM的劣势:

  • ORM的缺点是会在一定程度上牺牲程序的执行效率。
  • ORM的操作是有限的,也就是ORM定义好的操作是可以完成的,一些复杂的查询操作是完成不了。
  • ORM用多了SQL语句便会淡忘了,关于数据库相关技能也就淡淡退化了。

Django项目中使用Mysql数据库:

1、创建DjanGo项目:

创建好项目后生成如下目录结构:先简单认识几个文件。

2、ORM只能操作数据库中的表,不能操作数据库,所以我们需要到mysql数据库中手动创建数据库orm_practice。

3、创建好数据库后到Django项目中的设置文件中设置连接数据库,默认配置如下:

 我们重新修改配置文件,修改后的配置看起来像下面这个样子:

4、在orm_practice项目下的同名文件夹下找到__init__.py文件引用pymysql模块,告诉Django使用该模块操作数据库。

import pymysql

pymysql.install_as_MySQLdb()

 

5、到app目录下的models.py中创建出版社Publishing,书籍Books,作者Author三张表,models.py中的每个类就是一张表,类中的属性对应表的字段。

表的结构:一个出版社可以出版多本书,一本书可以由多个作者共同编写,同时一个作者也可以写多本书。最终表的关系如下所示:

from django.db import models

# Create your models here.
class Publishing(models.Model):
    pid = models.AutoField(primary_key=True)
    name = models.CharField(max_length=30)

class Books(models.Model):
    bid = models.AutoField(primary_key=True)
    name = models.CharField(max_length=30)
    pid = models.ForeignKey("Publishing",on_delete=models.CASCADE)

class Author(models.Model):
    aid = models.AutoField(primary_key=True)
    name = models.CharField(max_length=30)
    books = models.ManyToManyField("Books")
models.py

 

6、创建表后(也就是在models.py中的类),需要到终端中执行两条命令。

python37 manage.py makemigrations   #  生成迁移文件
python37 manage.py migrate          # 执行数据迁移

 

7、使用PyCharm带的mysql插件查看数据库结构,首先添加数据库管理器:

选择mysql后会弹出如下配置对话框:

配置成功后,使用mysql管理器对数据库进行操作。

如果觉得图形界面不习惯,也可以使用mysql命令行进行操作,这里主要对app_author、app_author_books、app_books、app_publishing这几张表进行操作。

8、向表app_author、app_author_books、app_books、app_publishing添加数据

8.1出版社表app_publishing中添加字段信息。

8.2书籍表app_books添加字段信息。

8.3作者表app_author添加字段:

8.4在书籍和作者关系表中app_author_books添加字段

到此建表完成。

我们在models.py中其实只创建了三个类Publishing、Books、Author,正常来说也就是创建三张表,但是这里生成了四张表多一个app_author_books,这张表是由作者表中多对多关系Django为我们自动创建的。

#############################################################################################

                                                       好了这里先停一下,下节来看一下ORM中的常用字段

#############################################################################################

 

 

--结束END--

本文标题: ORM初探(一)

本文链接: https://www.lsjlt.com/news/181767.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • ORM初探(一)
    Object Relational Mapping(ORM): 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。 简单的说,ORM是通过使用描...
    99+
    2023-01-31
    ORM
  • HBase 监控 | HBase Metrics 初探(一)
    前言:对于任意一个系统而言,做好监控都是非常重要的,HBase也不例外。经常,我们会从JMX中获取相关指标来做展示、对HBase进行监控,那这些指标是怎么生成的呢?如果你想自定义自己的监控指标又该怎么做呢?基于好奇之心和学习的目...
    99+
    2022-02-03
    HBase 监控 | HBase Metrics 初探(一)
  • selenium 初探
    1 # -*- coding:utf-8 -*- 2 3 from selenium import webdriver 4 driver = webdriver.Firefox() # 打开firefox浏览器 5 driver.g...
    99+
    2023-01-30
    selenium
  • Python 初探
     按照计划,今年要学习一门面向对象的语言,学习的范围锁定几门,PHP/PERL/PYTHON/RUBY,由于上半年学了bash,感觉python比较适合自己。从今天开始不定期的出一些笔记出来 #! /usr/bin/python   ID...
    99+
    2023-01-31
    Python
  • PostgreSQL 初探
    2020 年 2月的总排名为第四名,关系型数据库中排名第四名。排名信息参考:DB-Engines 为了更好地应用的工作中,针对 PostgreSQL 给我造成的疑惑整理了如下内容: (1) PostgreSQL 版本之间的...
    99+
    2019-11-15
    PostgreSQL 初探
  • 初探nodeJS
    一、node概要 对nodeJS早有耳闻,但是一直迟迟没有对它下手,哈哈哈,今儿咱就来初探一下它。 nodeJS是个啥东东? nodeJS,我的理解就是可以运行在后端的JavaScript。 为什么它能够在...
    99+
    2022-06-04
    nodeJS
  • Redis初探
       大概在2010年的时候,有一次和一个同事聊天,那个时候知道了Redis,对于技术的追随至今,还没有下载一个Redis版本玩玩,   只有1万多行代码,以性能惊人...
    99+
    2022-10-18
  • AS3初探
    开发工具:FLEX BUILDER3 PRO   语言:AS 3.0   操作系统:Windows XP SP2   1.       在flex3 里新建一个AS工程取名为lo...
    99+
    2023-01-31
  • 一文初探golang的方法特性
    随着云计算和大数据的发展,越来越多的开发者开始使用Golang这门语言进行开发。Golang是一门开源语言,具有运行速度快、内存占用少、并发能力强等优点。在此,本文将介绍Golang中的方法特性。Golang中的方法是一种特殊的函数,即re...
    99+
    2023-05-14
  • Android Context初探
    1.背景 作为一个Android新手,每次看到使用Context作为参数时,都有点焦虑,有时候传this就可以,有时候又不行,不知道为什么可以,...
    99+
    2022-06-06
    context Android
  • Oracle Wallet初探
    Oracle Wallet初探1.  什么是WalletA datastructure used to store and manage security credentials for...
    99+
    2022-10-18
  • 1、python-初探
    语言包括编译型语言和解释型语言编译型:全部翻译,再执行;c、c++解释型:边执行边翻译;python、php、java、c#、perl、ruby、javascript 一、系统位数32位系统内存的最大寻址空间位2**32,4GB64位系统...
    99+
    2023-01-31
    python
  • Python Metaclass 初探
    先以一个大牛的一段关于Python Metapgramming的著名的话来做开头: Metaclasses are deeper magic than 99% of users should ever worry about. If yo...
    99+
    2023-01-31
    Python Metaclass
  • python unittest初探
    待测试的类:class Request:    url = ""    method = ""    paras = {}    def __init__(self,url):        self.url = url        se...
    99+
    2023-01-31
    python unittest
  • 一文初探 Goroutine 与 channel基本用法
    目录前言Goroutine基本用法channelchannel 的基本操作带缓冲 channel 与无缓冲 channel声明 channel 的只发送类型和只接收类型channel...
    99+
    2023-02-02
    Goroutine channel基本用法 Goroutine channel
  • Javascript之JSBridge初探
    目录JSBridge 的起源JSBridge 的双向通信原理JS 调用 NativeNative 调用 JSJSBridge 的使用总结JSBridge 的起源 近些年,移动端普及化...
    99+
    2022-11-12
  • python与mongodb初探
    python连接mongodb:这个需要安装一个pymongo包。不知道是什么原因我安装不上去,总是提示我找不到安装的python后来安装了pycharm借助这个IDE安装上了pymongo然后就是在pyc...
    99+
    2022-10-18
  • RN 技术探索:Hermes Engine 初探
    桔妹导读:自从 Google 的 Flutter 发布之后,Facebook 对 React-Native 的迭代开始快了起来,优化 React-Native 的性能表现,避免被 Flutter 比下去。最近一个比较大的动作是开源了一个 J...
    99+
    2023-06-03
  • 一文初探Go语言中的reflect反射包
    目录reflect 反射包TypeOf(i) 和 ValueOf(i)案例1:获取变量的类别和类型信息案例2:修改基本数据类型变量的值案例3:通过反射获取结构体的字段名、字段类型和字...
    99+
    2022-12-08
    Go语言reflect反射包 Go语言reflect Go语言 反射包
  • 一个基于vue3+ts+vite项目搭建初探
    目录前言环境准备使用Vite快捷搭建使用npm使用yarn安装依赖启动项目修改vite配置文件找到根目录vite.config.ts文件打开集成路由集成Vuex添加element u...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作