当前位置:  数据库>sqlserver

SQL Server全文检索查询浅析

    来源: 互联网  发布时间:2014-09-05

    本文导语:  方案概要:   1. 改变文件存储时的文件名   2. 配置索引服务器,并将索引服务器与MS SQL Server关联。   3. 修改SQL语句,将进行全文查询语句的内容加入查询条件中   文件的存储方式:   为了方便存储以及方便索引...

方案概要:
  1. 改变文件存储时的文件名
  2. 配置索引服务器,并将索引服务器与MS SQL Server关联。
  3. 修改SQL语句,将进行全文查询语句的内容加入查询条件中
  文件的存储方式:
  为了方便存储以及方便索引,我们将上传的文件存储到一个目录里面,为了保证上传的文件名不重复,采用GUID作为文件名,并且通过这个GUID于数据库记录相关联。同时,文件的后缀还保持原始文件的后缀,让索引服务能够识别该文档。
  配置索引服务
  进入计算机管理(Computer Management)程序(右键”我的电脑”->”管理”),并找到索引服务(Index Service)
  配置索引服务的功能
  (1)右键选择索引服务弹出一个菜单
  (2)选择New->Catalog(新建一个编录)
  设置新增加的编录
  (1)输入编录的名字(这个名字需要与数据库进行关联,要注意命名,这里假设DCSII
  (2)点Browse进入选择索引服务运行目录窗体
  (3)选择前面创建的索引运行目录(任意地方)
  (4)点确定完成本次操作
  在编录创建号以后,需要给编录增加目录
  (1)右键选择刚刚创建的编录
  (2)选择New->Directory(新建目录)
  新建索引目录
  (1)点击Browse进入目录选择页面
  (2)选择要进行全文检索文件的目录
  (3)确定完成本次操作
  完成创建后启动索引服务
  (1)启动索引服务
  (2)索引服务启动成功后索引编录的信息,可以看到编录信息就表示服务已经启动成功。
  将索引服务和SQL数据库关联:
  在SQL 查询分析器(SQL Query Analyer)里执行下面的存储过程
  EXEC sp_addlinkedserver Dcs, -- 连接服务器的名字,到后面查询的时候要用到
  'Index Server',
  'MSIDXS',
  'DCSII' -- 索引服务里新建的编录名字
  索引服务的性能调整方法1
  (1)右键选择索引服务
  (2)选择 All Tasks-> Tune Perrformance
  (3)选择用户自定义
  (4)点击Customize进入性能调整窗体
  (5)将Index和Querying的属性移动到最右边
  (6)点确定完成操作
  性能调整方法2
  如果服务器不需要对整个系统的文件进行索引,可以停止或者删除System编录。
  MSSQL对索引服务器的调用
  1. 通过sql语句查询连接服务器的内容
  SELECT Q.*
  FROM OpenQuery(dcs, --连接服务器名字
  'SELECT FileName, Size, DocAuthor, path --在连接服务器里的sql语句
  FROM SCOPE()
  WHERE CONTAINS(''番号 and abc'') '
  ) AS Q
  2. 因为SQL语句不支持动态输入的字符串,因此查询字符串只好在C#代码里进行拼接
  s.p.
  实不用将文件保存到数据库外面也能实现在数据库里实现全文搜索。具体方案是在SQL Server 2000里安全全文搜索功能,用image字段存储文件内容,并新增一个字段存放文件类型,然后在通过企业管理器新建全文索引项的时候将这两个字段匹配就可以。不过从数据库的/率以及今后数据库备份和恢复的效率上来看,将文件放在数据库的设计不是太好。

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • sql2005 大数据量检索分页的sql代码
  • sql server 中 Select 检索高级用法
  • java命名空间java.sql接口statement的类成员方法: executeupdate定义及介绍
  • 请问,这是什么错误!java.sql.SQLException: [Microsoft][ODBC SQL Server Driver][Named Pipes]??????? SQL Server?虽然分少,但一定给,只要您是前5名回复者中最好的以为!
  • java命名空间java.sql接口connection的类成员方法: nativesql定义及介绍
  • SQL查询分析工具 SQL Workbench/J
  • java命名空间java.sql接口preparedstatement的类成员方法: executeupdate定义及介绍
  • oracle导出sql语句的结果集和保存执行的sql语句(深入分析)
  • java命名空间java.sql接口rowid的类成员方法: getbytes定义及介绍
  • SQL Server统计SQL语句执行时间的脚本
  • java命名空间java.sql接口ref的类成员方法: getbasetypename定义及介绍
  • SQL客户端软件 PKLite SQL Client
  • java命名空间java.sql接口databasemetadata的类成员方法: getsqlkeywords定义及介绍
  • SQL语句实现SQL Server 2000及Sql Server 2005日志收缩(批量)
  • java命名空间java.sql接口rowid的类成员方法: tostring定义及介绍
  • SQL客户端管理工具 SQuirreL SQL Client
  • java命名空间javax.sql.rowset接口joinrowset的类成员方法: getwhereclause定义及介绍
  • 如何处理此错误:java.sql.SQLException: [Microsoft][ODBC SQL Server Driver]没有执行可选特性
  • java命名空间java.sql接口statement的类成员方法: execute定义及介绍
  • 如何实现连接一次数据库,提交多个sql语句。(sql的批处理)
  • java命名空间java.sql接口resultset的类成员方法: getcursorname定义及介绍
  • 微软网站下载的Ms SQL Server2000 JDBC Driver,必须用英文版的SQL server2000吗?
  • java命名空间java.sql接口resultsetmetadata的类成员方法: getcolumntype定义及介绍
  • 安装SQL2008时提示删除SQL2005Express工具的解决方法


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3