使用peewee模块操作数据库
1. 简介
Peewee 是一个 Python ORM(Object-Relational Mapping)库,支持 SQLite、MySQL、PostgreSQL 和 Cockroach 数据库。在 ORM 系统中,每个类都映射到底层数据库中的一个表。ORM可以处理这些问题,我们就不需要自己编写乏味的数据库接口代码,可以专注于对系统逻辑进行编程。
2. 定义模型
类名为表名,在类中定义字段名称、类型、是否有空值等信息
from peewee import * db = SqliteDatabase('people.db') class Person(Model): name = CharField() birthday = DateField(null=True) class Meta: database = db # This model uses the "people.db" database. class Pet(Model): owner = ForeignKeyField(Person, backref='pets') name = CharField() animal_type = CharField() class Meta: database = db
如果操作已经存在的数据库表,我们可以通过以下命令生成模型文件
指定数据库名,host,用户名,密码,数据库,模板文件名
python -m pwiz -e mysql -H localhost -p 3306 -u user -P 123456 database > db.py
3. 表格操作
3.1 创建表格
db.create_tables([Person, Pet])
3.2 删除表格
db.drop_tables([Person, Pet])
4. 数据增删改查
4.1 新增数据
- 保存单条数据
from datetime import date uncle_bob = Person(name='Bob', birthday=date(1960, 1, 15)) uncle_bob.save()
- 一次性插入多条数据
Person.insert_many([{'name':'Bob', 'birthday':'2002-01-01'}, {'name':'Tom', 'birthday':'1999-05007'}]) .execute()
4.2 按条件删除数据
删除Tweet实例中创建日期为一年以前的数据
Tweet.delete().where(Tweet.creation_date < one_year_ago).execute()
teewee中
in
的使用
Person.delect().where(Person.name.in_(['Bob','Tom'])).execute()
4.3 更新/修改数据
Table.update(**kwargs).where((Table.datadate==datadate) & (Table.account_id==account_id)).execute()
4.4 查询数据
grandma = Person.select().where(Person.name == 'Grandma L.').get()
等价于
grandma = Person.get(Person.name == 'Grandma L.')
将查询到的数据转为DataFrame:
先用dicts()
方法将数据转化为字典格式,再转为DatFrame
df = pd.DataFrame(Table.select().where(Table.datadate==today).dicts())
df = pd.DataFrame(Table.select(Table.col1, Table.col2, Table.col3).where(Table.datadate==today).dicts())
更多内容可以查看官方文档
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律