Django学习(2)数据宝库

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 数据库是一所大宝库,藏着各种宝贝。一个没有数据库的网站,功能有限。在Django中,支持的数据库有以下四种:SQLite3MySQLPostgreSQLOracle其中SQLite3为Django自带数据库,无需安装。

数据库是一所大宝库,藏着各种宝贝。一个没有数据库的网站,功能有限。在Django中,支持的数据库有以下四种:

  • SQLite3
  • MySQL
  • PostgreSQL
  • Oracle

其中SQLite3为Django自带数据库,无需安装。Django要求MySQL4.0或更高的版本。
本文将介绍如何在Django中连接并操作MySQL.请确保你的系统里已安装MySQL以及Python模块pymysql.
首先新建项目Book,并在Book项目中新建应用books:

django-admin.py startproject Book
cd ./Book
django-admin.py startapp books

其中Book文件夹的树形结构如下图:
这里写图片描述
在settings.py中添加app:
这里写图片描述
并修改数据库连接方式为MySQL:
这里写图片描述
其中,ENGINE连接方式为MySQL。NAME为数据库名称,我们这里选择Book,前提是你的MySQL中已经创建好Book数据库。USER和PASSWORD为MySQL的用户名和密码。HOST和PORT分别选择本地连接和3306.
这样我们已经连接好MySQL的Book数据库,接下来需要创建表格。这可以在books的models.py中定义,代码如下:

from django.db import models

class MYBOOK(models.Model):
    name = models.CharField(max_length=200)
    price = models.FloatField()
    def __str__(self):
        return self.name+':'+str(self.price)

在上述模型中,我们定义了name和price字段,并用str()函数返回name:price的形式。接着我们需要将Django中的模型与MySQL数据库连接:
这里写图片描述
这里写图片描述
以上表明Django中的模型与MySQL数据库连接完成。我们可以去MySQL中查看:
这里写图片描述
这里写图片描述
其中books_mybook是模型生成的表格,是张空表格。那么该如何操作该表格呢?Django已经帮我们想好办法了,一种是利用shell命令行,一种是在books文件夹的views.py中操作。
首先我们先尝试用shell命令行模式,只需输入以下命令行:

python3 manage.py shell

进入IPython后进行以下操作:

In [1]: from books.models import MYBOOK

In [2]: MYBOOK.objects.create(name="Dive into Python", price=50.5)
Out[2]: <MYBOOK: Dive into Python:50.5>

In [3]: MYBOOK.objects.create(name="Dive into Scala", price=48.6)
Out[3]: <MYBOOK: Dive into Scala:48.6>

In [4]: MYBOOK.objects.create(name="Dive into Java", price=67.4)
Out[4]: <MYBOOK: Dive into Java:67.4>

In [5]: MYBOOK.objects.all()
Out[5]: [<MYBOOK: Dive into Python:50.5>, <MYBOOK: Dive into Scala:48.6>, <MYBOOK: Dive into Java:67.4>]

Django用类的实例表示表格的记录,所以需要导入MYBOOK类。MYBOOK.objects.create(name=”Dive into Python”, price=50.5)表示增加一条记录,MYBOOK.objects.all()则返回所有记录。我们可以去看看这时MySQL中的情况:
这里写图片描述
books_mybook确实已增加了三条记录!!!关于更多的操作数据库的命令可以参考:https://docs.djangoproject.com/en/2.0/topics/db/queries/
第二种方法是在books文件夹的views.py中操作,代码如下:

from django.shortcuts import render
from books.models import MYBOOK
from django.http import HttpResponse

def insert_and_show(request):
    #insert records into table using three methods
    MYBOOK.objects.create(name="Learning Scrapy",price=30)
    p = {'name':"Linux Shell", 'price':25}
    MYBOOK.objects.create(**p)
    q = MYBOOK(name='Learning Pyspark', price=20)
    q.save()
    #show the records in webpage
    book_list = MYBOOK.objects.all()
    string = "TABLE MYBOOK:<br/>"
    for _ in book_list:
        string += str(_)+'<br/><br/>'

    return HttpResponse(string)

该代码前半部分用三种方式插入数据,后半部分则是为了在网页中显示。
在urls.py中增加新的url:
这里写图片描述
启动server服务:

python3 manage.py runserver 8000

在网页中输入http://localhost:8000/book/,输出的内容如下:
这里写图片描述
这表明我们增加记录成功,并且也正确地在web页面显示了!!!
最后,我们再去MySQL中查看:
这里写图片描述
这样我们就完成了用views.py操作MySQL啦~~
当然,更多的内容大家可以参考Django的官方文档哦~~
本次分享到此结束,欢迎大家交流~~



参考文献:
1.Python 快速教程(Django02):庄园疑云: http://python.jobbole.com/82786/
2.Django 模型(数据库): https://code.ziqiangxuetang.com/django/django-models.html
3.Django官方文档: https://docs.djangoproject.com/en/2.0/
4.Django详解之models操作: http://www.mamicode.com/info-detail-1504351.html
5.Django_中文教程.pdf: http://download.csdn.net/download/huangzhichang13/8177581

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
数据采集 自然语言处理 监控
【优秀python毕设案例】基于python django的新媒体网络舆情数据爬取与分析
本文介绍了一个基于Python Django框架开发的新媒体网络舆情数据爬取与分析系统,该系统利用Scrapy框架抓取微博热搜数据,通过SnowNLP进行情感分析,jieba库进行中文分词处理,并以图表和词云图等形式进行数据可视化展示,以实现对微博热点话题的舆情监控和分析。
1212 110
【优秀python毕设案例】基于python django的新媒体网络舆情数据爬取与分析
|
编解码 前端开发 JavaScript
技术经验分享:Django学习日记
技术经验分享:Django学习日记
|
IDE 关系型数据库 MySQL
Django学习一:创建Django框架,介绍Django的项目结构和开发逻辑。创建应用,编写主包和应用中的helloworld
这篇文章是关于如何创建一个Django框架,介绍Django的项目结构和开发逻辑,并指导如何创建应用和编写“Hello, World!”程序的教程。
736 3
Django学习一:创建Django框架,介绍Django的项目结构和开发逻辑。创建应用,编写主包和应用中的helloworld
|
12月前
|
SQL 监控 数据库
深入探索Django ORM:高效数据操作的秘诀与实践####
在当今的Web开发领域,提升数据访问层的效率是优化应用性能的关键。本文旨在通过剖析Django框架中的ORM(对象关系映射)机制,揭示其如何简化数据库交互,并探讨一系列高级技巧与策略,帮助开发者构建更高效、可维护的数据访问代码。我们不涉及安装步骤或基础概念,而是聚焦于实战经验分享,旨在为中高级开发者提供深度洞见。 ####
|
JavaScript 前端开发 Python
django接收前端vue传输的formData图片数据
django接收前端vue传输的formData图片数据
226 4
|
数据库 数据安全/隐私保护 数据库管理
#765372#基于django和neo4j的通用数据展示系统
#765372#基于django和neo4j的通用数据展示系统
128 1
|
SQL Java 数据库
Django学习三:views业务层中通过models对实体对象进行的增、删、改、查操作。
这篇文章是关于如何使用Django框架的ORM系统在视图(views)层面进行数据库的增、删、改、查操作的教程。
118 0
Django学习三:views业务层中通过models对实体对象进行的增、删、改、查操作。
|
关系型数据库 MySQL Java
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
这篇文章是关于如何使用Django框架配置MySQL数据库,创建模型实例,并自动或手动创建数据库表,以及对这些表进行操作的详细教程。
448 0
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
|
搜索推荐 关系型数据库 MySQL
#874358#基于django/neo4j的电视剧浏览数据推荐系统
#874358#基于django/neo4j的电视剧浏览数据推荐系统
363 0
|
监控 数据可视化 前端开发
基于python django生产数据与计划大屏,可链接数据库
本文介绍了一个基于Python Django框架开发的生产数据与计划大屏系统,该系统能够实时采集和展示生产数据,支持数据可视化和实时更新,以提高生产监控的效率和质量。
265 3