Python Django ORM与模型详解

 更新时间:2021年11月11日 08:45:38   作者:久醉绕心弦,  
这篇文章主要介绍了django的ORM与模型的实现原理,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧v

一、 环境准备:

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 

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

在这里插入图片描述

总结

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

相关文章

  • Python 结合opencv实现图片截取和拼接代码实践

    Python 结合opencv实现图片截取和拼接代码实践

    这篇文章主要介绍了Python 结合opencv实现图片截取和拼接代码实践,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • Python工厂函数用法实例分析

    Python工厂函数用法实例分析

    这篇文章主要介绍了Python工厂函数用法,结合实例形式分析了Python工厂函数的概念、功能、使用方法及相关注意事项,需要的朋友可以参考下
    2018-05-05
  • Python实现PDF转为Excel的示例讲解

    Python实现PDF转为Excel的示例讲解

    这篇文章主要为大家详细介绍了在Python中将PDF表格转换为Excel文件的解决方案,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-11-11
  • Python使用Turtle模块绘制国旗的方法示例

    Python使用Turtle模块绘制国旗的方法示例

    这篇文章主要给大家介绍了关于Python使用Turtle模块绘制国旗的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • Python PyQt5学习之样式设置详解

    Python PyQt5学习之样式设置详解

    这篇文章主要为大家详细介绍了Python PyQt5中样式设置的相关资料,例如为标签添加背景图片、为按钮添加背景图片、设置窗口透明等,感兴趣的可以学习一下
    2022-12-12
  • python可视化分析绘制带趋势线的散点图和边缘直方图

    python可视化分析绘制带趋势线的散点图和边缘直方图

    这篇文章主要介绍了python可视化分析绘制带趋势线的散点图和边缘直方图,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-06-06
  • Pycharm新建模板默认添加个人信息的实例

    Pycharm新建模板默认添加个人信息的实例

    今天小编就为大家分享一篇Pycharm新建模板默认添加个人信息的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-07-07
  • Python使用CuPy模块实现高效数值计算

    Python使用CuPy模块实现高效数值计算

    CuPy是一个基于Python的GPU加速计算库,它提供了与NumPy相似的接口,可以在GPU上进行高效的数值计算,本文主要介绍一下CuPy的应用场景,并给出一些Python代码案例,需要的可以参考下
    2024-02-02
  • 解析python 中/ 和 % 和 //(地板除)

    解析python 中/ 和 % 和 //(地板除)

    这篇文章主要介绍了python 中/ 和 % 和 //(地板除)的区别及简介,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2020-06-06
  • 使用Python操作Redis所有数据类型的方法

    使用Python操作Redis所有数据类型的方法

    当今互联网时代,数据处理已经成为了一个非常重要的任务,而Redis作为一款高性能的NoSQL数据库,越来越受到了广大开发者的喜爱,本篇博客将介绍如何使用Python操作Redis的所有类型,以及一些高级用法,需要的朋友可以参考下
    2023-11-11

最新评论