TinyDB - 中介軟體



TinyDB 中介軟體透過包裝現有儲存來幫助我們定製資料庫儲存行為。該中介軟體提高資料庫的效能。

快取中介軟體

此中介軟體(顧名思義)透過減少磁碟 I/O 來提高資料庫的速度。CachingMiddleware 的工作方式如下:-

  • 首先,它捕獲所有讀取操作。

  • 然後在配置的一定次數寫入操作後將資料寫入磁碟。

語法

使用 CachingMiddleware 的語法如下:-

from tinydb.storages import JSONStorage
from tinydb.middlewares import CachingMiddleware
db = TinyDB('middleware.json', storage = CachingMiddleware(JSONStorage))
db.close()

示例

以下示例展示如何在資料庫中執行一個基本的中介軟體過程。

from tinydb import TinyDB
from tinydb.storages import JSONStorage
from tinydb.middlewares import CachingMiddleware
object = TinyDB('storage.json', storage=CachingMiddleware(JSONStorage))
object.all()

輸出

它將產生以下輸出:-

[
   {
      "roll_number":1,
      "st_name":"elen",
      "mark":250,
      "subject":"TinyDB",
      "address":"delhi"
   },
   {
      "roll_number":2,
      "st_name":"Ram",
      "mark":[
         250,
         280
      ],
      "subject":[
         "TinyDB",
         "MySQL"
      ],
      "address":"delhi"
   },
   {
      "roll_number":3,
      "st_name":"kevin",
      "mark":[
         180,
         200
      ],
      "subject":[
         "oracle",
         "sql"
      ],
      "address":"keral"
   },
   {
      "roll_number":4,
      "st_name":"lakan",
      "mark":200,
      "subject":"MySQL",
      "address":"mumbai"
   },
   {
      "roll_number":5,
      "st_name":"karan",
      "mark":275,
      "subject":"oracle",
      "address":"benglore"
   }
]

關閉資料庫以確保所有資料得到安全寫入。

db.close()
廣告