当前位置: 首页 > Python编程 > Python编程实战技能 > Python编程基础入门 > python peewee用来干啥的

python peewee用来干啥的

发布时间:2020年09月27日 07:34:10 来源: 点击量:425

【摘要】peewee是一个轻量级的ORM。用的是sqlalchemy内核,采用纯python编写;它提供了多种数据库的访问,如 SqliteDatabase(file or memory)

peewee是一个轻量级的ORM。用的是sqlalchemy内核,采用纯python编写;

它提供了多种数据库的访问,如 SqliteDatabase(file or memory)、MYSQLDatabase、PostgresqlDatabase。

SQLAlchemy和peewee对比

peewee

·优点:

Django式的API,使其易用

轻量实现,很容易和任意web框架集成

·缺点:

不支持自动化 schema 迁移

不能像Django那样,使线上的mysql表结构生成结构化的模型。

SQLAlchemy

·优点:

巨牛逼的API,使得代码有健壮性和适应性

灵活的设计,使得能轻松写复杂查询

·缺点:

工作单元概念不常见

重量级 API,导致长学习曲线

使用

·安装

pip install peewee

·根据sql生成模型

//读取localhost中的ershouche数据表,然后生成模型到db.py
python -m pwiz -e mysql -H localhost -p 3306 -u root -P root  ershouche > db.py

·增删查改

#coding=utf-8
from datetime import datetime
from db import *
database.connect()
# 打印出所有元素
for i in Dmoz.select():
    print i.description
    print i.__dict__
# 增加数据
for i in range(10):
    print Dmoz.create(description="user", link="HuaDong", title="100000%s" % str(i))
# 删除数据
band = Dmoz.get(Dmoz.title == "1000001")
band.delete_instance()
# select语句
band = Dmoz.select().where(Dmoz.title == "1000000").get()
print band.link
# 更改数据
band = Dmoz.get(Dmoz.title == "1000000")
print band.link
band.link = "Beach Boys"
band.save()
print  band.link
# 连表查询,peewee也支持join语句
# album = Album.select().join(Dmoz).where(
#         (Album.title == "Thrive") & amp;
# (Dmoz.name == "Newsboys")
# ).get()
# album.title = "Step Up to the Microphone"
# album.save()

众多python培训视频,尽在python学习网,欢迎在线学习!

分享到: 编辑:wangmin

就业培训申请领取
您的姓名
您的电话
意向课程
点击领取

环球青藤

官方QQ

扫描上方二维码或点击一键加群,免费领取大礼包,加群暗号:青藤。 一键加群

绑定手机号

应《中华人民共和国网络安全法》加强实名认证机制要求,同时为更加全面的体验产品服务,烦请您绑定手机号.

预约成功

本直播为付费学员的直播课节

请您购买课程后再预约

环球青藤移动课堂APP 直播、听课。职达未来!

安卓版

下载

iPhone版

下载
环球青藤官方微信服务平台

刷题看课 APP下载

免费直播 一键购课

代报名等人工服务

课程咨询 学员服务 公众号

扫描关注微信公众号

APP

扫描下载APP

返回顶部