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

Python Django ORM与模型详解

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

Python Django ORM与模型详解

一、 环境准备:

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 

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

在这里插入图片描述

总结

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

免责声明:

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

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

Python Django ORM与模型详解

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

下载Word文档

猜你喜欢

Django之模型---ORM简介

ORM,是“对象-关系-映射”的简称,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的工作量,不需要面对因数据库变更而导致的无效劳动。创建项目,在mode
2023-01-30

python-django 模型mode

Django通过model不可以创建数据库,但可以创建数据库表,一下是创建表的字段以及表字段的参数。一、字段1、models.AutoField  自增列 = int(11)  如果没有的话,默认会生成一个名称为 id 的列,如果要显示的自
2023-01-31

NodeJSExpress使用ORM模型访问关系型数据库流程详解

这篇文章主要介绍了NodeJSExpress使用ORM模型访问关系型数据库流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2023-01-10

Spring之ORM模块代码详解

Spring框架七大模块简单介绍Spring中MVC模块代码详解ORM模块对Hibernate、JDO、TopLinkiBatis等ORM框架提供支持ORM模块依赖于dom4j.jar、antlr.jar等包在Spring里,Hiberna
2023-05-30

使用Python怎么实现一个ORM模型

本篇文章为大家展示了使用Python怎么实现一个ORM模型,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。元类对于元类,我的理解其实也便较浅,大概是这个意思所有的类都是使用元类来进行创建的,而所有的类
2023-06-15

Python Django的模型建立与操作方法是什么

本文小编为大家详细介绍“Python Django的模型建立与操作方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python Django的模型建立与操作方法是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习
2023-07-04

怎么使用Python描述器实现ORM模型

本文小编为大家详细介绍“怎么使用Python描述器实现ORM模型”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么使用Python描述器实现ORM模型”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。访问或者修改描
2023-06-29

编程热搜

  • 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动态编译

目录