Django操作数据库

devtools/2024/10/22 0:34:12/

Django操作数据库

  • 1、ORM框架
  • 2、ORM-创建数据库
  • 3、ORM-连接数据库
  • 4、ORM-操作表
    • 4.1、类创建表
    • 4.2、修改表结构
      • 4.2.1、删除表结构
      • 4.2.2、新增表结构
  • 5、ORM-增删改查
    • 5.1、新增数据
    • 5.2、删除数据
    • 5.3、查询数据
    • 5.4、更新数据

1、ORM框架

  • Django开发操作数据库很简单,内部提供了ORM框架

在这里插入图片描述

ORM可以帮助我们做两件事:
创建、修改、删除数据库中的表(不用写SQL语句),但是无法创建数据库
操作表中的数据(不用写SQL语句),Django会利用ORM将代码翻译成SQL语句来操作数据库

  • 使用ORM之前还需安装第三方模块
pip install mysqlclient

在这里插入图片描述

2、ORM-创建数据库

由于ORM无法创建数据库,因此需要我们利用mysql来创建。

  • 启动mysql并输入密码登录
mysql -u root -p
 create database djangodb DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
 show databases;

3、ORM-连接数据库

  • 在settings.py文件中进行配置和修改

在这里插入图片描述

  • 删去db.sqlite3,并修改连接数据库的代码
python">DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql',  # 引擎'NAME': 'djangodb',  # 数据库名字'USER': 'root',   # 用户名'PASSWORD': 'root',    # 密码'HOST': '127.0.0.1',  # 安装MySQL的机器,一般是本机'PORT': 3306,}
}

4、ORM-操作表

4.1、类创建表

  • 在models.py中创建一个类,类中写入若干字段名

在这里插入图片描述

  • 编写类之后,ORM会根据类自动执行下述SQL语句来生成表(下述的SQL语句不需要自己写)
create table app01_userinfo(id bigint auto_increment primary key,name varchar(50),password varchar(60),age int
)
  • 表名:app名称_类名小写
  • 类中的字段对应表中的列
  • 自动生成id列,且是自增、主键
  • 此时我们查询数据库可以看到并未创建该表

在这里插入图片描述

  • 上述操作只是生成表,如果想让django数据库中创建该表,还需要执行下述命令
python manage.py makemigrations
python manage.py migrate

执行命令之前需要注意以下几点:

  • 确保app提前被注册
  • 当前的目录为根目录,必须包含manage.py,这样它才会发挥作用
  • 使用的python解释器必须安装了mysqlclient
  • 查询数据库的表时可以看到已经创建成功

在这里插入图片描述

生成很多其他的表是因为Django在执行上述命令时会去找每个app的models中的类来生成表,而Django默认提供了很多其他的app,这些app也依赖于一些表,因此会生成内部默认的一些表,如果不需要注释掉即可。
在这里插入图片描述

4.2、修改表结构

4.2.1、删除表结构

当想要删除表或表中的列时,只需要将models.py中的对应代码删掉或注释掉,重新执行下述命令即可

python manage.py makemigrations
python manage.py migrate

4.2.2、新增表结构

在表中新增列时,由于已存在列中可能已有数据,所以新增列必须要指定新增列对应的数据

  • 在表中新增size列

在这里插入图片描述

  • 重新执行上述命令时会出现下述选择(这里选择第一种选择)

在这里插入图片描述

  • 第二种选择是在代码中添加默认值

在这里插入图片描述

  • 第三种选择是允许数据为空

在这里插入图片描述

5、ORM-增删改查

5.1、新增数据

python">类名.objects.create(字段名=,...)

在这里插入图片描述
在这里插入图片描述

5.2、删除数据

  • 根据筛选条件删除数据
python">类名.objects.filter(筛选条件).delete()
  • 删除所有数据
python">类名.objects.all().delete()

5.3、查询数据

  • 获取符合条件的所有数据
python">data_list = 类名.objects.all()
  • 根据筛选条件获取数据
python">data_list = 类名.objects.filter(筛选条件)
  • 获取第一条数据
python">obj = 类名.objects.filter(筛选条件).first()

all()和filter()获取的数据类型均为QuerySet类型,可以看作数据列表类型,即[对象,对象,对象],而first()获得的是对象类型

5.4、更新数据

  • 更新所有数据
python">类名.objects.all().update(更新的字段名=新数据)
  • 根据筛选条件更新数据
python">类名.objects.filter(筛选条件).update(更新的字段名=新数据)

http://www.ppmy.cn/devtools/127690.html

相关文章

MySQL(python开发)——(3)表数据的基本操作,增删改查

MySQL(python开发)——(1)数据库概述及其MySQL介绍 MySQL(python开发)——(2)数据库基本操作及数据类型 MySQL—— 表数据基本操作 一、表中插入(insert)数据——增 insert into 表名 values (值1&#…

uniapp,获取头部高度

头部自定义时候&#xff0c;设置获取安全区域&#xff0c;可以用 uni.getSystemInfoSync();接口。 <view class"statusBar" :style"{height:statusBarHeightpx}"> let SYSuni.getSystemInfoSync(); let statusBarHeightref(SYS.statusBarHeight) …

PHP 正则验证A-Z且排除某字母

都已经找到这里来了&#xff0c;相信已经尝试很多办法了&#xff0c;那么我们直接上答案 关键正则&#xff1a;(?!.*[IO]) //验证5到6个大写字母且排除I和O if (preg_match(/^(?!.*[IO])[A-Z\d]{5,6}$/u, AAAAM)) {echo "匹配成功"; } else {echo "匹配失败…

CISP/NISP二级练习题-第一卷

目录 另外免费为大家准备了刷题小程序和docx文档&#xff0c;有需要的可以私信获取 1&#xff0e;不同的信息安全风险评估方法可能得到不同的风险评估结果&#xff0c;所以组织 机构应当根据各自的实际情况选择适当的风险评估方法。下面的描述中错误的是 &#xff08;&#…

刷爆Leetcode Day4

leetcode 16. 最小覆盖子串&#xff08;hard&#xff09;17. 二分查找&#xff08;easy&#xff09;18. 在排序数组中查找元素的第⼀个和最后⼀个位置&#xff08;medium&#xff09;19.搜索插入位置&#xff08;easy&#xff09;20. x的平方根&#xff08;easy&#xff09; 16…

Qt学习笔记第21到30讲

第21讲 new/delete关键字 new关键字 在 C 中&#xff0c; new 关键字用于动态分配内存。它是 C 中处理动态内存分配的主要工具之一&#xff0c;允许在程序运行时根据需要分配内存。 用法 ①分配单个对象&#xff1a;使用 new 可以在堆上动态分配一个对象。例如&#xf…

JVM(HotSpot):直接内存及其使用建议

文章目录 一、什么是直接内存&#xff1f;二、特点三、使用案例四、直接内存的管理 一、什么是直接内存&#xff1f; Direct Memory&#xff1a;系统内存 普通IO&#xff0c;运行原理图 磁盘到系统内存&#xff0c;系统内存到jvm内存。 NIO&#xff0c;运行原理图 划分了一块…

spdlog学习记录

spdlog Loggers&#xff1a;是 Spdlog 最基本的组件&#xff0c;负责记录日志消息。在 Spdlog 中&#xff0c;一个 Logger 对象代表着一个日志记录器&#xff0c;应用程序可以使用 Logger 对象记录不同级别的日志消息Sinks&#xff1a;决定了日志消息的输出位置。在 Spdlog 中&…