Python Django ORM与模型详解
作者:久醉绕心弦, 发布时间:2022-01-03 10:40:53
目录
一、 环境准备:
1.docker环境
2.安装mariadb数据库
二、ORM
1.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映射到本地目录testp
:设置容器的3306端口映射到主机3306端口env
:设置环境变量数据库相关信息d
:后台运行容器mariadb并返回容器idmariadb: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
执行命令后数据库生成表信息
来源:https://blog.csdn.net/weixin_42262081/article/details/121225712V


猜你喜欢
- python软件免费吗?python是免费的,是自由、开放源码的软件之一,在python官网可以免费下载,使用者可以自由地发布这个软件的拷贝
- python脚本执行的3种方法:(找到自己能够使用的方法,能用的方法就是好方法)方法一:交互模式直接执行语句交互模式下直接编写执行 Pyth
- Go微服务网关从核心原理理解网关的本质网关具备的基本功能:支持多种协议代理:tcp/http/ websocket/grpc支持多种负载均衡
- 使用df=df.values,可以把Pandas中的dataframe转成numpy中的array来源:https://blog.csdn.
- 本地一个长期更新的项目,git log突然报错:xxx@yyy:~/android/project/kernel/.git$ git log
- 1. 更新日志1.1. v1.01.1.1. 破坏性变更gorm.Open返回类型为*gorm.DB而不是gorm.DB更新只会更新更改的字
- 一、简介在这篇文章中,我们将学习Python中的高级数据结构,如堆、栈、队列、链表等,并使用Python实现常见的算法,如排序、查找等。我们
- 摘要:主要是讲解一些数据挖掘中频繁模式挖掘的Apriori算法原理应用实践当我们买东西的时候,我们会发现物品展示方式是不同,购物以后优惠券以
- 在SQL Server的查询条件中,能否在IN里面使用变量呢? 如果可以的话,有没有需要注意的地方或一些限制呢?在回答这个问题前,我们先来看
- 本文实例讲述了python使用Queue在多个子进程间交换数据的方法。分享给大家供大家参考。具体如下:这里将Queue作为中间通道进行数据传
- 任务队列主线程:正在执行的代码,会生成函数调用栈。macro-task(宏任务,新名:task)包括:script(整体代码), setTi
- 本文实例讲述了Python 类属性与实例属性,类对象与实例对象用法。分享给大家供大家参考,具体如下:demo.py(类属性,所有实例对象共用
- 错误出现情景在cmd中使用mysql命令,学生信息表添加数据。使用load data方式简单批量导入数据。准备好文本数据: xuesheng
- python共有两种浅拷贝的方法,一个是python的内置函数copy(),另一个是copy模块中的copy.copy()。python的六
- pygame如何捕捉鼠标的活动初始化参数import pygame, sysfrom pygame.locals import *def p
- 本人非计算机,亦非心理学,或者交互设计,更非设计专业出身,因此什么都是半桶水。即使如此,依然靠着兴趣寻找乐趣。对于设计,爱之,但没有受过系统
- 我们知道 Pandas 是数据科学社区中流行的 Python 包,它包含许多函数和方法来分析数据。尽管它的功能对于数据分析来说足够有效,但定
- 前言近期在刷新生产环境数据库的时候,需要更新表中的字段,如果对每条数据结果都执行一次update语句,占用的数据库资源就会很多,而且速度慢。
- 很简单,只需建立一个worksheet和Excel相关的信息就可以了具体代码见下:<%set xlApp =&nb
- 在开始之前,我们先来看看uint 与 int 的区别上面是图,下面是源码:package main import ( "fmt&q