使用 Django 连接 MySQL 数据库

news2025/1/19 16:58:04

文章目录

    • 步骤一:安装必要的库和驱动
    • 步骤二:配置数据库连接
    • 步骤三:执行数据库迁移
    • 步骤四:开始使用 MySQL 数据库
      • 创建一个模型
      • 迁移模型到数据库
      • 使用模型进行数据操作
        • 创建新记录:
        • 查询记录:
        • 更新记录:
        • 删除记录:
    • 总结与拓展
      • 总结
      • 拓展

在 Django 中,我们可以使用 MySQL 作为后端数据库来存储数据。下面是连接 Django 和 MySQL 数据库的步骤:
在这里插入图片描述

步骤一:安装必要的库和驱动

首先,确保已经安装了 Django 和 MySQL 客户端驱动。可以通过以下命令安装:

pip install Django mysqlclient

步骤二:配置数据库连接

在 Django 项目的 settings.py 文件中,找到 DATABASES 配置项,并进行如下配置:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'your_database_name',
        'USER': 'your_database_user',
        'PASSWORD': 'your_database_password',
        'HOST': 'localhost', # 或者指定数据库的主机地址
        'PORT': '3306', # MySQL 默认端口为 3306
    }
}

请将上述代码中的 your_database_nameyour_database_useryour_database_password 替换为实际的数据库名称、用户名和密码。

步骤三:执行数据库迁移

在配置好数据库连接后,使用以下命令执行数据库迁移:

python manage.py makemigrations
python manage.py migrate

这两个命令将会在 MySQL 数据库中创建相应的表结构。

步骤四:开始使用 MySQL 数据库

在 Django 项目中,您可以通过模型(Model)来定义数据结构并与 MySQL 数据库交互。以下是一些常用的操作示例:

创建一个模型

首先,在 Django 应用的 models.py 文件中定义一个模型类,例如:

from django.db import models

class Book(models.Model):
    title = models.CharField(max_length=100)
    author = models.CharField(max_length=50)
    publish_date = models.DateField()

迁移模型到数据库

运行以下命令将新定义的模型迁移至 MySQL 数据库:

python manage.py makemigrations your_app_name
python manage.py migrate

确保将 your_app_name 替换为您的应用名称。

使用模型进行数据操作

现在您可以在 Django 中使用该模型与 MySQL 数据库进行数据交互。以下是一些示例代码:

创建新记录:
book = Book(title='Django for Beginners', author='John Doe', publish_date='2024-05-28')
book.save()
查询记录:
books = Book.objects.all()  # 获取所有书籍记录
book = Book.objects.get(title='Django for Beginners')  # 根据标题获取特定记录
更新记录:
book = Book.objects.get(title='Django for Beginners')
book.author = 'Jane Smith'
book.save()
删除记录:
book = Book.objects.get(title='Django for Beginners')
book.delete()

总结与拓展

通过以上步骤,我们已经学会了如何在 Django 项目中使用 MySQL 数据库。

总结

  • 通过安装 mysqlclient 库并配置 DATABASES 设置,可以让 Django 项目连接到 MySQL 数据库。
  • 使用 makemigrationsmigrate 命令可以将模型迁移至 MySQL 数据库,并进行数据库表结构的创建和更新。
  • 在模型中定义字段和方法后,可以通过模型类进行数据的增删改查操作。

拓展

  • 可以进一步学习 MySQL 数据库的高级特性,如索引、事务、存储过程等,以优化数据库性能和扩展功能。
  • 可以探索 Django ORM(对象关系映射)的更多特性,如复杂查询、关联模型等,以更加灵活地操作数据库。
  • 了解 Django 的数据库迁移机制和版本控制,以便在团队协作或生产环境中管理数据库变更。

希望本文能够帮助您顺利地在 Django 项目中使用 MySQL 数据库,并为您未来的项目开发提供一定的指导和启发。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1712185.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

264 基于matlab的自适应语音盲分离

基于matlab的自适应语音盲分离,当a和b同时对着传声器A,B说话且传声器靠得很近时,传声器A,B会同时接受到a和b的声音,即a和b产生了混叠干扰,此时通过自适应语音盲分离系统可以将a,b的声音分离开,使得一个信道只有一个人的…

【并发程序设计】11.进程间通信

11.进程间通信 (IPC,InterProcess Communication)进程和进程之间交换信息。 常用通信方式 无名管道(pipe)有名管道 (fifo)信号(signal)共享内存(mmap)套接字&#xff0…

平衡二叉树的构建(理论,部分函数代码)

平衡二叉树是二叉排序树的一种特殊情况,平衡二叉树的出现是为了在最坏情况下的时间复杂度仍然是对数级别O(logn),从而保证了高效的搜索、插入和删除操作。 举个例子,如果有一个数组是:1,2,3。如果只简单的…

数据库多表查询

多表查询: SELECT *FROM stu_table,class WHERE stu_table.c_idclass.c_id; 多表查询——内连接 查询两张表交集部分。 隐式内连接: #查询学生姓名,和班级名称,隐式调用 SELECT stu_table.s_name,class.c_name FROM stu_table…

vs code 中使用SSH 连接远程的Ubuntu系统

如下图,找到对应的位置 在电脑上找到以下位置 打开配置如下,记住,那个root为你的用户名,这个用户名,具体根据你的用户名来设置,对应的密码就是你登录Ubuntu时的密码 Host root192.168.0.64User rootHostNa…

文件跨境传输法律管控越来越严格,企业该如何有效应对?

文件跨境传输已经成为非常普遍的业务需求,企业在世界各地的总分支处、合作伙伴,客户间开展业务时,必须基于数据的跨境流转而展开。 但随着世界各国对数据安全的重视,文件跨境传输也日趋严格,各国在法律法规上均出具了更…

RP2040 SPI DMA驱动ST7735

SPI DMA演示 一、源码 #include <stdio.h> #include <stdlib.h> #include "pico/stdlib.h" #include "pico/binary_info.h" #include "hardware/spi.h" #include "hardware/dma.h" #include "font.h"#define X…

Ownips+Coze海外社媒数据分析实战指南

目录 一、引言二、ISP代理简介三、应用实践——基于Ownips和coze的社媒智能分析助手3.1、Twitter趋势数据采集3.1.1、Twitter趋势数据接口分析3.1.2、Ownips原生住宅ISP选取与配置3.1.3、数据采集 3.2、基于Ownips和Coze的社媒智能助手3.2.1、Ownips数据采集插件集成3.2.2、创建…

Ubuntu配置Git

安装git sudo apt install git 查看是否安装成功 git --version 配置git 用github上注册的用户名和邮箱地址&#xff0c;配置git git config --global user.name "username" git config --global user.email "usernameemail.com" 重启ubuntu查看…

首搭第五代DM技术,秦L DM-i正式上市,仅售9.98万元起

5月28日&#xff0c;比亚迪王朝重磅新车秦L DM-i在西安震撼上市&#xff0c;首搭第五代DM技术&#xff0c;百公里亏电油耗达到划时代的2.9L&#xff0c;“一箱油”满油满电综合续航达2100公里&#xff0c;引领中级&#xff0c;创下了百公里油耗的历史新低&#xff0c;开创油耗2…

机顶盒也可以跑pcdn--上机指南(贰)

机顶盒能跑PCDN&#xff0c;以下是相关上机指南操作步骤&#xff1a; 1.申请PCDN服务&#xff1a;登录PCDN控制台&#xff0c;申请开通PCDN服务。 2.后台开通PCDN服务&#xff1a;工作人员与用户沟通业务详细需求&#xff0c;用户确定使用PCDN&#xff0c;后台为用户开通PCDN…

VolWeb:集中式增强型数字取证内存分析平台

关于VolWeb VolWeb是一款最新开发的集中式增强型数字取证内存分析平台&#xff0c;该平台基于Volatility 3框架实现其功能&#xff0c;该工具旨在辅助广大研究人员执行安全分析和事件应急响应等任务。 VolWeb可以提供集中式、可视化的增强型网络应用程序&#xff0c;并提高安全…

Java基础:类的详细说明

Java是一门面向对象的编程语言&#xff0c;所谓的面向对象&#xff0c;简单的说&#xff0c;就是在软件开发过程中&#xff0c;用各种各样的对象实现所需功能。 对象就好像是现实世界中不计其数的物体&#xff0c;根据物体的性质可以将其进行分门别类&#xff1a;石头、锤子、…

深入分析 Android Activity (十一)

文章目录 深入分析 Android Activity (十一)1. Activity 的内存管理和优化1.1 内存泄漏的常见原因1.2 避免内存泄漏的方法1.3 内存泄漏检测工具 2. Activity 的配置变更处理2.1 处理配置变更2.2 保存和恢复状态2.3 使用 ViewModel 3. Activity 的测试3.1 单元测试3.2 UI 测试 4…

编译安装Apache httpd服务(LAMP1)

目录 1.初始化设置&#xff0c;将Apache所需软件包传到 /opt 目录下 &#xff08;1&#xff09;关闭防火墙 &#xff08;2&#xff09;上传软件包到/opt目录 2.安装环境依赖包 3.配置软件模块 4.编译及安装 5.优化配置文件路径&#xff0c;并把httpd服务的可执行程序文件…

DDR5芯片系统框图详解

DDR5 SDRAM(双倍数据率五代同步动态随机存取存储器)的功能框图详细展现了其内部结构和各个关键模块,这些模块协同工作以实现高速数据传输和存储管理。以下是主要组成部分的详细介绍: Controller Logic (控制器逻辑)这是DDR5内存系统的大脑,负责接收来自CPU或SoC的指令,解…

怎么从视频中截取图片?这3个视频截图方法超清晰

怎么从视频中截取图片&#xff1f;从视频中截取图片确实是一个不可或缺的技能&#xff0c;特别是在我们想要留住视频中的某个动人瞬间、重要细节或是用于制作海报、封面等场合时。无论是专业的视频编辑人员&#xff0c;还是普通用户&#xff0c;掌握这技巧都能让视频内容得到更…

光缆监测主要功能值得一看

网络资源管理&#xff1a; 设备管理&#xff1a; 测试告警处理&#xff1a; 百度地图&#xff1a; 报表打印&#xff1a; 路由测试数据、路由段数据、路由故障报警统计、当前故障通知情况、路由测试数据、路由段信息。 手机客户端&#xff1a; 通过手机可以访问系统&#x…

为WPF的Grid添加网格边框线

在WPF中使用Grid绘制表格的时候&#xff0c;如果元素较多、排列复杂的话&#xff0c;界面会看起来很糟糕&#xff0c;没有层次&#xff0c;这时用网格或边框线分割各元素&#xff08;标签或单元格&#xff09;将会是页面看起来整齐有条理。 默认没有边框线的如下图所示&#xf…

FuTalk设计周刊-Vol.049

#AI漫谈 热点捕手 1.Gemini Pro1.5及其百万上下文功能现已向所有人开放 Gemini Pro1.5加入视频模态的长上下文功能&#xff0c;AI可以处理更复杂的视频内容。 链接https://aistudio.google.com/app/prompts/new_chat?reftop.aibase.com 2.Figma 2024 Config 大会 6月26-27日…