面试题第七关:
第一部分——考点:
- 了解常用的ORM框架;
- 使用SQLObject框架操作MySQL数据库。
第二部分——面试题:
1.面试题一:在Python语言中有哪些常用的ORM框架,它们有什么区别?
2.面试题二:如何使用SQLObject框架操作MySQL数据库?
第三部分——解析:
面试题一 之 Python语言中有哪些常用的ORM框架以及它们的区别:
在Python语言中主要有以下两个常用的ORM框架:
- SQLAlchemy
- SQLObject
它们俩的区别:
- SQLAlchemy框架偏向于SQL,可以灵活地提交SQL语句;
- 而SQLObject框架更加面向对象,无法自由使用原生的SQL语句。
面试题二 之 使用SQLObject框架操作MySQL数据库:
- 第一题提到的两个框架都需要安装:
pip install sqlobject
- 创建表:
# 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查看:
- 插入数据:
使用Navicat查看:
- 修改数据:
使用Navicat查看:
4.查询数据:
- 删除数据:
使用Navicat查看:
第四部分——知识点补给站:
首先,关于ORM简单聊几嘴:
对于像Python这样的面向对象的语言来说 ,一切皆对象 ,但是我们使用的数据库都是关系型的。 为了保证一致的使用习惯 ,我们就需要使用ORM在编程语言的对象模型和数据库的关系模型之间建立映射关系 ,这样我们在操作数据库时就可以直接使用编程语言的对象模型 ,而不用使用sql语言。
而ORM到底是什么呢?
-
英文全称object relational mapping(对象映射关系程序)
-
对象和关系之间的映射,让我们可以使用面向对象的方式来操作数据库。
-
把任何一个sql语句都封装成对象操作。关系模型和Python对象之间的映射如下:
| table -> class | 表映射为类 |
| row -> object | 行映射为实例 |
| column -> property | 字段映射为属性 |
🔆In The End!
👑有关于Me
个人简介:我是一个硬件出身的计算机爱好者,喜欢program,源于热爱,乐于分享技术与所见所闻所感所得。文章涉及Python,C,单片机,HTML/CSS/JavaScript及算法,数据结构等。
| 从现在做起,坚持下去,一天进步一小点,不久的将来,你会感谢曾经努力的你! |
|---|
认真仔细看完本文的小伙伴们,可以点赞收藏并评论出你们的读后感。并可关注本博主,在今后的日子里阅读更多技术文哦~
如有错误或者言语不恰当的地方可在评论区指出,谢谢!
如转载此文请联系我征得本人同意,并标注出处及本博主名,谢谢 !