思想架构DjanggoJava

ORM介绍

2018-10-22  本文已影响77人  甚得朕心

ORM概念

  对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。

简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据库中。

ORM在业务逻辑层和数据库层之间充当了桥梁的作用。

ORM由来

O是object,也就类对象的意思,R是relation,翻译成中文是关系,也就是关系数据库中数据表的意思,M是mapping,是映射的意思。在ORM框架中,它帮我们把类和数据表进行了一个映射,可以让我们通过类和类对象就能操作它所对应的表格中的数据。ORM框架还有一个功能,它可以根据我们设计的类自动帮我们生成数据库中的表格,省去了我们自己建表的过程。

几乎所有的软件开发过程中都会涉及到对象和关系数据库。在用户层面和业务逻辑层面,我们是面向对象的。当对象的信息发生变化的时候,我们就需要把对象的信息保存在关系数据库中。

按照之前的方式来进行开发就会出现程序员会在自己的业务逻辑代码中夹杂很多SQL语句用来增加、读取、修改、删除相关数据,而这些代码通常都是重复的。

ORM的优劣势

Django框架中ORM示意图

Selection_001.png
Selection_002.png

实例操作

数据库操作

上面我们提到过,在设置中设置关联数据库的时候,我们写了一个名字,但是数据库是不会自动生成的,所以需要我们进入数据库后,手动创建。

  1. 首先登录数据库


    Selection_007.png
  2. 创建我们在设置中所设置的数据库名字

注意:设置字符集为utf8

Selection_008.png

更改配置

我们演示使用MySQL数据库,这是Web项目首选的数据库。

  1. 进入虚拟环境

workon book

  1. 然后在/Documents/project_book目录下创建文件ORM_text。


    Selection_003.png

cd ORM_text
python3 manage.py startappbooktest

  1. 在ORM_text文件的settings.py中找到DATABASES项,其默认是使用SQLite3数据库,现在我们要对其设置,改成mysql。


    Selection_004.png
    原有的设置如图: Selection_005.png
    更改成如下图:
    Selection_006.png

数据库ORM Django框架不会自动生成,需要我们自己进入mysql数据库去创建。

  1. 在虚拟环境中安装mysql

pip install pymysql

安装成功之后,在ORM/init.py文件中加上如下代码:

import pymysql
pymysql.install_as_MySQLdb()

  1. 在ORM_text/models.py中添加我们所想要实现的类
from django.db import models
from django.db import models
#定义图书模型类BookInfo
class BookInfo(models.Model):
    btitle = models.CharField(max_length=20)#图书名称
    bpub_date = models.DateField()#发布日期
    bread = models.IntegerField(default=0)#阅读量
    bcomment = models.IntegerField(default=0)#评论量
    isDelete = models.BooleanField(default=False)#逻辑删除

#定义英雄模型类HeroInfo
class HeroInfo(models.Model):
    hname = models.CharField(max_length=20)#英雄姓名
    hgender = models.BooleanField(default=True)#英雄性别
    isDelete = models.BooleanField(default=False)#逻辑删除
    hcomment = models.CharField(max_length=200)#英雄描述信息
    hbook = models.ForeignKey('BookInfo')#英雄与图书表的关系为一对多,所以属性定义在英雄模型类中
  1. 执行生成迁移文件和迁移

python manage.py makemigrations
python manage.py migrate

7.在数据库中就可以看到相应的表结构


Selection_010.png

数据库中的表名称,是项目名称+类名称的小写。

数据的操作和显示

在数据库的表中插入我们许要的数据

  1. 进入数据库ORM然后添加book_info的内容
insert into booktest_bookinfo(btitle,bpub_date,bread,bcomment,isDelete) values
('射雕英雄传','1980-5-1',12,34,0),
('天龙八部','1986-7-24',36,40,0),
('笑傲江湖','1995-12-24',20,80,0),
('雪山飞狐','1987-11-11',58,24,0);
  1. 添加hero_info的内容
insert into booktest_heroinfo(hname,hgender,hbook_id,hcomment,isDelete) values
('郭靖',1,1,'降龙十八掌',0),
('黄蓉',0,1,'打狗棍法',0),
('黄药师',1,1,'弹指神通',0),
('欧阳锋',1,1,'蛤蟆功',0),
('梅超风',0,1,'九阴白骨爪',0),
('乔峰',1,2,'降龙十八掌',0),
('段誉',1,2,'六脉神剑',0),
('虚竹',1,2,'天山六阳掌',0),
('王语嫣',0,2,'神仙姐姐',0),
('令狐冲',1,3,'独孤九剑',0),
('任盈盈',0,3,'弹琴',0),
('岳不群',1,3,'华山剑法',0),
('东方不败',0,3,'葵花宝典',0),
('胡斐',1,4,'胡家刀法',0),
('苗若兰',0,4,'黄衣',0),
('程灵素',0,4,'医术',0),
('袁紫衣',0,4,'六合拳',0);
  1. 然后我们在表中能看到相应的内容。
  2. 定义视图
    打开booktest/views.py文件,定义视图代码如下:
from django.shortcuts import render,redirect
from booktest.models import *
from datetime import date
#查询所有图书并显示
def index(request):
    list=BookInfo.objects.all()
    return render(request,'booktest/index.html',{'list':list})

#创建新图书
def create(request):
    book=BookInfo()
    book.btitle = '流星蝴蝶剑'
    book.bpub_date = date(1995,12,30)
    book.save()
    #转向到首页
    return redirect('/')

#逻辑删除指定编号的图书
def delete(request,id):
    book=BookInfo.objects.get(id=int(id))
    book.delete()
    #转向到首页
    return redirect('/')
  1. 配置url 打开ORM/urls.py文件,配置url如下:
from django.conf.urls import include, url
from django.contrib import admin

urlpatterns = [
    url(r'^admin/', include(admin.site.urls)),
    #引入booktest的url配置
    url(r'^',include('booktest.urls')),
]

在booktest应用下创建urls.py文件。

from django.conf.urls import url
from booktest import views

urlpatterns=[
    url(r'^$',views.index),
    url(r'^delete(\d+)/$',views.delete),
    url(r'^create/$',views.create),
]
6. 创建模板 打开ORM/settings.py文件,配置模板查找目录TEMPLATES的DIRS。
> 'DIRS': [os.path.join(BASE_DIR,'templates')],
  1. 创建index.html文件。在templates/booktest/下

完成创建之后的文件列表如图所示:


Selection_011.png
上一篇下一篇

猜你喜欢

热点阅读