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
执行命令后数据库生成表信息

总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!
相关文章
Pycharm中配置使用Anaconda的虚拟环境进行项目开发的图文教程
今天在一台电脑上跑环境的时候,发现已经装了Pytorch了,但是运行没有用,提示报错:OSError: [WinError 126] 找不到指定的模块,但其实cmd进入虚拟环境是可以调用torch的,故本文给大家介绍了Pycharm中配置使用Anaconda的虚拟环境进行项目开发的图文教程2024-09-09
python3.6中anaconda安装sklearn踩坑实录
这篇文章主要介绍了python3.6中anaconda安装sklearn踩坑实录,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-07-07
python网络编程学习笔记(二):socket建立网络客户端
看了这一节,突然之间对python网络编程学习笔记(1)中的一些不理解的问题有了认识,至少明白了socket是怎么回事。这里关于socket的起源等问题就不做笔记记录了,直接进入主题2014-06-06
使用virtualenv创建Python环境及PyQT5环境配置的方法
这篇文章主要介绍了使用virtualenv创建Python环境及PyQT5环境配置的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2019-09-09
Python Pillow 图像处理库详解(常用Pillow函数及其参数)
Pillow,原名PIL(Python Imaging Library),是一个功能强大的Python图像处理库,支持多种格式,提供丰富的图像操作功能,如旋转、缩放、颜色转换等,以及易于使用的API,Pillow支持广泛的图像文件格式,并提供图像过滤、绘制等功能2024-09-09


最新评论