电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Python的輕量級ORM框架peewee使用教程

瀏覽:100日期:2022-06-28 11:16:19

ORM框架使用最廣泛的就是SQLAlchemy和Django自帶的ORM框架,但是SQLAlchemy的語法顯然相對Django的ORM框架麻煩一點。

而Django本身是一個web框架,比較重量級,僅僅為了使用Django的ORM框架的功能,而安裝Django有點導致系統臃腫。而peewee這個框架語法幾乎與Django的ORM框架一致,而又非常輕量。

它的安裝非常簡單:

pip install peewee

如果你在使用mysql數據庫的過程中報出如下錯誤:

peewee.ImproperlyConfigured: MySQL driver not installed!

則需要安裝一個mysql的驅動:

pip install pymysql

peewee的whl包是880kB,pymysql的whl包是51KB,非常輕量級。

peewee的官方文檔地址:http://docs.peewee-orm.com/en/latest/index.html

下面測試一下各項功能:

from peewee import *db = MySQLDatabase(’test’, host='localhost', user=’root’, passwd=’123456’, port=3306)# 定義Personclass Person(Model): name = CharField() birthday = DateField() is_relative = BooleanField() class Meta: database = db def test_create(): Person.create_table() # 創建多張表也可以這樣 # database.create_tables([Person])def test_insert(): # 添加一條數據 p = Person(name=’小華’, birthday=date(1996, 12, 20), is_relative=True) p.save()def test_delete(): # 刪除姓名為perter的數據 Person.delete().where(Person.name == ’perter’).execute() # 已經實例化的數據, 使用delete_instance p = Person(name=’小華’, birthday=date(1996, 12, 20), is_relative=False) p.id = 1 p.save() p.delete_instance()def test_update(): # 已經實例化的數據,指定了id這個primary key,則此時保存就是更新數據 p = Person(name=’小華’, birthday=date(1996, 12, 20), is_relative=False) p.id = 1 p.save() # 更新birthday數據 q = Person.update({Person.birthday: date(1983, 12, 21)}).where(Person.name == ’小華’) q.execute()def test_query(): # 查詢單條數據 p = Person.get(Person.name == ’小華’) print(p.name, p.birthday, p.is_relative) # 使用where().get()查詢 p = Person.select().where(Person.name == ’小華’).get() print(p.name, p.birthday, p.is_relative) # 查詢多條數據 persons = Person.select().where(Person.is_relative == True) for p in persons: print(p.name, p.birthday, p.is_relative)

下面測試一個各個方法。

測試創建表:

if __name__=='__main__': Person.create_table()

執行完畢,檢查數據庫成功創建下面這張表:

測試插入數據:

if __name__=='__main__': p = Person(name=’小華’, birthday=date(1996, 12, 20), is_relative=True) p.save()

執行完畢后,表數據多了一行:

測試查詢數據:

if __name__=='__main__': p = Person.get(Person.name == ’小華’) print(p.name, p.birthday, p.is_relative)

結果:

小華 1996-12-20 True測試刪除數據:

if __name__=='__main__': Person.delete().where(Person.name == ’小華’).execute()

執行后,數據庫對應的記錄被刪除:

測試修改數據:

if __name__ == '__main__': p = Person(name=’小新’, birthday=date(1995, 6, 20), is_relative=False) p.save() # 更新birthday數據 q = Person.update({Person.birthday: date(1983, 5, 21)}).where(Person.name == ’小新’) q.execute()測試批量查詢:

if __name__ == '__main__': for i in range(1, 5): p = Person(name=f’小張{i}’, birthday=date(1995, 6, 20), is_relative=False) p.save() # 查詢多條數據 persons = Person.select().where(Person.is_relative == False) for p in persons: print(p.name, p.birthday, p.is_relative)

以上就是Python的輕量級ORM框架peewee使用教程的詳細內容,更多關于Python的輕量級ORM框架peewee的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 扫地车厂家-山西洗地机-太原电动扫地车「大同朔州吕梁晋中忻州长治晋城洗地机」山西锦力环保科技有限公司 | 防腐木批发价格_深圳_惠州_东莞防腐木厂家_森源(深圳)防腐木有限公司 | 广州展览制作|展台制作工厂|展览设计制作|展览展示制作|搭建制作公司 | 开云(中国)Kaiyun·官方网站-登录入口 | 英思科GTD-3000EX(美国英思科气体检测仪MX4MX6)百科-北京嘉华众信科技有限公司 | 成都热收缩包装机_袖口式膜包机_高速塑封机价格_全自动封切机器_大型套膜机厂家 | 抓斗式清污机|螺杆式|卷扬式启闭机|底轴驱动钢坝|污水处理闸门-方源水利机械 | 上海质量认证办理中心| 自进式锚杆-自钻式中空注浆锚杆-洛阳恒诺锚固锚杆生产厂家 | 路斯特伺服驱动器维修,伦茨伺服驱动器维修|万骏自动化百科 | YT保温材料_YT无机保温砂浆_外墙保温材料_南阳银通节能建材高新技术开发有限公司 | 金属检测机_金属分离器_检针验针机_食品药品金属检探测仪器-广东善安科技 | 北京印刷厂_北京印刷_北京印刷公司_北京印刷厂家_北京东爵盛世印刷有限公司 | 无线联网门锁|校园联网门锁|学校智能门锁|公租房智能门锁|保障房管理系统-KEENZY中科易安 | 证券新闻,热播美式保罗1984第二部_腾讯1080p-仁爱影院 | 净化车间装修_合肥厂房无尘室设计_合肥工厂洁净工程装修公司-安徽盛世和居装饰 | 宝宝药浴-产后药浴-药浴加盟-艾裕-专注母婴调养泡浴 | 120kv/2mA直流高压发生器-60kv/2mA-30kva/50kv工频耐压试验装置-旭明电工 | 陕西安玻璃自动感应门-自动重叠门-磁悬浮平开门厂家【捷申达门业】 | 厦门ISO认证|厦门ISO9001认证|厦门ISO14001认证|厦门ISO45001认证-艾索咨询专注ISO认证行业 | 10吨无线拉力计-2吨拉力计价格-上海佳宜电子科技有限公司 | 座椅式升降机_无障碍升降平台_残疾人升降平台-南京明顺机械设备有限公司 | 蒸压釜_蒸养釜_蒸压釜厂家-山东鑫泰鑫智能装备有限公司 | 质检报告_CE认证_FCC认证_SRRC认证_PSE认证_第三方检测机构-深圳市环测威检测技术有限公司 | 钢格板|镀锌钢格板|热镀锌钢格板|格栅板|钢格板|钢格栅板|热浸锌钢格板|平台钢格板|镀锌钢格栅板|热镀锌钢格栅板|平台钢格栅板|不锈钢钢格栅板 - 专业钢格板厂家 | 房间温控器|LonWorks|海思 | 吨袋包装机|吨包秤|吨包机|集装袋包装机-烟台华恩科技 | 纳米二氧化硅,白炭黑,阴离子乳化剂-臻丽拾科技 | 水平垂直燃烧试验仪-灼热丝试验仪-漏电起痕试验仪-针焰试验仪-塑料材料燃烧检测设备-IP防水试验机 | 紧急切断阀_气动切断阀_不锈钢阀门_截止阀_球阀_蝶阀_闸阀-上海上兆阀门制造有限公司 | 混合气体腐蚀试验箱_盐雾/硫化氢/气体腐蚀试验箱厂家-北京中科博达 | 贴片电感_贴片功率电感_贴片绕线电感_深圳市百斯特电子有限公司 贴片电容代理-三星电容-村田电容-风华电容-国巨电容-深圳市昂洋科技有限公司 | 防腐储罐_塑料储罐_PE储罐厂家_淄博富邦滚塑防腐设备科技有限公司 | 北京成考网-北京成人高考网 | 砂尘试验箱_淋雨试验房_冰水冲击试验箱_IPX9K淋雨试验箱_广州岳信试验设备有限公司 | 字典-新华字典-在线字典查字-字典趣| 电磁辐射仪-电磁辐射检测仪-pm2.5检测仪-多功能射线检测仪-上海何亦仪器仪表有限公司 | 网站seo优化_seo云优化_搜索引擎seo_启新网络服务中心 | 视频教程导航网_视频教程之家_视频教程大全_最新视频教程分享发布平台 | 山东成考网-山东成人高考网 | 红外光谱仪维修_二手红外光谱仪_红外压片机_红外附件-天津博精仪器 |