TinyDB - exists() 查询
TinyDB 提供了一个名为 exists() 的高级查询,用于检查 JSON 文件中数据是否存在。 exists() 查询实际上测试 JSON 文件中子字段数据的可用性。 contains() 查询基于布尔条件进行工作。 如果子字段存在(即BOOLEAN TRUE),它将从JSON文件中获取相应的数据,否则将返回空白值。
语法
TinyDB的exists()语法如下 −
db.search(Query().field.exists())
这里,field代表我们想要访问的数据部分。 Query() 是从 JSON 表 student 创建的对象。
我们将使用与前面所有章节中使用的相同的student数据库。
示例 1
让我们对名为"subject"的字段使用 TinyDB exists() 查询 −
db.search(student.subject.exists())
此查询将获取所有行,因为所有行都有"subject"字段 −
[ { "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":" TinyDB ", "address":"benglore" } ]
示例 2
现在让我们使用 exists() 查询"address"字段 −
db.search(student.address.exists())
It will fetch the following rows −
[ { "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":" TinyDB ", "address":"benglore" } ]
示例 3
现在,让我们尝试使用 exists() 查询不可用的字段 −
db.search(student.city.exists())
由于给定表中的所有行都没有名为"city"的字段,因此上面的 contains() 查询将返回空白值 −
[]