iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python Django ORM与模型详解
  • 923
分享到

Python Django ORM与模型详解

2024-04-02 19:04:59 923人浏览 薄情痞子

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

摘要

目录一、 环境准备:1.Docker环境2.安装mariadb数据库二、ORM1.ORM简介2.Django配置数据库第一种方式:第二种方式:三、模型设计1.创建模型2.表关系四、模

一、 环境准备:

1.docker环境

docker环境如下:

在这里插入图片描述

2.安装mariadb数据库

运行如下命令

docker run -d --name [容器名称] -v test:/var/lib/Mysql -p 3306:3306 --env MARIADB_USER=[用户名] --env MARIADB_PASSWord=[用户密码] --env MARIADB_ROOT_PASSWORD=[root用户密码] --env MARIADB_DATABASE=[库名] mariadb:latest

参数详解:

  • name:启动容器设置容器名称
  • v:设置容器目录/var/lib/mysql映射到本地目录test
  • p:设置容器的3306端口映射到主机3306端口
  • env:设置环境变量数据库相关信息
  • d:后台运行容器mariadb并返回容器id
  • mariadb:latest:启动最新的镜像版本

等待命令运行结束后可以查看启动的容器:

在这里插入图片描述

navicat连接测试

在这里插入图片描述

创建好的数据库:

在这里插入图片描述

二、ORM

1.ORM简介

orm(object relational mapping )对象关系映射,用面向对象的方式,描述数据库,操作数据库,达到不编写sql语句就可以对数据库进行增删改查的一种技术,但是orm底层还是通过原生sql去实现的。

在这里插入图片描述

上图所示,而模型的对象就相当于表中数据。

2.djanGo配置数据库

在配置数据库前需要安装mysql驱动,此环境用的是mariadb数据库,安装驱动:


pip install mysqlclient

安装完成后可以通过如下两种方式添加配置信息:

第一种方式:

直接在settings.py中配置:


DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': '库名',
        'USER': '用户名',
        'PASSWORD': '用户密码',
        'HOST': '域名',
        'PORT': '端口号'
    }
}

第二种方式:

添加配置文件:

根目录下新建配置文件目录,并创建配置文件填写数据库信息:


# my.cnf
[client]
database = 库名
user = 用户名
password = 用户密码
host = 域名
port = 端口

settings.py 中


DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'OPTIONS': {
            'read_default_file': str(BASE_DIR / [配置文件路径])
        }
    }
}

三、模型设计

django中的模型准确且唯一的描述了数据,每个模型都是一个python类,继承django.db.models.Model类。模型类中的每个熟悉为数据库中的字段,diango提供了一个自动生成访问数据库的api

1.创建模型

每个应用的模型都会被编写到models.py文件下,如图,创建项目时会自动引入models模块。

在这里插入图片描述

创建一个学生表为例:


from django.db import models


# Create your models here.

class Stutent(models.Model):
    """
    学生表
    """
    name = models.CharField('学生姓名', max_length=200, unique=True, help_text='学生姓名')
    sex = models.CharField('性别', max_length=48, help_text='性别')
    hobby = models.CharField('爱好', max_length=200, null=True, blank=True, help_text='兴趣爱好')
    create_time = models.DateTimeField('创建时间', auto_now_add=True, help_text='创建时间')

    class Meta:
        """
        元数据,
        """
        db_table = 'student'  # 指定当前模型创建的表明,不写默认当前的模型名Student
        verbose_name = '学生信息表'  # 注释
        verbose_name_plural = verbose_name  # 指定为复数
        ordering = ['-create_time'] # 使用创建时间倒序排序,不加-为正序


CharField   字符类型代表数据库中的VARCHAR
DateTimeField  日期字段类型
IntegerField  整数字段类型
FloatField  数值字段类型
DecimalField  高精度字段类型
max_length  数据的长度限制,当使用CharField时,此字段必传,否则报错
unique 为True  代表字段唯一
null 为True  代表可以为空
blank 为True  不校验此字段
SmallIntegerField 小整数
auto_now_add  结合DateTimeField 使用,默认为当前时间

2.表关系

Django中的表关系可以通过下面方式表达


一对多关系:models.ForeignKey()        在多的一方创建
多对多关系:models.ManyToManyField()   随便表创建
一对一关系:models.OneToOneField()     随便表创建

继续创建学生班级模型:


class Class(models.Model):
    name = models.CharField('班级名称', max_length=200)
    class_num = models.IntegerField('班级', unique=True, help_text='班级number')
    student = models.ForeignKey(Stutent, on_delete=models.CASCADE)  # 设置外键,on_delete级联删除

四、模型应用

数据库迁移前需要将应用在settings文件的INSTALLED_APPS中去注册

在这里插入图片描述

第一步:


生成数据迁移记录
Python manage.py makemigrations projects

运行命令后会在migrations目录下生成迁移记录文件,id会自动创建,如下:

在这里插入图片描述

django底层是用sql实现的,查看执行迁移生成的sql命令如下:


python manage.py sqlmigrate projects 0001

在这里插入图片描述

第二步:

执行迁移


python manage.py migrate 

执行命令后数据库生成表信息

在这里插入图片描述

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!

--结束END--

本文标题: Python Django ORM与模型详解

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

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

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

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

下载Word文档
猜你喜欢
  • Python Django ORM与模型详解
    目录一、 环境准备:1.docker环境2.安装mariadb数据库二、ORM1.ORM简介2.django配置数据库第一种方式:第二种方式:三、模型设计1.创建模型2.表关系四、模...
    99+
    2024-04-02
  • Python Django模型详解
    目录Django模型字段类型字段类型的参数外键总结Django模型 Django的模型定义在models.py文件中。模型是MVT中的M,也相当于MVC中的M。 在Django中,模...
    99+
    2024-04-02
  • Django之模型---ORM简介
      ORM,是“对象-关系-映射”的简称,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的工作量,不需要面对因数据库变更而导致的无效劳动。 创建项...
    99+
    2023-01-30
    模型 简介 Django
  • Python使用描述器实现ORM模型的方法详解
    目录1.__set__方法:设置属性 2.__get__方法:访问属性3.__delete__方法:删除属性 4.描述器实现ORM模型: 总结访问或者修...
    99+
    2024-04-02
  • python-django 模型mode
    Django通过model不可以创建数据库,但可以创建数据库表,一下是创建表的字段以及表字段的参数。一、字段1、models.AutoField  自增列 = int(11)  如果没有的话,默认会生成一个名称为 id 的列,如果要显示的自...
    99+
    2023-01-31
    模型 python django
  • Pycharm开发Django项目创建ORM模型的问题
    随着项目越来越大,采用写原生SQL的方式在代码中会出现大量的SQL语句,那么问题就出现了: SQL语句重复利用率不高,越复杂的SQL语句条件越多,代码越长。会出现很多相近的...
    99+
    2024-04-02
  • Python Django模板系统详解
    目录设置模板路径模板变量引用静态文件总结设置模板路径 在django项目下创建templats文件来存放html文件 为了减少模板加载调用过程及模板本身的冗余代码,Django ...
    99+
    2024-04-02
  • Python Django 后台管理之后台模型属性详解
    目录十八、Django 后台模型属性篇18.1 在 admin 中注册模型18.2 Model.Admin 类提供的属性18.2.1 date_hierarchy18.2.2 act...
    99+
    2024-04-02
  • NodeJSExpress使用ORM模型访问关系型数据库流程详解
    目录一、ORM模型二、在Node中ORM的实现一、ORM模型 设计思想,主要目的是简化计算机程序访问数据库 1、ORM:对象关系模型(对象关系映射) Object Releastio...
    99+
    2023-01-10
    NodeJS Express访问关系型数据库 NodeJS ORM模型访问关系型数据库
  • Spring之ORM模块代码详解
    Spring框架七大模块简单介绍Spring中MVC模块代码详解ORM模块对Hibernate、JDO、TopLinkiBatis等ORM框架提供支持ORM模块依赖于dom4j.jar、antlr.jar等包在Spring里,Hiberna...
    99+
    2023-05-30
    spring orm 框架
  • Django中ORM基本应用与原理解析
    目录1.ORM构建数据表2.数据迁移3.Model相关的概念与使用方法Model的组成部分Meta元数据类属性说明Field的通用字段选项基础字段类型关系字段类型多对一一对一多对多关...
    99+
    2024-04-02
  • Python Django框架设计模式详解
    目录MVC设计模式MTV设计模式总结MVC设计模式 MVC (Model-View-Controller) 是软件工程中常用的软件架构模式,它是一种分离业务逻辑与显示界面的设计方法。...
    99+
    2024-04-02
  • 使用Python怎么实现一个ORM模型
    本篇文章为大家展示了使用Python怎么实现一个ORM模型,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。元类对于元类,我的理解其实也便较浅,大概是这个意思所有的类都是使用元类来进行创建的,而所有的类...
    99+
    2023-06-15
  • django中模板继承与ModelForm实例详解
    目录模板的继承form和ModelForm使用方法总结模板的继承 完美在写html的时候会发现,自己多个html文件中又好多东西是一样的,包括静插件的引入 还有有些简单的css样式都...
    99+
    2024-04-02
  • Django视图层与模板层实例详解
    目录theme: channing-cyan网页伪静态视图层1.视图函数的返回值问题2.视图函数返回json格式数据3.form表单携带文件数据4.FBV与CBV5.CBV源码分析模...
    99+
    2024-04-02
  • Django模板继承与模板的导入实例详解
    目录一:模版的继承1.什么是模板继承2.使用继承流程原理3.模板继承语法二:模板的继承使用1.案例需求2.总结模板继承三:模版的导入1.模板导入2.模板导入格式3.模板导入使用4.使...
    99+
    2024-04-02
  • 怎么使用Python描述器实现ORM模型
    本文小编为大家详细介绍“怎么使用Python描述器实现ORM模型”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么使用Python描述器实现ORM模型”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。访问或者修改描...
    99+
    2023-06-29
  • python利用元类和描述器实现ORM模型的详细步骤
    ORM模型: ORM模型对于后端开发来说肯定是不陌生的,包括很多后端框架比如django,现在都自带这个模型了 ORM(Object Relational Mapping)对象关系映...
    99+
    2024-04-02
  • Python Django的模型建立与操作方法是什么
    本文小编为大家详细介绍“Python Django的模型建立与操作方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python Django的模型建立与操作方法是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习...
    99+
    2023-07-04
  • Django学习之静态文件与模板详解
    目录前言模板存放目录模板调用模板语法数据传递元素引用 for语句 if语句静态文件存放目录文件调用总结前言 我们已经配置完Django,今天就来学学静态文件与模板...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作