Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 这篇文章是关于如何使用Django框架配置MySQL数据库,创建模型实例,并自动或手动创建数据库表,以及对这些表进行操作的详细教程。

前言

  • 上接博文:Django学习一:创建Django框架,介绍Django的项目结构和开发逻辑。创建应用,编写主包和应用中的helloworld
  • 紧跟上一篇博文,本文主要基于上一篇项目的内容,配置mysql,创建model实例,自动创建数据库表,进行操作model,并进行反思(不采用自动创建表,如何操作mysql的表)
  • 有兴趣可以添加我,一起探讨技术。
    • 加V:Fengfl1222,名称:insist科技。
    • 要资料,申请备注为:CSDN+地方,如CSDN山东。
    • 想接项目一起努力进步,申请备注为:CSDN+地方+项目,如CSDN+山东+项目,添加成功之后,可以发一份简历。
    • 本人介绍:211高校(北京交通大学)计算机研究生,本科双非计算机毕业后,校招进入军工,工作2个月离职后进入阿里,工作两年后离职考研,现已毕业,入职济南某大厂。主要技术栈:java、python、vue、react等web开发需求。已有开发团队,如果有空闲时间想一个接项目者,可以加我呦。
    • 不按上诉规则添加好友者,不予通过。
  • 项目环境
    • python: 3.11.5
    • django:4.1
      在这里插入图片描述

一、项目初始化搭建

1、创建项目:test_models_django

详细创建请看博文一:Django学习一:创建Django框架,介绍Django的项目结构和开发逻辑。创建应用,编写主包和应用中的helloworld

对前面的搭建流程梳理简化。

  1. django-admin startproject test_models_django:创建项目test_models_django
  2. cd test_models_django
  3. python manage.py migrate
    在这里插入图片描述
  4. python manage.py runserver:运行项目
    在这里插入图片描述
  5. 浏览器输入网址:http://127.0.0.1:8000/,结果如下,Django项目搭建成功
    在这里插入图片描述
  6. 使用pycharm打开如下。配置环境啥的请看博文一。

2、创建应用app01

  1. python manage.py startapp app01:创建应用app01

  2. 主包中配置应用app01,如下所示:
    在这里插入图片描述

  3. app01中的urls.pyviews.py。(没有则新建)
    在这里插入图片描述
    在这里插入图片描述

  4. 主包中的urls.py
    在这里插入图片描述

  5. 浏览器输入网址:http://127.0.0.1:8000/hello,结果如下,应用搭建成功
    在这里插入图片描述

二、配置mysql

主包中settings.py
默认的数据库配置如下。

DATABASES = {
    "default": {
        "ENGINE": "django.db.backends.sqlite3",
        "NAME": BASE_DIR / "db.sqlite3",
    }
}

修改后如下所示

DATABASES = {
    "default": {
        "ENGINE": "django.db.backends.mysql",
        "NAME": "数据库名",
        "USER": "用户",
        "PASSWORD": "密码",
        "HOST": "ip",
        "PORT": "3306"
    }
}

保存后,系统报错,缺少mysql插件,需要安装mysqlclient
在这里插入图片描述
执行以下命令安装

pip install mysqlclient

或者使用conda来安装

conda install mysqlclient

python manage.py runserver:然后成功运行。
在这里插入图片描述

三、创建model实例,自动创建数据库表

1、创建对象User类

  1. app01包中model.py,添加用户类User
  2. 子类Meta中定义表的元数据,我这里指定了表的名称为 f_user_01
from django.db import models

# Create your models here.
class User_01(models.Model):
    u_id = models.AutoField(primary_key=True)
    username = models.CharField(max_length=64, null=True)
    name = models.CharField(max_length=64, null=True)
    password = models.CharField(max_length=64, null=True)
    sex = models.CharField(max_length=64, null=True)
    age = models.CharField(max_length=64, null=True)
    phone = models.CharField(max_length=64, null=True)
    email = models.CharField(max_length=64, null=True)
    unit = models.CharField(max_length=64, null=True)
    avatar = models.CharField(max_length=64, null=True)
    status = models.CharField(max_length=64, null=True)
    create_time = models.CharField(max_length=64, null=True)
    delete_time = models.CharField(max_length=64, null=True)
    update_time = models.CharField(max_length=64, null=True)

    class Meta:
        db_table = "f_user_01"

在这里插入图片描述

2、执行命令

# 生成迁移数据
python manage.py makemigrations
# 生成数据库表
python manage.py migrate
  • 执行完第一个命令,会在当前包app01中生成初始化文件,仅仅对我们的类做了一个解读。
    在这里插入图片描述
    在这里插入图片描述

  • 执行完第二个命令,会在数据库中生成数据库表。
    在这里插入图片描述

  • 数据库表生成如下所示,只有f_user_01是我们要生成的表,上面的其他表都是Django系统默认生成的表。暂且不管。(未圈中的与本项目无关)
    在这里插入图片描述

四、思考问题(****)

  • 其实大多数时候,都是自己创建表,不需要自动创建表,那么从models.py中创建了对象类,应该怎么和自己创建的数据库表对应呢。
  • 或者说,是否可以直接通过model.py不创建新表,直接操作数据库中对应的表呢。
  • 那就实验一下吧,自己手动创建数据库表,然后手动创建models.py,在执行迁移命令,看是否还会生成新的表呢。

1、是否会生成新表呢(答案报错)

数据库创建表 f_user。具体如下所示。(如上面截图所示,我这里已经创建好了)
在这里插入图片描述
models.py添加User类,与数据库表中字段一一对应。 和f_user_01表一样,唯一的不一样就说最后的时间类型改为DateTime。数据库也修改成相应的了。

class User(models.Model):
    u_id = models.AutoField(primary_key=True)
    username = models.CharField(max_length=64, null=True)
    name = models.CharField(max_length=64, null=True)
    password = models.CharField(max_length=64, null=True)
    sex = models.CharField(max_length=64, null=True)
    age = models.CharField(max_length=64, null=True)
    phone = models.CharField(max_length=64, null=True)
    email = models.CharField(max_length=64, null=True)
    unit = models.CharField(max_length=64, null=True)
    avatar = models.CharField(max_length=64, null=True)
    status = models.CharField(max_length=64, null=True)
    create_time = models.CharField(max_length=64, null=True)
    delete_time = models.CharField(max_length=64, null=True)
    update_time = models.CharField(max_length=64, null=True)

    class Meta:
        db_table = "f_user"

在这里插入图片描述
执行命令如下,看是否会报错等其他情况。

# 生成迁移数据
python manage.py makemigrations
# 生成数据库表
python manage.py migrate

执行第一个命令后,migrations中生成了一个新的映射迁移。新的类,生成了一个新的模型类。
在这里插入图片描述
在这里插入图片描述
执行第二个命令后,报错,如下:(说明表已经存在)
在这里插入图片描述

2、总结

models.py中指定了表名,如果数据库表中没有则创建,有则报错。
接下来对这两个表进行添加操作。

五、f_user_01和f_user的添加操作

1、f_user_01中的添加操作(自动生成的表)

a、views.py

from django.http import HttpResponse
from app01 import models
import json

def hello_world(request):
    return HttpResponse("app01 Hello, World!")

def addUser01(request):
    models.User_01.objects.create(username='admin', name='冯坚持', password='123456', sex='男', age='18',
                                  phone='1234567890', email='123456789@163.com', unit='1-1-1', avatar='asdad',
                                  status='1', create_time='20240104 12:12:22', delete_time='20240104 12:12:22',
                                  update_time='20240104 12:12:22')
    result = {
        'code': 0,
        'msg': 'success',
        'data': ''
    }
    return HttpResponse(json.dumps(result, ensure_ascii=False), content_type='application/json')

在这里插入图片描述

b、urls.py

from django.urls import path
from . import views

urlpatterns = [
    path('hello/', views.hello_world),
    path('addUser01/', views.addUser01),
]

在这里插入图片描述

c、测试

  1. 浏览器输入:http://127.0.0.1:8000/addUser01/
    在这里插入图片描述
  2. 查看mysql数据库,数据插入成功
    在这里插入图片描述

2、f_user中的添加操作(手动在mysql创建的表)

a、views.py

from django.http import HttpResponse
from app01 import models
import json
from django.utils import timezone
from datetime import datetime

def addUser(request):
    print(timezone.now())  # 使用 timezone.now() 获取当前时间
    print(datetime(2023, 6, 6, 12, 0, 0))  # 手动设置 datetime 值,可以使用 Python 的 datetime 模块
    models.User.objects.create(username='admin', name='冯坚持', password='123456', sex='男', age='18',
                               phone='1234567890', email='123456789@163.com', unit='1-1-1', avatar='asdad',
                               status='1', create_time=timezone.now(), delete_time=timezone.now(),
                               update_time=timezone.now())
    result = {
        'code': 0,
        'msg': 'success',
        'data': ''
    }
    return HttpResponse(json.dumps(result, ensure_ascii=False), content_type='application/json')

在这里插入图片描述

b、urls.py

from django.urls import path
from . import views

urlpatterns = [
    path('hello/', views.hello_world),
    path('addUser01/', views.addUser01),
    path('addUser/', views.addUser),
]

在这里插入图片描述

c、测试

  1. 浏览器输入:http://127.0.0.1:8000/addUser/
    在这里插入图片描述
  2. 查看mysql数据库,数据插入成功
    在这里插入图片描述

d、print输出

在这里插入图片描述

3、发现问题

a、问题

在运行界面,发现如下提示。
在这里插入图片描述

b、原因

意思是有一个没有应用的迁移类,因为在第四章,执行了命令python manage.py makemigrations,所以在migrations中生成了对应迁移类User,但是其表f_user在数据库中已经存在了,所以,在执行第二个命令python manage.py migrate 报错了,提示表已经存在。
这就是出现上面警告的原因。
在这里插入图片描述

c、解决

对于数据库中已经存在的表,只在models.py中声明即可,不用执行迁移的两个命令。现在目前的情况,删除0002__user.py即可。
在这里插入图片描述

d、删除之后再运行

在这里插入图片描述
在执行f_user表的添加请求测试如下。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

六、总结

  1. 配置mysql,需要安装mysqlclient,编写models的实体类,通过迁移命令可以自动生成mysql数据库表结构。
  2. 如果数据库表中已经创建好表,则只在model.py中创建对应实体类即可,不用执行迁移的两个命令。(这里就和java对应上了,直接编写对应实体类和sql即可)
  3. 如果数据库没有创建好表,可以在models设计号实体类,使用迁移命令即可自动生成mysql数据库表结构。
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
11天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
38 3
|
11天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
38 3
|
11天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
52 2
|
18天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
24天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
168 15
|
25天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
29天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
2月前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据
|
2月前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
46 1
|
2月前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
73 4