Django操作数据库

Django操作数据库

1、ORM框架

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

ORM可以帮助我们做两件事:

创建、修改、删除数据库中的表(不用写SQL语句),但是无法创建数据库

操作表中的数据(不用写SQL语句),Django会利用ORM将代码翻译成SQL语句来操作数据库

  • 使用ORM之前还需安装第三方模块
bash 复制代码
pip install mysqlclient

2、ORM-创建数据库

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

  • 启动mysql并输入密码登录
sql 复制代码
mysql -u root -p
  • 创建数据库
sql 复制代码
 create database djangodb DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
  • 查询数据库看是否创建成功
sql 复制代码
 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语句不需要自己写)
sql 复制代码
create table app01_userinfo(
    id bigint auto_increment primary key,
    name varchar(50),
    password varchar(60),
    age int
)
  • 表名:app名称_类名小写
  • 类中的字段对应表中的列
  • 自动生成id列,且是自增、主键
  • 此时我们查询数据库可以看到并未创建该表
  • 上述操作只是生成表,如果想让django在数据库中创建该表,还需要执行下述命令
bash 复制代码
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中的对应代码删掉或注释掉,重新执行下述命令即可

bash 复制代码
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(更新的字段名=新数据)
相关推荐
想不明白的过度思考者几秒前
Java从入门到“放弃”(精通)之旅——JavaSE终篇(异常)
java·开发语言
时序数据说11 分钟前
时序数据库IoTDB在航空航天领域的解决方案
大数据·数据库·时序数据库·iotdb
明月与玄武19 分钟前
Python编程的真谛:超越语法,理解编程本质
python·编程语言
CodeCraft Studio20 分钟前
Excel处理控件Aspose.Cells教程:使用 Python 在 Excel 中进行数据验
开发语言·python·excel
.生产的驴25 分钟前
SpringBoot 封装统一API返回格式对象 标准化开发 请求封装 统一格式处理
java·数据库·spring boot·后端·spring·eclipse·maven
猿周LV32 分钟前
JMeter 安装及使用 [软件测试工具]
java·测试工具·jmeter·单元测试·压力测试
晨集35 分钟前
Uni-App 多端电子合同开源项目介绍
java·spring boot·uni-app·电子合同
AnsenZhu37 分钟前
2025年Redis分片存储性能优化指南
数据库·redis·性能优化·分片
时间之城37 分钟前
笔记:记一次使用EasyExcel重写convertToExcelData方法无法读取@ExcelDictFormat注解的问题(已解决)
java·spring boot·笔记·spring·excel
椰羊~王小美44 分钟前
LeetCode -- Flora -- edit 2025-04-25
java·开发语言