MongoDB之索引(全文索引)
发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,在一些信息管理平台上经常需要进行信息模糊查询,最早的时候是在某个字段上实现的模糊查询,但是这个时候返回的信息并不会很准确,因为只能够查A字段或者是B字段,而在MongoDB里面实现了非常简单的全文检索
千家信息网最后更新 2025年11月08日MongoDB之索引(全文索引)在一些信息管理平台上经常需要进行信息模糊查询,最早的时候是在某个字段上实现的模糊查询,但是这个时候返回的信息并不会很准确,因为只能够查A字段或者是B字段,而在MongoDB里面实现了非常简单的全文检索。
范例:定义一个新的集合
db.news.insert({"title":"stoneA","content":"ttA"});
db.news.insert({"title":"stoneB","content":"ttB"});
db.news.insert({"title":"stoneC","content":"ttC"});
db.news.insert({"title":"stoneD","content":"ttD"});
范例:创建全文索引
> db.news.createIndex({"title":"text","content":"text"});
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
范例:实现数据的模糊查询
如果要想表示出全文检索,则使用"$text"判断符,而要想进行数据的查询则使用"$search"运算符:
● 查询指定的关键字:{"$search":"查询关键字"}
● 查询多个关键字(或关系):{"$search":"查询关键字 查询关键字 ..."}
● 查询多个关键字(与关系):{"$search":"\"查询关键字\" \"查询关键字\" ..."}
● 查询多个关键字(排除某一个):{"$search":"查询关键字 查询关键字 ...-排查关键字"}
范例:查询单个内容
> db.news.find({"$text":{"$search":"stoneA"}})
{ "_id" : ObjectId("5992c4310184ff511bf02bbb"), "title" : "stoneA", "content" : "ttA" }
范例:查询包含有"stoneA"和"stoneB"的信息
> db.news.find({"$text":{"$search":"stoneA stoneB"}})
{ "_id" : ObjectId("5992c4310184ff511bf02bbc"), "title" : "stoneB", "content" : "ttB" }
{ "_id" : ObjectId("5992c4310184ff511bf02bbb"), "title" : "stoneA", "content" : "ttA" }
范例:查询同时包含有"ttC"和"ttD"
> db.news.find({"$text":{"$search":"\"ttC\" \"ttD\""}})
{ "_id" : ObjectId("5992c61d0184ff511bf02bc1"), "title" : "stoneC", "content" : "ttC ttD ttE" }
{ "_id" : ObjectId("5992c61d0184ff511bf02bc2"), "title" : "stoneD", "content" : "ttC ttD ttF" }
范例:查询包含有"ttE"但是不包含"ttF"
> db.news.find({"$text":{"$search":"ttE -ttF"}})
{ "_id" : ObjectId("5992c61d0184ff511bf02bc1"), "title" : "stoneC", "content" : "ttC ttD ttE" }
但是在进行全文检索操作的时候还可以使用相似度的打分来判断检索结果。
范例:为查询结果打分
> db.news.find({"$text":{"$search":"ttC ttD ttE"}},{"score":{"$meta":"textScore"}}).sort({"score":{"$meta":"textScore"}})
{ "_id" : ObjectId("5992c61d0184ff511bf02bc1"), "title" : "stoneC", "content" : "ttC ttD ttE", "score" : 2 }
{ "_id" : ObjectId("5992c61d0184ff511bf02bc2"), "title" : "stoneD", "content" : "ttC ttD ttF", "score" : 1.3333333333333333 }
按照打分的成绩进行排列,实际上就可以实现更加准确的信息搜索。
如果一个集合的字段太多了,那么每一个字段都分别设置全文索引比较麻烦,简单一些,可以为所有字段设置全文索引。
范例:为所有字段设置全文索引
> db.news.dropIndexes()
{
"nIndexesWas" : 2,
"msg" : "non-_id indexes dropped for collection",
"ok" : 1
}
> db.news.createIndex({"$**":"text"});
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
这是一种最简单的设置全文索引的方式,但是尽可能别用,会慢。
范例:定义一个新的集合
db.news.insert({"title":"stoneA","content":"ttA"});
db.news.insert({"title":"stoneB","content":"ttB"});
db.news.insert({"title":"stoneC","content":"ttC"});
db.news.insert({"title":"stoneD","content":"ttD"});
范例:创建全文索引
> db.news.createIndex({"title":"text","content":"text"});
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
范例:实现数据的模糊查询
如果要想表示出全文检索,则使用"$text"判断符,而要想进行数据的查询则使用"$search"运算符:
● 查询指定的关键字:{"$search":"查询关键字"}
● 查询多个关键字(或关系):{"$search":"查询关键字 查询关键字 ..."}
● 查询多个关键字(与关系):{"$search":"\"查询关键字\" \"查询关键字\" ..."}
● 查询多个关键字(排除某一个):{"$search":"查询关键字 查询关键字 ...-排查关键字"}
范例:查询单个内容
> db.news.find({"$text":{"$search":"stoneA"}})
{ "_id" : ObjectId("5992c4310184ff511bf02bbb"), "title" : "stoneA", "content" : "ttA" }
范例:查询包含有"stoneA"和"stoneB"的信息
> db.news.find({"$text":{"$search":"stoneA stoneB"}})
{ "_id" : ObjectId("5992c4310184ff511bf02bbc"), "title" : "stoneB", "content" : "ttB" }
{ "_id" : ObjectId("5992c4310184ff511bf02bbb"), "title" : "stoneA", "content" : "ttA" }
范例:查询同时包含有"ttC"和"ttD"
> db.news.find({"$text":{"$search":"\"ttC\" \"ttD\""}})
{ "_id" : ObjectId("5992c61d0184ff511bf02bc1"), "title" : "stoneC", "content" : "ttC ttD ttE" }
{ "_id" : ObjectId("5992c61d0184ff511bf02bc2"), "title" : "stoneD", "content" : "ttC ttD ttF" }
范例:查询包含有"ttE"但是不包含"ttF"
> db.news.find({"$text":{"$search":"ttE -ttF"}})
{ "_id" : ObjectId("5992c61d0184ff511bf02bc1"), "title" : "stoneC", "content" : "ttC ttD ttE" }
但是在进行全文检索操作的时候还可以使用相似度的打分来判断检索结果。
范例:为查询结果打分
> db.news.find({"$text":{"$search":"ttC ttD ttE"}},{"score":{"$meta":"textScore"}}).sort({"score":{"$meta":"textScore"}})
{ "_id" : ObjectId("5992c61d0184ff511bf02bc1"), "title" : "stoneC", "content" : "ttC ttD ttE", "score" : 2 }
{ "_id" : ObjectId("5992c61d0184ff511bf02bc2"), "title" : "stoneD", "content" : "ttC ttD ttF", "score" : 1.3333333333333333 }
按照打分的成绩进行排列,实际上就可以实现更加准确的信息搜索。
如果一个集合的字段太多了,那么每一个字段都分别设置全文索引比较麻烦,简单一些,可以为所有字段设置全文索引。
范例:为所有字段设置全文索引
> db.news.dropIndexes()
{
"nIndexesWas" : 2,
"msg" : "non-_id indexes dropped for collection",
"ok" : 1
}
> db.news.createIndex({"$**":"text"});
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
这是一种最简单的设置全文索引的方式,但是尽可能别用,会慢。
查询
关键
关键字
范例
全文
字段
索引
信息
检索
全文检索
多个
时候
数据
是在
结果
相似
内容
单个
同时
实际
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全的童诗童谣五十字
四川天鉴恒网络安全技术
各医院病历数据库连通吗
温州嵌入式软件开发项目
数据库怎么删除特定人名
分离后的数据库还存在吗
阿里云数据库链接地址
数据库批量添加注释快捷键
数据库管理系统支持的语言
拳头账号怎样更换服务器
ibm服务器生产日期
java实现通知其他服务器
服务器系统更安全嘛
福建回收服务器主板
软件开发者路线图第五章
access数据库or
进口网络技术服务质量保证
西集国家网络安全产业园地铁
软件开发专业技能怎么写
删数据库法律怎么判
白宫 网络安全
闽南契约数据库
数据库查询数据时间最后的
JCREATOR下载软件开发
四川省农行软件开发中心
软件开发考研就业
计算机网络安全要求
伯利兹 服务器
修改数据库表中查询到的数据
广州net软件开发哪家便宜