TinyDB - 邏輯非



邏輯非作為一種反向邏輯閘工作。它將匹配不匹配給定查詢的文件。簡單來說,它將顯示給定命令的反義。

語法

TinyDB **邏輯非** 的語法如下:

db.search(~(Query().field)

這裡,**field** 表示我們要訪問的資料部分。**Query()** 是我們名為 **student** 的 JSON 表格建立的物件。它將獲取表示給定命令反義的資料。

讓我們看幾個例子,看看它是如何工作的。我們將使用我們在前面所有章節中使用的相同的 **student** 資料庫。

示例 1

讓我們看看如何從我們的 **student** 表格中查詢學生姓名不是 '**elen**' 的欄位:

from tinydb import TinyDB, Query
db = TinyDB('student.json')
db.search(~(Query().st_name == 'elen'))

上述查詢將獲取學生姓名不是“elen”的所有行。

[
   {
      "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":"TinyDB",
      "address":"benglore"
   }
]

示例 2

讓我們看看如何使用邏輯非避免特定的地址:

from tinydb import TinyDB, Query
db = TinyDB('student.json')
db.search(~(student.address.one_of(['keral', 'delhi'])))

此查詢將獲取“address”欄位既不包含“keral”也不包含“delhi”的所有行。

[
   {
      "roll_number":4,
      "st_name":"lakan",
      "mark":200,
      "subject":"MySQL",
      "address":"mumbai"
   },
   {
      "roll_number":5,
      "st_name":"karan",
      "mark":275,
      "subject":"TinyDB",
      "address":"benglore"
   }
]
廣告