Django学习(2)数据宝库

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

  • SQLite3
  • MySQL
  • PostgreSQL
  • Oracle
    其中SQLite3为Django自带数据库,无需安装。Django要求MySQL版本4.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
'''
遇到不懂的问题?Python学习交流群:821460695满足你的需求,资料都已经上传群文件,可以自行下载!
'''
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啦~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值