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