Python每日一练——数据存储第七关:ORM框架知多少

Posted 孤寒者

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python每日一练——数据存储第七关:ORM框架知多少相关的知识,希望对你有一定的参考价值。

面试题第七关:

第一部分——考点:

  1. 了解常用的ORM框架;
  2. 使用SQLObject框架操作mysql数据库。

第二部分——面试题:

1.面试题一:在Python语言中有哪些常用的ORM框架,它们有什么区别?

2.面试题二:如何使用SQLObject框架操作MySQL数据库?


第三部分——解析:

面试题一 之 Python语言中有哪些常用的ORM框架以及它们的区别:

在Python语言中主要有以下两个常用的ORM框架:

  1. SQLAlchemy
  2. SQLObject

它们俩的区别:

  • SQLAlchemy框架偏向于SQL,可以灵活地提交SQL语句;
  • 而SQLObject框架更加面向对象,无法自由使用原生的SQL语句。

面试题二 之 使用SQLObject框架操作MySQL数据库:

  • 第一题提到的两个框架都需要安装:
    pip install sqlobject
  1. 创建表:
# coding=utf-8
# _author__ = 孤寒者

from sqlobject import *

        #                                   库名
mysql = 'mysql://root:123456@localhost:3306/test?charset=utf8'
                                                # 用pymysql与sqlalchemy交互~
sqlhub.processConnection = connectionForURI(mysql, driver='pymysql')

class Person(SQLObject):
    class sqlmeta:
        table = 'new_persons'
    name = StringCol(length = 30)
    age = IntCol()
    address = StringCol(length = 30)
    salary = FloatCol()

# 习惯性创建一个新表之前先删除~  (是个好习惯哦!)
try:
    Person.dropTable()
except:
    pass
Person.createTable()

使用Navicat查看:

  1. 插入数据:
    使用Navicat查看:
  2. 修改数据:

使用Navicat查看:

4.查询数据:

  1. 删除数据:

使用Navicat查看:


第四部分——知识点补给站:

首先,关于ORM简单聊几嘴:

对于像Python这样的面向对象的语言来说 ,一切皆对象 ,但是我们使用的数据库都是关系型的。 为了保证一致的使用习惯 ,我们就需要使用ORM在编程语言的对象模型和数据库的关系模型之间建立映射关系 ,这样我们在操作数据库时就可以直接使用编程语言的对象模型 ,而不用使用sql语言。

而ORM到底是什么呢?

  • 英文全称object relational mapping(对象映射关系程序)

  • 对象和关系之间的映射,让我们可以使用面向对象的方式来操作数据库。

  • 把任何一个sql语句都封装成对象操作。关系模型和Python对象之间的映射如下:

table -> class表映射为类
row -> object行映射为实例
column -> property字段映射为属性

以上是关于Python每日一练——数据存储第七关:ORM框架知多少的主要内容,如果未能解决你的问题,请参考以下文章

Python每日一练——数据存储第二关:XML文档和字典的互转

Python每日一练——数据存储第五关:操作SQLite数据库

Python每日一练——数据存储第六关:操作MySQL数据库

Python每日一练——数据存储第三关:如何将一个JSON文档映射为Python对象

Python每日一练——数据存储第一关:读取XML节点和属性值的方法

Python每日一练——数据存储第四关:如何将一个Python对象转换为对应的JSON字符串