您的位置:首页 > 数据库

数据库全库搜索简单实现

2012-06-19 23:48 239 查看
这里说的数据库搜索不是指全文检索,如果是全文检索,针对非结构化数据,可以采用常用的全文检索软件提供的接口实现,比如lucence,sphinx等开源软件实现,设计到大数量的问题,不属于本文考虑的问题。

一般数据库系统中存储的都是结构化的数据,每个字段的数据量很小,针对这样的数据进行全文搜索,如果是单个表,可以穷举各个字段,获得各个字段大致是采用resultset.getDatabaseMetaDate函数,然后对各个字段采用 like 'keyword‘等,如果不是一个关键词,可以按空格对输入的字符串进行切割,一般来说,输入的单词之间是与关系。这里要把这些 select 语句 采用 union 关键词组合起来,即结果集组合,union表示结果集没有重复,union
all 表示有重复,所以union执行时会效率有所降低。

如果针对多个表,采用类似的方法,对每个表进行遍历。最终得到结果集。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: