上一篇简单的说了一下整体项目的搭建,但是这还不够,一般完整的项目还要有很多东西,比如前端页面有一些数据不是固定的,需要前后端交互,还需要后台管理系统,有可能我还不想用自带的sqlite,想用mysql。这一篇讲一下后台管理、模版渲染、以及怎么用mysql数据库,前后端交互我会在另外一篇文章,前后端分离再说。

一、django自带的后台管理系统

1、建表

后台管理系统数据库是一定要用的,python已经帮我们做了很多东西,我们只需要调用就可以了,首先需要建表,打开myapp下models.py,添加以下内容

image.png

接下来需要同步数据库,上一篇已经在搭建项目的时候说过了,这里重新说一下,只需要两行命令。

image.png

这时候会发现根目录下多了一个db.sqlite3的文件,打开是乱码,没错这就是刚刚新建的表。。。以文本的形式存储在根目录下。

还需要一步操作,打开myapp目录下的admin.py,添加如下内容,用后台管理系统来管理刚创建的表。

image.png

2、后台管理系统

django的后台管理系统已经很完善了,我们需要做的就是创建一个账号,登录,操作,没有其他了,不需要自己写任何东西。

创建账号

image.png

请忽略那几行提示,密码我用的是六个1,多么的贴心,给了我三行提示。

至此账号已经创建好了,接下来就是打开后台管理系统登录。

相信在上一篇写urls的时候都发现了有一个admin的默认路径,那个就是后台管理系统。

python manage.py runserver

在浏览器地址栏输入http://127.0.0.1:8000/admin

image.png

输入刚创建好的账号和密码登录

image.png

这就是刚创建的表,点击Add我们来添加一组数据。

image.png

image.png

这就是django自带的后台管理系统。

二、模版渲染

1、直接将数据渲染到页面

有了数据就要显示在前端,这就要用到模版渲染,上一篇已经说过怎么建模版,这里就不说了,主要说以下怎么渲染数据。

首先需要在渲染模版的时候把数据一起返回,打开myapp目录下的views.py

image.png

templates目录下的index.html需要修改如下

image.png

这里用到了django渲染模版的语法。

刷新浏览器

image.png

2、数据传递给js

有时候数据需要做一些处理再渲染到页面,这就要先把数据给js,具体操作方法和直接渲染其实差不多。

在index.html里加上这句代码

image.png

{{}}里边的就是传递过来的数据,和直接渲染是一样的,如果只是一个字符串或者数字,可以直接用{{}}包裹,写到body里。

打开开发者模式,刷新浏览器。

Uncaught SyntaxError: Unexpected token &

是不是报错了,这就对了。

看一下script标签里是什么情况

image.png

说好的数据呢。。。

我们需要在数据传过来之前处理一下。

1、从数据库拿出来的字典或者列表需要用json.dumps处理以下。

2、在模版上还要加safe过滤。

先在模版加safe

image.png

刷新一下,然后看一下script标签

image.png

尖括号这些东西已经没有了,接下来是json.dumps()。

image.png

刷新,还是报错。

是因为我们在存数据的时候有DateTimeField,对于这个dumps不能序列化,需要用到serializers和DjangoJSONEncoder,修改如下:

image.png

刷新

image.png

可以把数据处理一下只把需要的数据传到js,这里就不演示了。

三、mysql数据库

1、查看当前数据库

django自带的是sqlite数据库,如果不想用,可以换成mysql、mongodb或者其他想用的,这里以mysql为例。

首先看一下我们的数据库结构。

在项目根目录下输入

sqlite3

进入sqlite shell,sqlite的命令是.开头的

.help

可以看见所有命令

我们想看数据结构,用.databases,然后用.tables

image.png

可以看见里边有一些自带的表还有我们创建的myapp_article,支持sql命令,想看什么自己看吧。

2、切换mysql数据库

mysql安装过程就不说了,直接开始。

首先新建一个数据库test。

mysql

create database test;

show databases;

会发现又一个test的数据库,切换到这个test

use test;

show tables;

里边是空的没有表

用mysql我们需要安装一个pymysql

pip3 install pymysql

安装之后打开myproject目录下的_init_.py,添加两行代码

import pymysql

pymysql.install_as_MySQLdb()

接下来打开myproject目录下的settings.py,修改如下

image.png

保存之后会发现命令行提示我们要同步数据库

image.png

同步数据库

python manage.py makemigrations

python manage.py migrate

然后开启服务,刷新127.0.0.1:8000发现数据没有了,打开后台管理用之前的账户密码登录也不能登录,说明已经切换到mysql,表都是空的,没有数据,我们看以下刚刚新建的test:

image.png

和之前我们看sqlite的表一样,重复之前后台管理有关的操作,发现没有什么区别一样可以操作数据,切换完成。

django 不用自带的mysql_python笔记二 django自带后台管理系统、模版渲染以及使用mysql数据库...相关推荐

  1. java毕业设计校园二手书交易平台源码+lw文档+mybatis+系统+mysql数据库+调试

    java毕业设计校园二手书交易平台源码+lw文档+mybatis+系统+mysql数据库+调试 java毕业设计校园二手书交易平台源码+lw文档+mybatis+系统+mysql数据库+调试 开发软件 ...

  2. 扫描二维码实现后台管理系统登录

    二维码实现后台登录简单版的过程: 1.前端页面实时生成带有唯一标识uid的二维码,二维码内容为系统内的接口.(后端也可以生成) 2.当扫描二维码时访问后台接口,后台的接口获取uid,组装数据访问微信端 ...

  3. python爬虫10万信息mysql_python爬虫:爬取易迅网价格信息,并写入Mysql数据库

    #!/usr/bin/python # -*- encoding:utf-8 -*- '''思路:1.从易迅网爬取冰箱的数据,包括品牌,型号,价格,容积,能效等级,制冷方式,门款式,显示方式,定频/变 ...

  4. 基于Springboot+mysql手机商城(带后台管理系统)

    项目描述 Springboot+mysql手机商城(带后台管理系统) 运行环境 jdk8+mysql+IntelliJ IDEA+maven 项目技术 springboot+mysql+mybatis ...

  5. 九.django学习笔记二

    django学习之模型 我们在前面已经讲过,模型是专门与数据库交互的部分,那模型是如何实现增删改查的呢,已经如何在项目中使用我们的mysql数据库呢 一.数据库的增删改查 增:book = BookI ...

  6. django 不用自带的mysql_21_django配置使用mysql数据库的两种方式

    配置django项目使用mysql数据库的两种方式 1. 直接在settings.py 文件中添加数据库配置信息 # 配置数据库的第一种方式 DATABASES = { 'default': { 'E ...

  7. MyBatis笔记二:配置

    MyBatis笔记二:配置 1.全局配置 1.properites 这个配置主要是引入我们的 properites 配置文件的: <properties resource="db.pr ...

  8. Python学习笔记--10.Django框架快速入门之后台管理admin(书籍管理系统)

    Python学习笔记--10.Django框架快速入门之后台管理 一.Django框架介绍 二.创建第一个Django项目 三.应用的创建和使用 四.项目的数据库模型 ORM对象关系映射 sqlite ...

  9. Mongodb使用学习笔记(二)

    文章目录 Mongodb使用学习笔记(二)之查询篇 1. MongoDB命令学习 (1) MongoDB 查询文档 1.1 全部查询 1.2 单条件查询 1.3 多条件查询 1.3.1 AND拼接多条 ...

最新文章

  1. 简洁版本 STP/RSTP/MSTP的区别以及各自的特点
  2. 全文检索lucene中文分词的一些总结
  3. procexp.exe中文版---Process Explorer 进程监视V11.21中文版
  4. openshift harp.js heroku react-router 4
  5. python开发自己的工具包_爬虫开发python工具包介绍 (4)
  6. .NET中的异步编程(一)-为什么需要异步
  7. 【英语学习】【WOTD】resuscitate 释义/词源/示例
  8. Qt界面UI之QML初见(学习笔记四)
  9. 仪式与工具--团队管理之规范创立与流程固化过程中必要因素
  10. DNN硬件加速器设计3 -- DNN Accelerators(MIT)
  11. 工具 | CAN总线数据采集工具PCAN的使用教程
  12. 微信小程序打开手机的手电筒
  13. 字体在ppt中可以整体替换吗_在ppt中怎么批量替换字体和图片呢?
  14. 时间开关的工作原理、安装方法及其应用特点
  15. 操作系统-逻辑地址转换为物理地址Java实现
  16. 转载:js和as间的交互
  17. 电子计算机与多媒体短文阅读答案,电子计算机和多媒体习题精选.doc
  18. 滤了asa,cer,cdx,php,aspx等脚本类型的上传情况下添加一个ashx的上传类型
  19. idea中leetcode插件 中文题目乱码问题
  20. Frp内网穿透(四)安卓设备内网穿透

热门文章

  1. 关于MFC的CString 访问越界问题
  2. 012 分析技能冷却二叉树
  3. 13、HTML <meta>标签
  4. 图的邻接矩阵存储和邻接表存储定义方法
  5. MySQL查询的进阶操作--分组查询
  6. 练习C语言二级编程题的一些问题
  7. 【图解Java】这下可以真的弄懂Java IO了~
  8. 我这样写代码,比直接使用 MyBatis 效率提高了 100 倍
  9. 一款基于 Spring Boot 开发 OA 开源产品
  10. 史上最全SQL优化方案