Python:輕量級 ORM 框架 peewee 用法詳解

来源:https://www.cnblogs.com/gl1573/archive/2019/02/15/10380793.html
-Advertisement-
Play Games

peewee 是一個輕量級的 Python ORM 框架,個人用下來感覺還好,簡單易上手,對於小項目能滿足大部分需求。peewee 的官方文檔沒有中文版的,網上的文章都是快速入門,抄了文檔中幾個例子,沒有詳細介紹的。本文略長,詳細介紹了增刪改查操作,並且詳解介紹了使用過程中遇到的各種問題。 ...


說明:peewee 中有很多方法是延時執行的,需要調用 execute() 方法使其執行。下文中不再特意說明這個問題,大家看代碼。

本文中代碼樣例所使用的 Person 模型如下:

class Person(Model):
    Name = CharField()
    Age = IntegerField()
    Birthday = DateTimeField()
    Remarks = CharField(null=True)

一、新增

1、create

Model.create 向資料庫中插入一條記錄,並返回一個新的實例。

p = Person.create(Name='張三', Age=30, Birthday=date(199011))

2、save

語法:

save(force_insert=False, only=None)

參數:

  • force_insert:是否強制插入
  • only(list):需要持久化的欄位,當提供此參數時,只有提供的欄位被持久化。

示例:

p1 = Person(Name='王五', Age=50, Birthday=date(1970, 1, 1))
p1.save()

這裡說的比較簡單,下麵會詳細說明。

3、insert

insert 只插入數據而不創建模型實例,返回新行的主鍵。

Person.insert(Name='李四', Age=40, Birthday=date(198011)).execute()

4、insert_many

語法:

insert_many(rows, fields=None)

參數:

  • rows:元組或字典列表,要插入的數據
  • fields(list):需要插入的欄位名列表。

說明:
1、當 rows 傳遞的是字典列表時,fields 是不需要傳的,如果傳了,那麼,rows 中的欄位在字典中必須存在,否則報錯。如果沒有傳遞 fields 參數,那麼預設取所有字典的交集作為插入欄位。這個也好理解,比如一個字典的鍵是a、b、c,一個是 b、c、d,那麼就取 b、c 作為需要插入的欄位。peewee 不會為缺失的欄位做預設處理。
2、當 rows 傳遞的是元組列表時,必須指定 fields,並且 fields 中欄位名的順序跟元組一致。元組中值的數量必須大於等於 fields 中欄位的數量,一般建議是保持一致。

示例:

Person.insert_many([
    ('張三'30date(199011)),
    ('李四'40date(198011)),
    ('王五'50date(197011))
],
    ['Name''Age''Birthday']
).execute()

Person.insert_many([
    {'Name''張三''Age'30'Birthday'date(199011)},
    {'Name''李四''Age'40'Birthday'date(198011)},
    {'Name''王五''Age'50'Birthday'date(197011)}
]
).execute()

對於批量操作,應該放在事務中執行:

with db.atomic():
    Person.insert_many(data, fields=fields).execute()

在使用批量插入時,如果是 SQLite,SQLite3 版本必須為 3.7.11.0 或更高版本才能利用批量插入API。此外,預設情況下,SQLite 將 SQL 查詢中的綁定變數數限製為 999。

SQLite 中,當批量插入的行數超過 999 時,就需要使用迴圈來將數據批量分組:

with db.atomic():
    for idx in range(0len(data), 100):
        Person.insert_many(data[idx: idx+100], fields=fields).execute()

Peewee 中帶有一個分塊輔助函數 chunked(),使用它可以有效地將通用迭代塊分塊為一系列批量迭代的迭代:

from peewee import chunked

# 一次插入 100 行.
with db.atomic():
    for batch in chunked(data, 100):
        Person.insert_many(batch).execute()

5、bulk_create

語法:

bulk_create(model_list, batch_size=None)

參數:

  • model_list (iterable):未保存的模型實例的列表或其他可迭代對象。
  • batch_size (int):每次批量插入的行數。如果未指定,則一次性全部插入。

示例:
簡單來說,insert_many 使用字典或元組列表作為參數,而 model_list 使用模型實例列表作為參數,就這區別。

data = [Person(Name='張三~', Age=30, Birthday=date(199011)),
        Person(Name='李四~', Age=40, Birthday=date(198011))]
with db.atomic():
    Person.bulk_create(data)

註意:如果使用的是 Postgresql(支持該RETURNING子句),則先前未保存的模型實例將自動填充其新的主鍵值。

例如用的是 SQLite,執行上述代碼之後,print(data[0].id) 顯示的結果是 None

6、batch_commit

這不是一個好的方法,來看下麵的例子

data_dict = [{'Name''張三''Age'30'Birthday'date(199011)},
             {'Name''李四''Age'40'Birthday'date(198011)},
             {'Name''王五''Age'50'Birthday'date(197011)}]

for row in db.batch_commit(data_dict, 100):
    p = Person.create(**row)

查看 SQL 語句如下:

('BEGIN', None)
('
INSERT INTO "person" ("Name""Age""Birthday"VALUES (?, ?, ?)', ['張三', 30, datetime.date(1990, 1, 1)])
('
INSERT INTO "person" ("Name""Age""Birthday"VALUES (?, ?, ?)', ['李四', 40, datetime.date(1980, 1, 1)])
('
INSERT INTO "person" ("Name""Age""Birthday"VALUES (?, ?, ?)', ['王五', 50, datetime.date(1970, 1, 1)])

其實,batch_commit 就是自動添加了一個事務,然後一條條的插入,所以返回的模型實例中能獲取到主鍵。
參數第一個是字典列表,第二個就是每多少條啟用一個事務,大家可以把它改成 1 看下 SQL 語句就明白了。

7、insert_from

使用 SELECT 查詢作為源 INSERT 數據。此 API 應用於 INSERT INTO … SELECT FROM … 形式的查詢。

語法:

insert_from(query, fields)

參數:

  • query:SELECT查詢用作數據源
  • fields:要將數據插入的欄位,此參數必須要的
    示例:我們將 Person 表按原結構複製一個 Person2 表出來,以做演示。
data = Person.select(Person.Name, Person.Age, Person.Birthday)
Person2.insert_from(data, ['Name''Age''Birthday']).execute()

註意: 因為是 INSERT INTO … SELECT FROM … 形式的,所以數據源的列跟要插入的列必須保持一致。

二、刪除

1、delete

delete 後加 where 刪除指定記錄,如果不加 where,則刪除全部記錄。

Person.delete().where(Person.Name=='王五').execute()

2、delete_instance

刪除給定的實例。
語法:

delete_instance(recursive=False, delete_nullable=False)

示例:


              
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 通過瀏覽器訪問url時候瀏覽器會攜帶cookie,可利用cookie進行信息驗證如用戶驗證,cookie前後端都可獲取設置,後端用self.get_cookie和self.set_cookie,前端可用document.cookie 獲取設置,根據前端document的這個方法結合Date()方法自... ...
  • 在寫移動端導航的時候經常用到點擊按鈕出現/隱藏導航條的情況,最常見的方法當然還是前端框架直接調用,省心省力,不易出錯;當然還有使用純JS實現的小代碼段。我這裡整理了純CSS實現方式,給需要的人和給自己做個筆記: 實現原理利用CSS偽類:target 可以配合CSS3過渡做出很多不同的效果,具體不做詳 ...
  • echo.js的github地址:https://github.com/toddmotto/echo echo是一個獨立的JavaScript、輕量級的、延遲圖片載入插件,echo壓縮後體積不到1k,使用html的標準data-*屬性,echo支持IE8+。 一般將其放在滾動事件的下麵: <img ...
  • 1. 通過 id 查找 HTML 元素 2. 通過標簽名查找 HTML 元素 ...
  • 在 CSS3 之前,web 設計師必須使用已在用戶電腦上安裝好的字體。 通過 CSS3,web 設計師可以使用他們喜歡的任意字體。 當您找到或購買到希望使用的字體時,可將該字體文件存放到 web 伺服器上,它會在需要時被自動下載到用戶的電腦上。 您“自己的”的字體是在 CSS3 @font-fa ...
  • 簡介: 單例模式是一種簡單的設計模式,但是要在程式設計中使用好單例模式,卻需要註意幾個地方。 單例模式意味著在整個系統中,單例類只能有一個實例對象,且需要自行完成實例化,並始終對外提供同一個實例對象。 單例模式實現方式: 餓漢模式: 懶漢模式(單線程版): 上述懶漢模式有延遲載入的意思,但是沒有考慮 ...
  • 1、兩種創建方式 使用字面量創建時只會生成一個對象,而通過構造方法創建時會生成兩個對象(前面的str2和後面的new String對象) 2、常見的構造方法 3、其它常用方法 4、String、StringBuffer、StringBuilder 4.1、String是不可變的字元序列,在定義時長度 ...
  • 【New責任鏈&裝飾者】 感慨一下,本以為上下篇能一起發呢,結果要隔一定時間,傳統的責任鏈與裝飾者模式:https://www.cnblogs.com/SharePointApp/p/10340578.html 基本代碼 現在要做的就是責任鏈如果使用外置模式,能不能像裝飾者一樣幾個處理類聯合處理?答 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...