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   字符类型代表数据库中的VARCHARDateTimeField  日期字段类型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 

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

(0)

相关推荐

  • django中ORM模型常用的字段的使用方法

    与数据类型相关的字段 CharField         作用:字符串字段, 用于较短的字符串.         参数:CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层限制该字段所允许的最大字符数. IntegerField        作用:用于保存一个整数. CommaSeparatedIntegerField         作用:用于存放逗号分隔的整数值. 类似 CharField, 必须要有maxlength参数. FloatField

  • django框架面向对象ORM模型继承用法实例分析

    本文实例讲述了django框架面向对象ORM模型继承用法.分享给大家供大家参考,具体如下: Django ORM对模型继承的支持,将python面向对象的编程方法与数据库面向关系表的数据结构结合的很巧妙.支持三种风格的模型继承. 1.抽象类继承:父类继承自models.Model,但不会在底层数据库中生成相应的数据表,父类的属性列存储在其子类的数据表中. 2.多表继承:多表继承的每个模型类都在底层数据库中生成相应的数据表管理数据. 3.代理模型继承:父类用于在底层数据库中管理数据表,而子类不定义

  • 简单了解django orm中介模型

    什么是中介模型 中介模型针对的是ManyToMany(多对多)的时候第三张表的问题, 中介模型其实指的就是我们不通过Django创建第三张表,如果自己不创建第三张表,而是由django给我们创建,那就不存在中介模型 中介模型示例 普通的ManyToMany示例 class Book(models.Model): title = models.CharField(max_length=32) authors = models.ManyToManyField(to='Author') class A

  • Pycharm开发Django项目创建ORM模型的问题

    随着项目越来越大,采用写原生SQL的方式在代码中会出现大量的SQL语句,那么问题就出现了: SQL语句重复利用率不高,越复杂的SQL语句条件越多,代码越长.会出现很多相近的SQL语句. 很多SQL语句是在业务逻辑中拼出来的,如果有数据库需要更改,就要去修改这些逻辑,这会很容易漏掉对某些SQL语句的修改. 写SQL时容易忽略web安全问题,给未来造成隐患.SQL注入. ORM,全称Object Relational Mapping,中文叫做对象关系映射,通过ORM我们可以通过类的方式去操作数据库,

  • 在脚本中单独使用django的ORM模型详解

    有时候在测试django中一些模块时,不想重新跑一整个django项目,只想跑单个文件,正好写在if __name__ == '__main__': 这样也不会打扰到正常的代码逻辑 方法 正常方法 大家都知道的方法就是'python manage.py shell',当然我知道这可能不是你需要的: 更好用的方法 在脚本中import模型前调用下面几行即可: import os, sys BASE_DIR = os.path.dirname(os.path.abspath(__file__)) #

  • 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=[库名] mariad

  • 搭建python django虚拟环境完整步骤详解

    一.建立虚拟环境 pip install virtualenv 要使用Django,首先要建立一个虚拟工作环境.我们先为项目建立一个文件夹learn,在文件夹中打开命令行(shift+右击),来建立另一个虚拟环境. 如果使用的是python 3,可使用如下命令来创建: python -m venv l_env 这里运行模块venv,用它来创建一个名为l_env的虚拟环境,此时learn文件夹中会多出来一个l_env的文件夹. 如果上述成功了,则跳转到三.激活虚拟环境,否则跳转二.安装virtua

  • python多线程抽象编程模型详解

    最近需要完成一个多线程下载的工具,对其中的多线程下载进行了一个抽象,可以对所有需要使用到多线程编程的地方统一使用这个模型来进行编写. 主要结构: 1.基于Queue标准库实现了一个类似线程池的工具,用户指定提交任务线程submitter与工作线程worker数目,所有线程分别设置为后台运行,提供等待线程运行完成的接口. 2.所有需要完成的任务抽象成task,提供单独的无参数调用方式,供worker线程调用:task以生成器的方式作为参数提供,供submitter调用. 3.所有需要进行线程交互的

  • Python中函数参数匹配模型详解

    当我们的函数接收参数为任意个,或者不能确定参数个数时,我们,可以利用 * 来定义任意数目的参数,这个函数调用时,其所有不匹配的位置参数会被赋值为元组,我们可以在函数利用循环或索引进行使用 def f(*args): # 直接打印元组参数 print(args) print('-'*20) # 循环打印元组参数 [print(i) for i in args] ... # 传递一个参数 f(1) print('='*20) # 传递5个参数 f(1, 2, 3, 4, 5) 示例结果: (1,)

  • Python之两种模式的生产者消费者模型详解

    第一种使用queue队列实现: #生产者消费者模型 其实服务器集群就是这个模型 # 这里介绍的是非yield方法实现过程 import threading,time import queue q = queue.Queue(maxsize=10) def Producer(anme): # for i in range(10): # q.put('骨头%s'%i) count = 1 while True: q.put('骨头%s'%count) print('生产了骨头',count) cou

  • python多进程中的生产者和消费者模型详解

    目录 Python生产者消费者模型 一.消费模式 二.传输原理 三.实现方式 Python生产者消费者模型 一.消费模式 生产者消费者模式 是Controlnet网络中特有的一种传输数据的模式.用于两个CPU之间传输数据,即使是不同类型同一厂家的CPU也可以通过设置来使用. 二.传输原理 类似与点对点传送,又略有不同,一个生产者可以对应N个消费者,但是一个消费者只能对应一个生产者: 每个生产者消费者对应一个地址,占一个网络节点,属于预定性数据,在网络中优先级最高: 此模式如果在网络中设置过多会影

  • Django分页器的用法详解

    Django是一个大而全的框架.需要明确的是,传参进行分页获取分页后的数据,一般都是通过向服务器发送get请求的方式实现的,在向后端服务发送查看数据的同时可以携带一个或多个参数并发送get请求来实现分页查看功能 1.准备基础数据 设计表模型 为了体现分页的效果,需要先创建一个表并准备较多数据,模型如下 from django.db import models # Create your models here. class Book(models.Model): title = models.C

  • Python探索之ModelForm代码详解

    这是一个神奇的组件,通过名字我们可以看出来,这个组件的功能就是把model和form组合起来,对,你没猜错,相信自己的英语水平. 先来一个简单的例子来看一下这个东西怎么用: 比如我们的数据库中有这样一张学生表,字段有姓名,年龄,爱好,邮箱,电话,住址,注册时间等等一大堆信息,现在让你写一个创建学生的页面,你的后台应该怎么写呢? 首先我们会在前端一个一个罗列出这些字段,让用户去填写,然后我们从后天一个一个接收用户的输入,创建一个新的学生对象,保存 其实,重点不是这些,而是合法性验证,我们需要在前端

  • BootStrap扔进Django里的方法详解

    因为django的版本差异化比较大,所以以下配置仅供学习参考. D:\www\mysite>python --version Python 2.7.5 >>> print django.__version__ 1.9.4 本记录不作细说,主要配置过程如下: 1.settings.py最后一段,关于静态文件的配置 # Static files (CSS, JavaScript, Images) # https://docs.djangoproject.com/en/1.9/howto

随机推荐