python进阶数据库之对象关系映射SQLAalchemy
程序员文章站
2024-03-17 17:19:10
...
一、简介
1、什么是ORM?
- 对象关系映射(Object Relational Mapping,简称ORM)是通过使用描述对象和数据库之间映射的元数据,将面向对象语言程序中的对象自动持久化到关系数据库中。本质上就是将数据从一种形式转换到另外一种形式。 这也同时暗示着额外的执行开销;然而,如果ORM作为一种中间件实现,则会有很多机会做优化,而这些在手写的持久层并不存在。 更重要的是用于控制转换的元数据需要提供和管理;但是同样,这些花费要比维护手写的方案要少;而且就算是遵守ODMG规范的对象数据库依然需要类级别的元数据。
- 对象-关系映射(Object/Relation Mapping,简称ORM),是随着面向对象的软件开发方法发展而产生的。面向对象的开发方法是当今企业级应用开发环境中的主流开发方法,关系数据库是企业级应用环境中永久存放数据的主流数据存储系统。对象和关系数据是业务实体的两种表现形式,业务实体在内存中表现为对象,在数据库中表现为关系数据。内存中的对象之间存在关联和继承关系,而在数据库中,关系数据无法直接表达多对多关联和继承关系。因此,对象-关系映射(ORM)系统一般以中间件的形式存在,主要实现程序对象到关系数据库数据的映射。
- 通俗来讲:ORM,即Object-Relational Mapping(对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,这样,我们在具体的操作业务对象的时候,就不需要再去和复杂的SQL语句打交道,只需简单的操作对象的属性和方法。
- 常见的ORM框架有:Hibernate、TopLink、Castor JDO、Apache OJB等。
- Java中ORM的原理: 先说ORM的实现原理,其实,要实现JavaBean的属性到数据库表的字段的映射,任何ORM框架不外乎是读某个配置文件把JavaBean的属 性和数据库表的字段自动关联起来,当从数据库Query时,自动把字段的值塞进JavaBean的对应属性里,当做INSERT或UPDATE时,自动把 JavaBean的属性值绑定到SQL语句中。
- SQLAlchemy是Python编程语言下的一款开源软件。提供了SQL工具包及对象关系映射(ORM)工具,为高效和高性能的数据库访问设计,实现了完整的企业级持久模型。
2、SQLAlchemy与数据库关系图
二、基本操作
1、安装sqlalchemy
1). 需要一台有安装mysql数据库的机器(已安装)
2). 安装模块: pip install sqlalchemy
pip install sqlalchemy
可见我的电脑这个模块已经包含了。
3). 查看版本信息
4)连接数据库
在sqlalchemy中,session用于创建程序与数据库之间的会话。所有对象的载入和保存都需要通过session对象。
5)创建映射(创建表)
一个映射对应着一个Python类,用来表示一个表的结构。
6)添加单条数据
7)添加多条数据
8)查找数据
在sqlalchemy模块中,查找数据给提供了query()的方法
9)删除数据
例如:
import sqlalchemy
from sqlalchemy import Column,Integer,String
from sqlalchemy.ext.declarative import declarative_base
import pymysql
pymysql.install_as_MySQLdb()
from sqlalchemy.orm import Session, sessionmaker
#创建数据库引擎(连接数据库) echo=True表示显示面向对象的语言转为sql语句
engine=sqlalchemy.create_engine("mysql://root:aaa@qq.com/Blog",
encoding='utf8',echo=True) #用户名、密码、主机名、数据库名
#2)建议缓存
session=sessionmaker(bind=engine)()
#3)创建数据库对象需要继承的基类
Base=declarative_base()
#3)创建类==数据库表
class student_info(Base): #父类为Base才能将面向对象的语言转为sql语句。写表结构信息
#数据库表名称
__tablename__='student_info'
#数据库表属性信息
id=Column(Integer,primary_key=True,autoincrement=True)
name=Column(String(20))
sex=Column(String(20))
def __repr__(self):
return self.name #返回对象绑定的属性:name、sex、id
if __name__ == '__main__':
Base.metadata.create_all(engine) #在数据库中建表
#添加多条数据信息(实例化对象:添加一条数据/记录),为了数据的安全性:先添加到缓存中,再提交到数据库中。
stu1=student_info(id=21,name='westos21',sex='man')#实例化对象:添加一条数据
stu2=student_info(id=31,name='westos31',sex='woman')
stu3=student_info(id=41,name='westos41',sex='man')
session.add_all([stu1,stu2,stu3])
session.commit()
#查询数据信息,此时数据库查找到信息后转换为面向对象的语言输出显示为一个对象,因此需要魔术方法来友好的显示。
print(session.query(student_info).all())
#根据筛选条件查询信息
print(session.query(student_info).filter_by(name='westos31').all())
#删除数据
stu1=session.query(student_info).filter_by(name='westos3').first()
print('before del :',stu1)
session.delete(stu1)
session.commit()
stu1=session.query(student_info).filter_by(name='westos3').first() #再查找一次
print('after del :',stu1)
通俗理解:对象关系映射扮演了一个程序对象到SQL的翻译器的作用。
关于其详细使用方法后面会逐渐进行补充。