数据库的全文搜索
程序员文章站
2022-05-15 15:00:32
...
这里说的数据库搜索不是指全文检索,如果是全文检索,针对非结构化数据,可以采用常用的全文检索软件提供的接口实现,比如lucence,sphinx等开源软件实现,设计到大数量的问题,不属于本文考虑的问题。
一般数据库系统中存储的都是结构化的数据,每个字段的数据量很小,针对这样的数据进行全文搜索,如果是单个表,可以穷举各个字段,获得各个字段大致是采用resultset.getDatabaseMetaDate函数,然后对各个字段采用 like 'keyword‘等,如果不是一个关键词,可以按空格对输入的字符串进行切割,一般来说,输入的单词之间是与关系。这里要把这些 select 语句 采用 union 关键词组合起来,即结果集组合,union表示结果集没有重复,union all 表示有重复,所以union执行时会效率有所降低。
如果针对多个表,采用类似的方法,对每个表进行遍历。最终得到结果集。
一般数据库系统中存储的都是结构化的数据,每个字段的数据量很小,针对这样的数据进行全文搜索,如果是单个表,可以穷举各个字段,获得各个字段大致是采用resultset.getDatabaseMetaDate函数,然后对各个字段采用 like 'keyword‘等,如果不是一个关键词,可以按空格对输入的字符串进行切割,一般来说,输入的单词之间是与关系。这里要把这些 select 语句 采用 union 关键词组合起来,即结果集组合,union表示结果集没有重复,union all 表示有重复,所以union执行时会效率有所降低。
如果针对多个表,采用类似的方法,对每个表进行遍历。最终得到结果集。
上一篇: 我们应当怎样做需求分析
下一篇: DES加密解密
推荐阅读