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"
   }
]