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

文章目录

  • 前言
  • 一、项目初始化搭建
    • 1、创建项目:test_models_django
    • 2、创建应用app01
  • 二、配置mysql
  • 三、创建model实例,自动创建数据库表
    • 1、创建对象User类
    • 2、执行命令
  • 四、思考问题(****)
    • 1、是否会生成新表呢(答案报错)
    • 2、总结
  • 五、f_user_01和f_user的添加操作
    • 1、f_user_01中的添加操作(自动生成的表)
      • a、views.py
      • b、urls.py
      • c、测试
    • 2、f_user中的添加操作(手动在mysql创建的表)
      • a、views.py
      • b、urls.py
      • c、测试
      • d、print输出
    • 3、发现问题
      • a、问题
      • b、原因
      • c、解决
      • d、删除之后再运行
  • 六、总结

前言

  • 上接博文: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数据库表结构。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据结构——哈希表、哈希桶

哈希概念 顺序结构以及平衡树中,元素关键码与其存储位置之间没有对应的关系,因此在查找一个元素时,必须要经过关键码的多次比较,顺序查找时间复杂度为O(N),平衡树中为树的高度,即O(logN),搜索的效率取决于搜索过程种元素的比较次…

Java递归删除文件夹

Java可以直接删除文件或者空文件夹,但是当文件夹不为空时,就不能直接删除了,这时候可以使用递归将文件夹直接删除 首先我们假设在D盘创建a文件夹,a中有一个b文件夹,b中有一个c文件夹,c中有三个文本文件&…

22. 计算机网络 - 物理层

通信方式带通调制 通信方式 根据信息在传输线上的传送方向,分为以下三种通信方式: 单工通信:单向传输半双工通信:双向交替传输全双工通信:双向同时传输 带通调制 模拟信号是连续的信号,数字信号是离散的…

新Docker镜像代理地址!

针对近期国内Docker镜像代理地址不能用,新的替换地址: 除了阿里自己账号申请的镜像加速地址外,下面的也可以用 "https://docker.m.daocloud.io", "https://docker.nju.edu.cn", "https://dockerproxy.com" systemctl d…

搭建自己的DNS服务器

个人名片 🎓作者简介:java领域优质创作者 🌐个人主页:码农阿豪 📞工作室:新空间代码工作室(提供各种软件服务) 💌个人邮箱:[2435024119qq.com] &#x1f4f1…

Unity 资源 之 风格化地形纹理(Stylized Terrain Textures)免费领取

风格化地形纹理:Stylized Terrain Textures 前言资源包内容领取兑换码 前言 亲爱的 Unity 游戏开发者们,我们自豪地为大家推荐最新的每周免费资源:风格化地形纹理!这些令人惊叹的纹理将为你的游戏世界带来独特而引人入胜的视觉体…

走进高等学府,ATFX再度亮相雅尔穆克大学,共绘市场发展新蓝图

自2022年成功获得约旦证券委员会(JSC)颁发牌照后,ATFX植根约旦本土并于同年设立约旦办事处,不断深化与当地各界合作伙伴间的沟通协作,矢志为每一位客户打造优质、便捷、高效的投教服务体验。近日,ATFX再度登…

人工智能系统越来越擅长欺骗我们?

人工智能系统越来越擅长欺骗我们? 一波人工智能系统以他们没有被明确训练过的方式“欺骗”人类,通过为他们的行为提供不真实的解释,或者向人类用户隐瞒真相并误导他们以达到战略目的。 发表在《模式》(Patterns)杂志上的一篇综述论文总结了之…

JustAuth Illegal state xx问题

排查 起因 服务上线生产环境后使用飞书登录有些时候会登录失败,查看日志出现以上错误Illegal state [FEISHU],但是测试环境没有出现这个情况 排查 经过排查发现是JustAuth 报的错 分析出现原因 在JustAuth找到出现原因和解决方案 原文地址:异常相关问题 | JustAuth 异常…

Mat的lambda方式像素高效遍历(C++11)

Mat的lambda方式像素高效遍历(C11) 文章目录 Mat的lambda方式像素高效遍历(C11)前言一、Mat的lambda方式像素高效遍历二、代码实现总结 前言 图像遍历是图像处理中的经典操作,快速高效的进行像素遍历对性能的提升至关…

建构信任基石:揭秘Web3的去中心化信任体系

在传统的互联网时代,信任往往建立在中心化的机构和第三方平台之上,而这种中心化的信任体系往往面临着数据泄露、信息滥用等问题。然而,随着区块链技术的发展,Web3时代正在向我们展示一种全新的信任体系,即去中心化的信…

随到随学|2024泰迪智能科技暑期在线项目/集训营

在数字化转型的浪潮中,大数据和人工智能等前沿技术已成为推动经济发展和科技进步的关键动力。当前,全球各行各业都在积极推进数字化转型,不仅为经济增长注入新活力,也对人才市场结构产生了深刻影响,尤其是对数字化人才…

vCenter7.0安装部署

vCenter7.0安装部署 一、准备环境二、创建新的虚拟机1.创建虚拟机2.第3-5步可直接默认安装并同意许可协议。3.其他设置4.第一阶段直接点完成即可 三、进入第二阶段安装(输入ip:5480进入安装界面) 一、准备环境 准备一台exsi,并登…

《数学学习与研究》投稿难度大吗?

《数学学习与研究》杂志的投稿难度相对适中。 一方面,它作为一本有一定影响力的数学专业期刊,对稿件的质量有一定要求。论文需要具备一定的创新性、科学性和逻辑性,研究内容要具有一定的价值和深度。 另一方面,与一些核心期刊相…

Lab_ Exploiting a mass assignment vulnerability_实验室:利用大规模分配漏洞

使用 wiener:peter 登录 点击轻量级“l33t”皮夹克产品并将其添加到购物篮中。 去到购物车,点击下单,提示Not enough store credit for this purchase(没有足够的商店信用用于此次购买) 在Burp的HTTP历史记录中发现了API的请求…

QT creator c动态链接库的创建与调用

QT creator c动态链接库的创建与调用 QT5.15.2 1.创建dll项目 确保两类型选择正确 2.选择MinGW 64-bit 3.点击完成 pro文件参考: QT - guiTEMPLATE lib DEFINES QT_DLL_DEMO_LIBRARYCONFIG c17# You can make your code fail to compile if it uses deprecat…

网线制作(双绞线+水晶头)——T568B标准

参考视频:https://www.bilibili.com/video/BV1KQ4y1i7zP/ 1、使用剥线器 2、将线捋顺、排序、剪掉牵引线 记忆技巧 1.线序颜色整体是一浅一深 2.颜色顺序是黄、蓝、绿、棕 一个黄种人、从上向下看,分别看到的是蓝天、青草(绿)、泥土(棕色) 3.中间两根浅…

抗锯齿技术在AI绘画中的应用与意义

随着人工智能技术的飞速发展,AI绘画逐渐成为艺术创作领域的一大热点。然而,在数字绘画的过程中,画面的锯齿效应一直是影响作品质量的一个重要因素。抗锯齿技术的应用,有效地解决了这一问题,使得AI绘画作品更加细腻、真…

自然语言处理(NLP)—— 主题建模

1. 主题建模的概念 主题建模(Topic Modeling)是一种用于发现文档集合(语料库)中的主题(或称为主题、议题、概念)的统计模型。在自然语言处理和文本挖掘领域,主题建模是理解和提取大量文本数据隐…

小程序 UI 风格魅力非凡

小程序 UI 风格魅力非凡