Python | 轻量ORM框架Peewee的基础使用(增删改查、自动创建模型类、事务装饰器)

文章目录

  • 01 简介
  • 02 安装
  • 03 自动创建模型类
  • 04 基础使用
    • 4.1 查询
    • 4.2 新增
    • 4.3 更新
    • 4.4 删除
  • 05 事务


01 简介

在使用python开发的过程中,有时需要一些简单的数据库操作,而Peewee正是理想的选择,它是一个小巧而灵活的 Python ORM(对象关系映射)框架,用于简化数据库操作。

本文基于mysql数据库,介绍最基础和常用的用法。

官方文档:
https://docs.peewee-orm.com/en/latest/index.html

GitHub上目前已有10.5k Star:
https://github.com/coleifer/peewee

02 安装

# 安装peewee库
pip install peewee
# 安装mysql数据库客户端
pip install pymysql

03 自动创建模型类

假设我有一个名为test的数据库,其中有一张名为user的表,此时可以通过命令自动创建该数据库下各个表的映射模型类:

python -m pwiz -e <db_type> -H <host> -p <port> -u <username> -P <db_name> > model.py

其中:

  • db_type:数据库类型,例如mysql
  • host:数据库主机地址
  • port:端口
  • username:数据库连接的用户名
  • db_name:数据库名称

示例:

python -m pwiz -e mysql -H 192.168.0.25 -p 3306 -u root -P test > model.py

执行后,会让输入数据库连接密码,而后会在cmd启动的所在目录下生成一个model.py文件。

注意:刚生成的model.py文件编码可能与系统不同,例如我显示是UTF-16LE编码,需要转换为与项目其他.py文件相同的编码。

在这里插入图片描述
在这里插入图片描述

创建好的模型类:

from peewee import *database = MySQLDatabase('test', **{'charset': 'utf8', 'sql_mode': 'PIPES_AS_CONCAT', 'use_unicode': True,'host': '...', 'port': 3306, 'user': 'root', 'password': '...'})class UnknownField(object):def __init__(self, *_, **__): passclass BaseModel(Model):class Meta:database = databaseclass User(BaseModel):age = IntegerField(null=True)email = CharField(null=True)name = CharField()class Meta:table_name = 'user'

这里面的User类对应的就是我数据库中的user表,模型类虽然不显式包含主键字段,但使用user.id可以查看得到。

  • 操作结束后建议关闭连接:
database.close()

04 基础使用

4.1 查询

  • 查询所有用户
# 查询所有用户
users = User.select()# 看看有多少条数据
print(len(users))# 查看第0条数据
print(users[0])# 查看所有数据
for user in users:print(user)  # 每个user都是User模型对象 这里print会输出主键值print(user, user.name, user.age, user.email)
  • 查询特定属性
users = User.select(User.name, User.age)
for user in users:print(user.name, user.age)
  • 条件查询
# 使用where实现条件查询
young_users: ModelSelect = User.select().where(User.age < 35)
for user in young_users:print(user, user.name, user.age, user.email)
  • 查询单个用户
# 使用get 直接返回一个User对象
user = User.get(User.name == '张三')
print(user.name, user.name)
  • 根据主键查询
# get_by_id()方法
user = User.get_by_id(3)
print(user.name)
  • 多条件、排序、LIMIT
SELECT name FROM `user` WHERE name = '张三' AND email = 'xxx@qq.com' ORDER BY age DESC LIMIT 5;

转换为:

query = User.select(User.name).where((User.name == '张三') & (User.email == 'xxx@qq.com')).order_by(User.age.desc()).limit(20)
  • 子查询示例
SELECT * FROM `user` WHERE id NOT IN (SELECT id FROM user_new);

转换:

inner_query = User.select(User.id);
query = User.select().where(User.id.not_in(inner_query))

4.2 新增

# 会在数据库新增数据 同时也会返回这个新对象
user = User.create(name="王五", age=28, email=None)
print(user.name)

4.3 更新

# 注意最后要加execute()
User.update(email='xxx@qq.com').where(User.name == '王五').execute()

4.4 删除

# 条件删除
User.delete().where(User.name == '张三').execute()# 按照id删除 不需要execute()
User.delete_by_id(2)

更新和删除操作,往往要在最后加execute()

05 事务

使用atomic装饰器实现原子操作:

# 创建数据库连接
database = MySQLDatabase(...)# 在方法上使用装饰器来保证原子操作 注意这里的()符号不能省略
@database.atomic()
def func():User.update(age=20).where(User.name == "张三").execute()User.update(age=21).where(User.name == "李四").execute()# 结束后关闭连接
database.close()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/238609.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

探索数据之美:深入学习Plotly库的强大可视化

1. 引言&#xff1a; Plotly 是一个交互性可视化库&#xff0c;可以用于创建各种漂亮的图表和仪表板。它支持多种编程语言&#xff0c;包括Python、R、JavaScript。在Python中&#xff0c;Plotly提供了Plotly Express和Graph Objects两个主要的绘图接口。 2. Plotly库简介&am…

6.8 Windows驱动开发:内核枚举Registry注册表回调

在笔者上一篇文章《内核枚举LoadImage映像回调》中LyShark教大家实现了枚举系统回调中的LoadImage通知消息&#xff0c;本章将实现对Registry注册表通知消息的枚举&#xff0c;与LoadImage消息不同Registry消息不需要解密只要找到CallbackListHead消息回调链表头并解析为_CM_NO…

助力android面试2024【面试题合集】

转眼间&#xff0c;2023年快过完了。今年作为口罩开放的第一年大家的日子都过的十分艰难&#xff0c;那么想必找工作也不好找&#xff0c;在我们android开发这一行业非常的卷&#xff0c;在各行各业中尤为突出。android虽然不好过&#xff0c;但不能不吃饭吧。卷归卷但是还得干…

STM32F407-14.3.9-01输出比较模式

输出比较模式 此功能用于控制输出波形&#xff0c;或指示已经过某一时间段。 当捕获/比较寄存器与计数器之间相匹配时&#xff0c;输出比较功能&#xff1a; ● 将为相应的输出引脚分配一个可编程值&#xff0c;该值由输出比较模式&#xff08;TIMx_CCMRx 寄存器中的 OCxM⑦…

【QuickSort】单边快排思路及实现

思路&#xff1a; &#xff08;1&#xff09;首先定义一个递归函数&#xff1a;qucikSort(int [ ] arr,int l,int r)。函数的定义&#xff1a;给定一个数组arr&#xff0c;对它在[l,r]这个区间内的元素进行排序&#xff0c;从而使得整个数组在[l,r]这个区间内有序。 &#xff0…

蓝牙概述及基本架构介绍

蓝牙概述及基本架构介绍 1. 概述1.1 蓝牙的概念1.2 蓝牙的发展历程1.3 蓝牙技术概述1.3.1 Basic Rate(BR)1.3.2 Low Energy&#xff08;LE&#xff09; 2. 蓝牙的基本架构2.1 芯片架构2.2 协议架构2.2.1 官方协议中所展示的蓝牙协议架构2.2.1.1 全局分析2.2.1.2 局部分析 2.2.2…

Syntax Error: TypeError: Cannot read properties of undefined (reading ‘styles‘)

日志只有这一行&#xff0c;比较难排查 排查途径&#xff1a; 1、从上图找到唯一的文件输出output.js&#xff0c;断点查看堆栈信息&#xff0c;如下图&#xff0c;可以看到这个错误是由于哪个文件引起的 以为从App.vue中定位到原因了&#xff0c;其实也不对&#xff0c;继续…

SQL Server数据库部署

数据库简介 使用数据库的必要性 使用数据库可以高效且条理分明地存储数据&#xff0c;使人们能够更加迅速、方便地管理数据。数据库 具有以下特点。 》可以结构化存储大量的数据信息&#xff0c;方便用户进行有效的检索和访问。 》 可以有效地保持数据信息的一致性&#xff0c…

CGAL的三维曲面网格生成

1、介绍 此程序包提供了一个函数模板&#xff0c;用于计算三角网格&#xff0c;以近似表面。 网格化算法要求仅通过一个能够判断给定线段、直线或射线是否与曲面相交&#xff0c;并且如果相交则计算交点的oracle来了解待网格化的表面。这一特性使该软件包具有足够的通用性&…

读书笔记-《数据结构与算法》-摘要1[数据结构]

文章目录 [数据结构]1. String - 字符串2. Linked List - 链表2.1 链表的基本操作2.1.1 反转链表单向链表双向链表 2.1.2 删除链表中的某个节点2.1.3 链表指针的鲁棒性2.1.4 快慢指针 3. Binary Tree - 二叉树3.1 树的遍历3.2 Binary Search Tree - 二叉查找树 4. Queue - 队列…

人工智能-优化算法之学习率调度器

学习率调度器 到目前为止&#xff0c;我们主要关注如何更新权重向量的优化算法&#xff0c;而不是它们的更新速率。 然而&#xff0c;调整学习率通常与实际算法同样重要&#xff0c;有如下几方面需要考虑&#xff1a; 首先&#xff0c;学习率的大小很重要。如果它太大&#xf…

acwing算法基础之动态规划--数位统计DP、状态压缩DP、树形DP和记忆化搜索

目录 1 基础知识2 模板3 工程化 1 基础知识 暂无。。。 2 模板 暂无。。。 3 工程化 题目1&#xff1a;求a~b中数字0、数字1、…、数字9出现的次数。 思路&#xff1a;先计算1~a中每位数字出现的次数&#xff0c;然后计算1~b-1中每位数字出现的次数&#xff0c;两个相减即…