我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ORM初探(一)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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中的常用字段

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

 

 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ORM初探(一)

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

下载Word文档

猜你喜欢

ORM初探(一)

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

HBase 监控 | HBase Metrics 初探(一)

前言:对于任意一个系统而言,做好监控都是非常重要的,HBase也不例外。经常,我们会从JMX中获取相关指标来做展示、对HBase进行监控,那这些指标是怎么生成的呢?如果你想自定义自己的监控指标又该怎么做呢?基于好奇之心和学习的目的,最近打算学习一下HBase监
HBase 监控 | HBase Metrics 初探(一)
2022-02-03

初探nodeJS

一、node概要 对nodeJS早有耳闻,但是一直迟迟没有对它下手,哈哈哈,今儿咱就来初探一下它。 nodeJS是个啥东东? nodeJS,我的理解就是可以运行在后端的JavaScript。 为什么它能够在后端运行呢? 这就得归功于V8引擎
2022-06-04

AS3初探

开发工具:FLEX BUILDER3 PRO 语言:AS 3.0  操作系统:Windows XP SP2 1.       在flex3 里新建一个AS工程取名为login22.       导入所需要的包(如果无法使用fl包,请参照我的
2023-01-31

selenium 初探

1 # -*- coding:utf-8 -*-2 3 from selenium import webdriver4 driver = webdriver.Firefox() # 打开firefox浏览器5 driver.get("ht
2023-01-30
2024-04-02

PostgreSQL 初探

2020 年 2月的总排名为第四名,关系型数据库中排名第四名。排名信息参考:DB-Engines 为了更好地应用的工作中,针对 PostgreSQL 给我造成的疑惑整理了如下内容: (1) PostgreSQL 版本之间的主要区别 (2) Postg
PostgreSQL 初探
2019-11-15

Python 初探

按照计划,今年要学习一门面向对象的语言,学习的范围锁定几门,PHP/PERL/PYTHON/RUBY,由于上半年学了bash,感觉python比较适合自己。从今天开始不定期的出一些笔记出来#! /usr/bin/python ID = ra
2023-01-31

MyBatis ORM缓存机制探讨

MyBatis ORM 提供了两级缓存机制,一级缓存是默认开启的,位于 SqlSession 会话级别,而二级缓存是可选的,位于 Application 级别。这两级缓存机制通过减少对数据库的访问次数来提高应用程序的性能。以下是 MyBat
MyBatis ORM缓存机制探讨
2024-09-16

1、python-初探

语言包括编译型语言和解释型语言编译型:全部翻译,再执行;c、c++解释型:边执行边翻译;python、php、java、c#、perl、ruby、javascript一、系统位数32位系统内存的最大寻址空间位2**32,4GB64位系统内存
2023-01-31

Python Metaclass 初探

先以一个大牛的一段关于Python Metapgramming的著名的话来做开头:Metaclasses are deeper magic than 99% of users should ever worry about. If you
2023-01-31

python unittest初探

待测试的类:class Request:    url = ""    method = ""    paras = {}    def __init__(self,url):        self.url = url        se
2023-01-31

一文初探 Goroutine 与 channel基本用法

这篇文章主要为大家介绍了一文初探 Goroutine 与 channel基本用法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-02-02

Android Context初探

1.背景 作为一个Android新手,每次看到使用Context作为参数时,都有点焦虑,有时候传this就可以,有时候又不行,不知道为什么可以,为什么又不可以,根本原因还是对Context是一知半解,偏偏很多地方用到Context作为参数,
2022-06-06

RN 技术探索:Hermes Engine 初探

桔妹导读:自从 Google 的 Flutter 发布之后,Facebook 对 React-Native 的迭代开始快了起来,优化 React-Native 的性能表现,避免被 Flutter 比下去。最近一个比较大的动作是开源了一个 J
2023-06-03

Golang初探:探索之路开始

【Golang简介:一切从这里开始】Golang,也被称为Go语言,是一种由Google开发的开源编程语言。自2007年开始设计,2009年正式发布,Golang以其出色的性能、简洁的语法和强大的工具链迅速赢得开发者们的青睐。作为一门静态
Golang初探:探索之路开始
2024-02-24

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录