PHP前端开发

Python中的ORM框架Peewee详解

百变鹏仔 4小时前 #Python
文章标签 详解

python中的orm框架peewee详解

ORM(对象关系映射)是一种将对象与关系数据库之间进行映射的技术。本文将介绍一个Python中的ORM框架Peewee。Peewee是一个轻量级、易用、灵活的ORM框架,支持SQLite、MySQL、PostgreSQL等多种数据库。本文将介绍Peewee的安装、基本用法、高级用法以及与其他ORM框架的比较。

  1. 安装Peewee

Peewee可以通过pip进行安装。在终端中输入以下命令即可安装:

pip install peewee
  1. 基本用法

(1)数据库连接

在使用Peewee前,需要先进行数据库连接。下面的代码展示了如何通过Peewee连接SQLite数据库:

立即学习“Python免费学习笔记(深入)”;

from peewee import *db = SqliteDatabase('my_database.db')

其中,my_database.db为SQLite数据库的名称,如果该数据库文件不存在,则会在当前目录下创建该文件。

Peewee还支持MySQL、PostgreSQL等数据库,只需要将SqliteDatabase替换为对应的数据库即可。比如,下面的代码展示了如何通过Peewee连接MySQL数据库:

db = MySQLDatabase('my_database', user='my_user', password='my_password', host='my_host', port=3306)

(2)定义模型

Peewee使用模型来描述数据库中的表。每一个模型代表一张表,每个属性则代表表中的一个字段。下面的代码定义了一个模型User,其中包含id和name两个字段:

class User(Model):    id = AutoField(primary_key=True)    name = CharField()    class Meta:        database = db

其中,AutoField代表自增主键,primary_key=True表示该字段为主键,CharField代表字符串类型。

(3)创建表

在定义完模型之后,需要对应的数据库中创建对应的表。Peewee提供了create_table方法来创建表,代码如下:

User.create_table()

(4)插入数据

Peewee提供了save方法来将数据插入到数据库中。下面的代码插入了一条数据:

user = User(name='张三')user.save()

(5)查询数据

Peewee提供了get和select方法来查询数据。其中,get方法用于查询单条数据,select方法用于查询多条数据。下面的代码查询了所有名字为张三的用户:

users = User.select().where(User.name == '张三')for user in users:    print(user.id, user.name)
  1. 高级用法

(1)关联查询

Peewee支持外键关联查询。下面的代码定义了一个模型Order,其中包含id、user和product三个字段:

class Order(Model):    id = AutoField(primary_key=True)    user = ForeignKeyField(User, backref='orders')    product = CharField()    class Meta:        database = db

其中,ForeignKeyField代表外键,backref='orders'表示通过User.orders可以访问到该用户的所有订单。

可以通过join方法进行关联查询,如下所示:

orders = Order.select().join(User).where(User.name == '张三')for order in orders:    print(order.id, order.user.name, order.product)

(2)事务操作

Peewee支持事务操作。可以将多个对数据库的操作封装在with db.atomic()中,代码如下:

with db.atomic() as txn:    user1 = User(name='张三')    user1.save()    user2 = User(name='李四')    user2.save()    for i in range(10):        order = Order(user=user1, product='product_' + str(i))        order.save()        order = Order(user=user2, product='product_' + str(i))        order.save()
  1. 与其他ORM框架的比较

与Django自带的ORM框架相比,Peewee更加轻量级,使用也更加灵活。与SQLAlchemy相比,Peewee的语法更加简洁明了,同时也提供了许多方便的高级用法。

总之,Peewee是一个值得推荐的Python ORM框架,由于其灵活和易用,它在许多项目中也被广泛使用。