小白学Django第四天| Django后台管理及配置MySQL数据库

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS Agent(兼容OpenClaw),2核4GB
简介: 小白学Django第四天| Django后台管理及配置MySQL数据库

本文内容:


   1. 后台管理

   2. 配置MySQL数据库



1. 后台管理

     当我们在开发一个网站的时候,我们往往需要对数据表中的数据进行增删改查。例如在电商网中,每一个商家对商品的上架和下架以及商品信息的编辑都是需要对数据表进行操作的。


     在Django框架中,提供了一种机制,能够帮助我们自动生成相应的数据表后台管理。


微信图片_20220217121011.jpg

(图取自第一天学习)


上图中的文件admin.py正是后台管理相关的文件,具体如何使用这个Django后台管理,看下文:


1、首先,我们需要去修改setting.py文件,这个文件里包含着整个项目的总体配置。修改什么呢?我们需要本地化语言和时间。


微信图片_20220217121020.jpg

(默认)


因为我们处在中国,所以我们需要修改相应的时间和语言(根据自己实际情况而定)


微信图片_20220217121023.jpg

(修改后)


2、创建管理员账户


python manage.py createsuperuser


通过上述命令,我们可以迅速的创建一个管理员账户


微信图片_20220217121026.png


3、登录管理后台


python manage.py runserver


微信图片_20220217121108.png


此时我们访问   http://127.0.0.1:8000/admin    即可(记得后缀加admin)


微信图片_20220217121116.png

(后台管理页面)

4、注册模型类


进入之后我们会发现什么都没有,所以接下来我们需要在应用下中的admin.py文件中注册模型类,相应的Django会根据注册的模型类生成对应的管理页面。


微信图片_20220217121124.jpg


我们刷新后台会发现多出了我们刚刚注册的模型类:


微信图片_20220217121127.png

点进去看,会发现有两个对象:


微信图片_20220217121130.png

我们可以通过重写模型类中的str方法,使这里更加直观的显示书名


微信图片_20220217121133.jpg


这两个对象就是我们在之前文章中所添加的两本书籍信息:


微信图片_20220217121136.png


微信图片_20220217121139.png


在后台管理页面,我们可以非常快捷的给模型增添新的数据:


微信图片_20220217121142.png


页面上的增添、修改、删除也都是可以通过命令实现的,只不过Django框架提供了这种快速而且方便的方式。这里的删除等操作我就不一一展示,大家自行挖掘。


5.自定义管理页面


大家可能会发现这个页面未免也太单调了吧,他并没有像数据库那样把所有的详细数据给展示出来,当然也是可以的,Django后台管理是可以自定义管理页面


首先,我们需要自定义模型管理类,这个类就是告诉Django,我需要展示出什么东西:


微信图片_20220217121145.jpg


此时,再去看我们的管理页面


微信图片_20220217121148.png


就已经把我们需要展示的数据给展示出来了。


2.配置MySQL数据库

    这里给大家补充一个知识,因为我们大部分的项目数据库都是使用MySQL,但是Django默认配置的是sqlite3数据库,所以今天带着大家来修改一下数据库配置。


微信图片_20220217121151.jpg


在前面,我们说过setting.py是整个项目的配置文件,所以我们需要在这个文件中来修改。


微信图片_20220217121154.jpg


DATABASES = {     
   'default': {          
      'ENGINE': 'django.db.backends.mysql', # 数据库引擎          
      'NAME': 'Bookdb', # 数据库名称          
      'HOST': 'localhost', # 数据库主机         
      'PORT': '3306', # 数据库端口          
      'USER': 'root', # 数据库用户名          
      'PASSWORD': 'mysql', # 数据库密码      
    }  
}

我们只需要把内容改成上述代码,并且根据自己情况修改即可。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
12月前
|
关系型数据库 MySQL 数据库连接
Django数据库配置避坑指南:从初始化到生产环境的实战优化
本文介绍了Django数据库配置与初始化实战,涵盖MySQL等主流数据库的配置方法及常见问题处理。内容包括数据库连接设置、驱动安装、配置检查、数据表生成、初始数据导入导出,并提供真实项目部署场景的操作步骤与示例代码,适用于开发、测试及生产环境搭建。
566 1
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
9月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
1074 7
|
9月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
842 11
|
11月前
|
存储 前端开发 应用服务中间件
Django 实战:静态文件与媒体文件从开发配置到生产部署
Django项目中,静态文件(Static Files)和媒体文件(Media Files)是两类不同用途的文件。本文详细介绍了它们的区别、配置方法以及在开发与生产环境中的处理方式,并结合用户头像上传功能进行实战演示,最后讲解了如何通过Nginx或OpenResty部署静态与媒体文件服务。
543 1
|
Ubuntu 关系型数据库 MySQL
在Ubuntu 22.04上配置和安装MySQL
以上就是在Ubuntu 22.04上配置和安装MySQL的步骤。这个过程可能看起来有点复杂,但只要按照步骤一步步来,你会发现其实并不难。记住,任何时候都不要急于求成,耐心是解决问题的关键。
1533 31
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
710 11
|
关系型数据库 MySQL Linux
CentOS 7系统下详细安装MySQL 5.7的步骤:包括密码配置、字符集配置、远程连接配置
以上就是在CentOS 7系统下安装MySQL 5.7的详细步骤。希望这个指南能帮助你顺利完成安装。
3299 26
|
SQL 关系型数据库 MySQL
seatunnel配置mysql2hive
本文介绍了SeaTunnel的安装与使用教程,涵盖从安装、配置到数据同步的全过程。主要内容包括: 1. **SeaTunnel安装**:详细描述了下载、解压及配置连接器等步骤。 2. **模拟数据到Hive (fake2hive)**:通过编辑测试脚本,将模拟数据写入Hive表。 3. **MySQL到控制台 (mysql2console)**:创建配置文件并执行命令,将MySQL数据输出到控制台。 4. **MySQL到Hive (mysql2hive)**:创建Hive表,配置并启动同步任务,支持单表和多表同步。
|
存储 Oracle 关系型数据库
MySQL 8.4 配置SSL组复制(八个步骤)
MySQL 8.4 配置SSL组复制(八个步骤)
997 0

推荐镜像

更多