2020-04-10--Django2

MVC/MVT介绍

MVC的全拼为Model-View-Controller,最早由TrygveReenskaug在1978年提出,是施乐帕罗奥多研究中心(Xerox PARC)在20世纪80年代为程序语言Smalltalk发明的一种软件设计模式,是为了将传统的输入(input)、处理(processing)、输出(output)任务运用到图形化用户交互模型中而设计的。随着标准输入输出设备的出现,开发人员只需要将精力集中在业务逻辑的分析与实现上。后来被推荐为Oracle旗下Sun公司Java EE平台的设计模式,并且受到越来越多的使用ColdFusion和PHP的开发者的欢迎。现在虽然不再使用原来的分工方式,但是这种分工的思想被沿用下来,广泛应用于软件工程中,是一种典型并且应用广泛的软件架构模式。后来,MVC的思想被应用在了Web开发方面,被称为Web MVC框架。
MVC框架的核心思想是:解耦,让不同的代码块之间降低耦合,增强代码的可扩展性和可移植性,实现向后兼容。

Web MVC各部分的功能:

  • M全拼为Model,主要封装对数据库层的访问,对数据库中的数据进行增、删、改、查操作。
  • V全拼为View,用于封装结果,生成页面展示的html内容。
  • C全拼为Controller,用于接收请求,处理业务逻辑,与Model和View交互,返回结果。


Django简介

Django,发音为[`dʒæŋɡəʊ],是用python语言写的开源web开发框架,并遵循MVC设计。劳伦斯出版集团为了开发以新闻内容为主的网站,而开发出来了这个框架,于2005年7月在BSD许可证下发布。这个名称来源于比利时的爵士音乐家DjangoReinhardt,他是一个吉普赛人,主要以演奏吉它为主,还演奏过小提琴等。由于Django在近年来的迅速发展,应用越来越广泛,被著名IT开发杂志SDTimes评选为2013SDTimes100,位列"API、库和框架"分类第6位,被认为是该领域的佼佼者。Django的主要目的是简便、快速的开发数据库驱动的网站。它强调代码复用,多个组件可以很方便的以"插件"形式服务于整个框架,Django有许多功能强大的第三方插件,你甚至可以很方便的开发出自己的工具包。这使得Django具有很强的可扩展性。它还强调快速开发和DRY(DoNotRepeatYourself)原则。
Django框架遵循MVC设计,并且有一个专有名词:MVT

Django MVT介绍

MVT各部分功能

  • M全拼为Model,与MVC中的M功能相同,负责和数据库交互,进行数据处理。
  • V全拼为View,与MVC中的C功能相同,接收请求,进行业务处理,返回应答。
  • T全拼为Template,与MVC中的V功能相同,负责封装构造要返回的html。
    差异就在于黑线黑箭头标识出来的部分


利用django框架进行数据库开发

我们之前操作数据库是通过写sql语句,那么能不能不写sql语句就可以操作数据库呢? 可以,就是通过接下来要给大家讲的ORM框架

1.ORM框架

O是object,也就类对象的意思,R是relation,翻译成中文是关系,也就是关系数据库中数据表的意思,M是mapping,是映射的意思。在ORM框架中,它帮我们把类和数据表进行了一个映射,可以让我们通过类和类对象就能操作它所对应的表格中的数据。ORM框架还有一个功能,它可以根据我们设计的类自动帮我们生成数据库中的表格,省去了我们自己建表的过程。
django中内嵌了ORM框架,不需要直接面向数据库编程,而是定义模型类,通过模型类和对象完成数据表的增删改查操作。
使用django进行数据库开发的步骤如下:

  1. 在models.py中定义模型类
  2. 迁移
  3. 通过类和对象完成数据增删改查操作

1.1在model.py文件下定义模型类

from django.db import models

# Create your models here.
class BookInfo(models.Model):
    #书名,models.CharField 字符串类型,字符串的最大长度为20
    btitle = models.CharField(max_length=20)
    #出版日期
    bpub_date = models.DateField()

定义一个类BookInfo,继承models.Model
属性:

  • btitle :书名
  • bpub_date:出版日期
    说明:不需要定义主键列,在生成时会自动添加,并且值为自动增长。

1.2迁移

1.生成迁移文件
首先打开cmd 输入workon py_django1 然后cd 到 django1文件夹
生成迁移文件命令如下:




2.执行迁移文件



当执行迁移命令后,Django框架会读取迁移文件自动帮我们在数据库中生成对应的表格。

Django默认采用sqlite3数据库,上图中的db.sqlite3就是Django框架帮我们自动生成的数据库文件。 sqlite3是一个很小的数据库,通常用在手机中,它跟mysql一样,我们也可以通过sql语句来操作它。

下面使用pycharm自带的datasource打开db.sqlite3文件进行查看
点击右侧datasource然后新建SQLite数据库




找到项目存放位置中的db.sqlite文件



点击Text Connection,有错误信息,要download sqlite

点击apply,ok
打开db.sqlite文件

刷新



默认生成的表名称
细心的同学会发现我们上面生成的表的名字叫做booktest_bookinfo,booktest是应用的名字,bookinfo是模型类的名字。
数据表的默认名称为
_
例:
booktest_bookinfo

1.3使用命令行shell操纵数据库(增删改查)

完成数据表的迁移之后,下面就可以通过进入项目的shell,进行简单的API操作。如果需要退出项目,可以使用ctrl+d快捷键或输入quit()。
进入项目shell的命令:
在终端执行以下命令:


#导入模块
from booktest.models import BookInfo
b=BookInfo()    #对象实例化
b.btitle = '神雕侠侣'      #赋值
from datetime import date     #导入时间模块
b.bpub_date = date(1992,1,1)     #赋值
b.save()               #保存

在pycharm中点击刷新


2.1在model.py中在添加一个英雄表

model.py:

from django.db import models

# Create your models here.
class BookInfo(models.Model):
    #书名,models.CharField 字符串类型,字符串的最大长度为20
    btitle = models.CharField(max_length=20)
    #出版日期
    bpub_date = models.DateField()
#迁移
class HeroInfo(models.Model):
    hname = models.CharField(max_length=20)    #姓名
    hgender = models.BooleanField(default=False)   #性别(默认为男性)
    hcomment = models.CharField(max_length=100)    #备注
    #这两个表是一对多关系,设置一对多的外键,参数是对应表的类名
    hbook = models.ForeignKey('BookInfo')

重复上边操作

  1. 在cmd中生成迁移文件
python manage.py makemigrations

生成迁移文件


  1. 执行迁移文件
python manage.py migrate

刷新pycharm中的数据库表,出现了新的表


2.2在python shell中操作数据库表

>>>from booktest.models import BookInfo,HeroInfo
>>>BookInfo.objects.all()  
[]
>>> b= BookInfo.objects.get(id=1)  #把id为一的对象赋给b
>>> b          

>>> b.btitle
'神雕侠侣'
>>> b.bpub_date
datetime.date(1992, 1, 1)
>>> b.delete()      #删除b对象中的那内容
>>> b

>>> BookInfo.objects.all()        #查询表中所有内容
[]

删除后,表中没有内容


>>> h = HeroInfo()   #实例化英雄类
>>> h.hname = '扫地僧'   #赋值
>>> h.hcomment = '这是高手'
>>> b

>>> b.save()     #之前删除了,在存一遍
>>> b.btitle = '天龙八部'   #修改
>>> b.save()     #保存

表中title修改了



定义外键

 h.hbook = b #把b对象存入hbook中

HeroInfo表:


image.png
#查询b对象中所有的英雄信息
 b.heroinfo_set.all()  
[]

你可能感兴趣的:(2020-04-10--Django2)