Date: 2019-06-03

Author: Sun

什么是ORM?

​ ORM(object relational mapping), 就是对象关系映射,简单来说我们类似python这种面向对象的程序来说一切皆对象,但是我们使用的数据库却都是关系型的,为了保证一致的使用习惯,通过orm将编程语言的对象模型和数据库的关系模型建立映射关系,这样我们在使用编程语言对数据库进行操作的时候可以直接使用编程语言的对象模型进行操作就可以了,而不用直接使用sql语言。

ORM作用: 对象模型(类) 《====》 关系模型 进行关联

​ 用户只需要操作类就可以实现操作数据库

ORM 相当于把数据库也实例化,在代码操作mysql中级又加了orm这一层。

ORM 的优点:

  1. 隐藏了数据访问细节,“封闭”的通用数据库交互,ORM的核心。他使得我们的通用数据库交互变得简单易行,并且完全不用考虑该死的SQL语句。快速开发,由此而来。
  2. ORM使我们构造固化数据结构变得简单易行。

sqlalchemy

在Python中,最有名的ORM框架是SQLAlchemy。用户包括openstack\Dropbox等知名公司或应用.

安装依赖库:

pip install pymysql

pip install sqlalchemy

SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据API执行SQL并获取执行结果。SQLAlchemy本身无法操作数据库,其必须以来pymsql等第三方插件,Dialect用于和数据API进行交流,根据配置文件的不同调用不同的数据库API,从而实现对数据库的操作:

相关连接语句如下:

MySQL - Python   (python2.7推荐)
mysql+mysqldb://<user>:<password>@<host>[:<port>]/<dbname> pymysql (python3.5以上版本推荐使用)
mysql+pymysql://<username>:<password>@<host>:<port>/<dbname>[?<options>] MySQL - Connector
mysql + mysqlconnector: // < user >: < password > cx_Oracle (oracle数据连接)
oracle+cx_oracle://user:pass@host:port/dbname[?key=value&key=value...]

ORM 案例分析

# -*- coding: utf-8 -*-
__author__ = 'sun'
__date__ = '2018/6/7 上午9:33' '''
采用sqlalchemy定义实体类,进行ORM操作
依赖库:
pip install sqlalchemy
pip install pymysql
'''
from sqlalchemy import create_engine from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker from sqlalchemy import Column, Integer, String, ForeignKey '''
数据库连接拼接串语法:
mysql_conn_str = "mysql+pymysql://username:password@IP:PORT/database"
''' mysql_conn_str = "mysql+pymysql://django:123456@172.16.245.202:3306/toscrape"
engine = create_engine(mysql_conn_str) Base = declarative_base() class Book(Base):
__tablename__ = "toscrape_book"
id = Column(Integer, primary_key=True) #create id column, set it auto_increment.
book_title = Column(String(200))
image_url = Column(String(300))
book_url = Column(String(300))
book_rate = Column(String(50))
book_price = Column(String(15)) '''
初始化DB,进行模型 --> 数据库 同步
'''
def _create_db_table():
Base.metadata.create_all(engine) def create_session():
_create_db_table()
Session = sessionmaker(bind=engine)
session = Session()
#session = sessinmaker(bind=engine)()
return session '''
add record to session.
objs --> (1) [obj1, obj2] (2) obj
'''
def add_records(session, objs):
if isinstance(objs, list):
session.add_all(objs)
else:
session.add(objs)
session.commit() '''
查询数据模型中的db数据
'''
def query_records(session, Cls):
return session.query(Cls).all() if __name__ == "__main__":
session = create_session()
'''
records = query_records(session, Book)
for rec in records:
print("title: " + rec.book_title + ", image_url:" + rec.image_url)
''' book = Book(book_title='xxx', image_url='xxx', book_url='xxx', book_rate='2.0',
book_price='xxx')
add_records(session, book)

相关参考文档:

https://blog.csdn.net/fgf00/article/details/52949973

作业:

采用python ORM相关技术,实现一个学生班级信息管理模块

模型说明:

  1. 学生(学生姓名, 学生性别,年龄,所属班级)

  2. 班级(班级名称)

    一个班级有多个学生,班级id是学生表中的外键

    功能说明:

​ (1)实现数据模型定义,同步到数据库DB

​ (2)班级和学生信息的添加功能(提供外部传参函数就行,下面雷同)

​ (3) 班级和学生信息的更新和删除功能

Python-ORM实战的更多相关文章

  1. 【图文详解】python爬虫实战——5分钟做个图片自动下载器

    python爬虫实战——图片自动下载器 之前介绍了那么多基本知识[Python爬虫]入门知识,(没看的先去看!!)大家也估计手痒了.想要实际做个小东西来看看,毕竟: talk is cheap sho ...

  2. Python开发实战教程(8)-向网页提交获取数据

    来这里找志同道合的小伙伴!↑↑↑ Python应用现在如火如荼,应用范围很广.因其效率高开发迅速的优势,快速进入编程语言排行榜前几名.本系列文章致力于可以全面系统的介绍Python语言开发知识和相关知 ...

  3. Python爬虫实战(4):豆瓣小组话题数据采集—动态网页

    1, 引言 注释:上一篇<Python爬虫实战(3):安居客房产经纪人信息采集>,访问的网页是静态网页,有朋友模仿那个实战来采集动态加载豆瓣小组的网页,结果不成功.本篇是针对动态网页的数据 ...

  4. Python爬虫实战(2):爬取京东商品列表

    1,引言 在上一篇<Python爬虫实战:爬取Drupal论坛帖子列表>,爬取了一个用Drupal做的论坛,是静态页面,抓取比较容易,即使直接解析html源文件都可以抓取到需要的内容.相反 ...

  5. Spring MVC 程序首页的设置 - 一号门-程序员的工作,程序员的生活(java,python,delphi实战)

    body { font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI ...

  6. python机器学习实战(一)

    python机器学习实战(一) 版权声明:本文为博主原创文章,转载请指明转载地址 www.cnblogs.com/fydeblog/p/7140974.html  前言 这篇notebook是关于机器 ...

  7. python机器学习实战(二)

    python机器学习实战(二) 版权声明:本文为博主原创文章,转载请指明转载地址 http://www.cnblogs.com/fydeblog/p/7159775.html 前言 这篇noteboo ...

  8. python机器学习实战(三)

    python机器学习实战(三) 版权声明:本文为博主原创文章,转载请指明转载地址 www.cnblogs.com/fydeblog/p/7277205.html  前言 这篇notebook是关于机器 ...

  9. python机器学习实战(四)

    python机器学习实战(三) 版权声明:本文为博主原创文章,转载请指明转载地址 www.cnblogs.com/fydeblog/p/7364317.html 前言 这篇notebook是关于机器学 ...

  10. selenium2 python自动化测试实战(回归测试)

    selenium2 python自动化测试实战 最近接手商城的项目,针对后台测试,功能比较简单,但是流程比较繁多,涉及到前后台的交叉测试.在对整个项目进行第一轮测试完成之后,考虑以后回归测试任务比较重 ...

随机推荐

  1. nginx强制使用https访问(多站点多域名配置)

    很多配置过https模板的人都知道,配置https 时 ,站在用户的角度http 和https 的区别根本不清楚.有时候敲 http 时会出现 404 错误,而实际上我们是https. 有朋友找我配置 ...

  2. Mybatis批量插入的代码实现

    简单的学习总结一下,希望能帮到需要的同学! 1.mapper.xml文件sql语句如下: <insert id="insertBatch" parameterType=&qu ...

  3. ubuntu的安装

    前言 对计算机的学习来说,使用Linux系统是有好处的,Windows是商业的,无法学习操作系统的内在东西,所以选择折腾Linux. 我选择了ubuntu作为学习系统,Linux发行版没有什么最好之说 ...

  4. python第三周:集合、函数、编码、文件

    1.集合: 集合的创建: list_1 = set([1,2,3,4,5]) list_2 = set([2,3,44,7,8]) 集合的特性:集合是无序的,集合可以去掉重复的元素 集合的操作:求交集 ...

  5. ubuntu17.04中启动tnsorboard过程

    ubuntu17.04中启动tnsorboard过程 首先激活tensorboard,找到根目录文件(注:跟tensorflow文件同级)找到tensorboard文件的main.py文件 然后找到程 ...

  6. Git学习总结(11)——Git撤销操作详解

    本文主要讨论和撤销有关的 git 操作.目的是让读者在遇到关于撤销问题时能够方便迅速对照执行解决问题,而不用去翻阅参数繁多的 git 使用说明. 一开始你只需了解大致功能即可,不必记住所有命令和具体参 ...

  7. Jquery Math ceil()、floor()、round()比较与用法

    Math.ceil():向上取值 如:Math.ceil(2.1) --  结果为  3 Math.ceil(-2.1)  -- 结果为-2 结论:正入 负舍 Math.floor(): 先下取值 入 ...

  8. 在WPF的MVVM框架中获取下拉选择列表中的选中项

    文章概述: 本演示介绍怎样在WPF的MVVM框架中.通过数据绑定的方式获取下拉列表中的选中项.程序执行后的效果例如以下图所看到的: 相关下载(代码.屏幕录像):http://pan.baidu.com ...

  9. 学习笔记一:关于directx sdk的安装于一些概念

    关于directx sdk开发环境的安装: 在百度搜索了directx sdk,进入了微软的官网,下载了DXSDK_Jun10.exe 百度网盘:http://pan.baidu.com/s/1o6r ...

  10. mysql安装出错cannot create windows service for mysql.error:0

    配置时最后一步出现不能启动mysql 解决成功的办法:[MySQL] Could not start the service MySQL 解决方法 安装mysql 5.1.33,在运行Server I ...