Python Django ORM与模型详解

作者:久醉绕心弦, 时间:2022-01-03 10:40:53 

目录
  • 一、 环境准备:

    • 1.docker环境

    • 2.安装mariadb数据库

  • 二、ORM

    • 1.ORM简介

    • 2.django配置数据库

      • 第一种方式:

      • 第二种方式:

  • 三、模型设计

    • 1.创建模型

      • 2.表关系

      • 四、模型应用

        • 第一步:

          • 第二步:

          • 总结

            一、 环境准备:

            1.docker环境

            docker环境如下:

            Python Django ORM与模型详解

            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:启动最新的镜像版本

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

            Python Django ORM与模型详解

            navicat连接测试:

            Python Django ORM与模型详解

            创建好的数据库:

            Python Django ORM与模型详解

            二、ORM

            1.ORM简介

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

            Python Django ORM与模型详解

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

            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模块。

            Python Django ORM与模型详解

            创建一个学生表为例:


            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 Django ORM与模型详解

            第一步:


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

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

            Python Django ORM与模型详解

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


            python manage.py sqlmigrate projects 0001

            Python Django ORM与模型详解

            第二步:

            执行迁移


            python manage.py migrate

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

            Python Django ORM与模型详解

            来源:https://blog.csdn.net/weixin_42262081/article/details/121225712V

            标签:Python,Django,ORM,模型
            0
            投稿

            猜你喜欢

          • 利用Python找出删除自己微信的好友并将他们自动化删除

            2022-05-23 00:10:13
          • python读取raw binary图片并提取统计信息的实例

            2023-09-22 12:46:35
          • 用实例分析如何整理SQL Server输入数据

            2009-01-20 15:16:00
          • 使用python3调用wxpy模块监控linux日志并定时发送消息给群组或好友

            2022-05-12 03:35:29
          • PyQt5实现简易计算器

            2022-12-14 02:12:38
          • SQL SERVER 2014 安装图解教程(含SQL SERVER 2014下载)

            2024-01-16 05:16:07
          • javascript自动生成包含数字与字符的随机字符串

            2024-04-17 09:45:29
          • Python内置函数Type()函数一个有趣的用法

            2023-01-16 06:30:44
          • PHP策略模式定义与用法示例

            2024-05-13 09:21:04
          • Python PyInstaller库基本使用方法分析

            2022-03-19 16:29:46
          • python中break、continue 、exit() 、pass终止循环的区别详解

            2023-03-08 15:59:52
          • 浅谈numpy数组中冒号和负号的含义

            2023-09-02 01:03:04
          • 基于Python中求和函数sum的用法详解

            2022-12-05 23:26:18
          • Python定义一个函数的方法

            2023-09-18 17:28:09
          • PyTorch一小时掌握之图像识别实战篇

            2023-01-28 00:08:01
          • Go pprof内存指标含义备忘录及案例分析

            2024-05-21 10:19:46
          • Python全局变量关键字global的简单使用

            2022-01-29 11:03:49
          • Python+腾讯云服务器实现每日自动健康打卡

            2023-08-18 00:22:44
          • python直接获取API传递回来的参数方法

            2023-11-10 18:01:59
          • 在python 中实现运行多条shell命令

            2023-07-30 10:40:11
          • asp之家 网络编程 m.aspxhome.com