SQL Server全文检索简介

 更新时间:2016年11月25日 16:44  点击:1271
全文索引和全文检索是sql server 7.0的新增功能,它能够对数据中的字符类型列(如varchar、text等类型列)进行索
引,并通过索引实现全文搜索查询。sql server常规索引与全文检索相比,二者的区别如下:
常规索引 全文索引
使用create index或约束定义创建 使用全文索引存储过程创建和删除
通过删除或执行drop index语句删除
当插入、修改或删除数据时,sql server 只能通过任务调度或执行存储过
能够自动更新常规索引内容 程来填充全文索引
每个表可以建立多个常规索引 每个表只能有一个全文索引
索引不能分组 同一个数据库中的多个全文索引可
以组织为一个全文目录
常规索引存储在数据库文件中 全文索引存储在文件系统中
为了支持全文索引操作,sql server 7.0新增了一些新存储过程和transact-sql语句,使用这些存储过程创建全文索引的
具本步骤为(括号内为每步所调用的存储过程名称):
(1)启动数据库的全文处理功能(sp_fulltext_datebase);
(2)建立全文目录(sp_fulltext_catalog);
(3)在全文目录中注册需要全文索引的表(sp_fulltext_table);
(4)指出表中需要全文检索的列名(sp_fulltext_column)
(5)为表创建全文索引(sp_fulltext_table);
(6)填充全文索引(sp_fulltext_catalog)。
例:
use pubs
go
exec sp_fulltext_database 'enable'
--为titles表建立全文索引数据元,其中create为建立,activate为激活,deactivate为关闭表全文索引的激活状态,使
它不再参加全文目录填充,drop为删除;create参数中,后面跟的是全文目录名称和索引列名。
--下面语句为pubs数据库中的titles表创建全文索引数据元,存储该数据元的全文目录为FT_pubs,所使用的唯一索引为
UPKCL_titleidind(title表中为title_id列的PRIMARY KEY约束所建立的唯中索引)
sp_fulltext_table titles,'create','FT_pubs','upkcl_titledind'
--激活它
sp_fulltext_table titles,'activate'
--指定参加全文索引的列
sp_fulltext_column 'titles','title','add'
sp_fulltext_column 'titles','notes','add'
拷贝的SQL Server 7数据库的恢复方法
在SQL Server 7中由于MS重新设计了数据库文件的存储方式,取消了新建设备再建数据库这一繁琐的过程。新的存储格式,一个数据库包括两个文件,mdf数据库文件和ldf日志文件。所以我们在重装机器备份时可以把你要备份的数据库的这两个文件拷贝出来,重新安装之后再恢复。
  在SQL Server中提供了这种恢复方式的存储过程。
1.sp_attach_db [@dbname =] 'dbname',[@filename1 =] 'filename_n'
给系统添加一个数据库,在dbname指定数据库名称,filename_n指定数据库的文件和日志文件。比如我有一个voogiya的库,停止SQL Server服务备份voogiya_data.mdf,voogiya_log.ldf,启动SQL server,删除掉这个库,然后再把这两上文件拷到sql server DATA目录中,在Query Analyzer中执行如下语句:
EXEC sp_attach_db @dbname = N'voogiya',
@filename1 = N'd:mssql7datavoogiya_data.mdf',
@filename2 = N'd:mssql7datavoogiya_log.ldf'
就会把这个库加入到SQL Server Group中.
2.sp_attach_single_file_db [@dbname =] 'dbname',
[@physname =] 'physical_name'
这个命令和上面的功能一样,在physical_name中只要写上据库的物理文件名就可以了,日志文件SQL server会重新建立。这个存储过程的运行要先执行下面的存储过程:
sp_detach_db @dbname = 'dbname'
同样以上面的为例:
EXEC sp_detach_db @dbname = 'voogiya'
EXEC sp_attach_single_file_db @dbname = 'voogiya',
@physname = 'd:mssql7datavoogiya_data.mdf'

要注意执行以上存储过程的用户要在sysadmin中.
以上方法在windows Nt 4.0,service pack5,sql server 7.0上运行通过。

【「Microsoft SQL Server 7.0」以下简称「SQL Server 7.0」】
在SQL Server 7.0中如何不重启SQL Server服务,即可循环errorlog(错误日志)?(New)
在SQL Server 7.0中如果要cycle errorlog,(即重新产生一个新的errorlog,errorlog变成errorlog.1,errorlog.1变成errorlog.2,...)但不重新激活SQL Server Service,在SQL Server 7.0提供了一个新的Stored procedure:sp_cycle_errorlog。您可利用这个stored procedure达到cycle errorlog的功能。
将Internet explorer 5.0安装在有安装SQL Server 7.0的Windows 95/98的计算机上,在执行SQL Server 7.0 Wizard或点选Property各页面时,常会有"这个作业的执行无效,即将关闭。如果问题无法解决,请洽询程序设计人员。"或其它错误讯息如何解决?
这是因为安装Internet Explorer5.0变更了comctl32.dll这个档案造成的。请升级SQL Server 7.0至Service Pack 1。
安装Office 2000 或Microsoft SQL Server 7.0 客户端程序之后由SQL Server6.5所附的MS Query存取SQL Server 6.5的资料得到的是乱码如何解决?
这可能是因为您使用SQL Server ODBC 3.70.06.23版的Driver。请不要设定"Perform translation for character data",并且升级SQL Server ODBC 版本至3.70.06.90。
 附注:SQL server 7.0附的是3.70.06.23 ,SQL server 7.0 SP1附的是3.70.06.90。
如何由网际网络查询关于SQL Server 7.0产品最完整的相关信息?
参考美国微软网站 http://www.microsoft.com/sql/default.asp,您可由此查询到关于产品的概观、功能、系统需求、评估工具、产品价格等等相关信息
目前Microsoft SQL Server 7.0有那几种版本?
EnterPrise Edition。
Standard Edition。
Desktop Edition。
若无特别提及,一般都是指Standard Edition(标准版)。
SQL Server 7.0有无中文版?
SQL Server 7.0为双字节版本,可安装于Windows NT Server4.0中文版上。
如何在命令提示字符下激活MSSQLServer 7.0 desktop edition?
请执行下列指令:c:mssqlinnscm.exe -Action 1 -Silent 1
是否可以在命令提示字符下激活SQL Server 7.0 Desktop Edition的SQLServerAgent?
不行。此为产品限制。
如何增加SQL Server 7.0 error log的数目?
SQL Server预设的数目为六个,如果要增加请在Query Analyzer下执行下列指令:
xp_regwrite 'HKEY_LOCAL_MACHINE','SOFTWAREMicrosoftMSSQLServerMSSQLServer', 'NumErrorLogs','REG_DWORD', 20
如何重建SQL Server 7.0的Master database?
SQL Server 7.0提供一个新的工具:Rebuildm.exe,这个档案位于MSSQLBINN。必需注意的是重建SQL Server 7.0的Master database亦建MSDB及MODEL数据库。AREMicrosoftMSSQLServerMSSQLServer', 'NumErrorLogs','REG_DWORD', 20

当您怀疑计算机硬件是影响SQL Server运行性能的主要原因时,可以通过SQL Server Performance Monitor监视相应硬件的负载,以证实您的猜测并找出系统瓶颈。下文将介绍一些常用的分析对象及其参数。
Memory: Page Faults / sec
  如果该值偶尔走高,表明当时有线程竞争内存。如果持续很高,则内存可能是瓶颈。
Process: Working Set
  SQL Server的该参数应该非常接近分配给SQL Server的内存值。在SQL Server设定中,如果将"set working set size"置为0, 则Windows NT会决定SQL Server的工作集的大小。如果将"set working set size"置为1,则强制工作集大小为SQLServer的分配内存大小。一般情况下,最好不要改变"set working set size"的缺省值。
Process:%Processor Time
  如果该参数值持续超过95%,表明瓶颈是CPU。可以考虑增加一个处理器或换一个更快的处理器。
Processor:%Privileged Time
  如果该参数值和"Physical Disk"参数值一直很高,表明I/O有问题。可考虑更换更快的硬盘系统。另外设置Tempdb in RAM,减低"max async IO","max lazy writer IO"等措施都会降低该值。
Processor:%User Time
  
  表示耗费CPU的数据库操作,如排序,执行aggregate functions等。如果该值很高,可考虑增加索引,尽量使用简单的表联接,水平分割大表格等方法来降低该值。
Physical Disk:Avg.Disk Queue Length
  该值应不超过磁盘数的1.5~2倍。要提高性能,可增加磁盘。
  注意:一个Raid Disk实际有多个磁盘。
SQLServer:Cache Hit Ratio
该值越高越好。如果持续低于80%,应考虑增加内存。
 注意该参数值是从SQL Server启动后,就一直累加记数,所以运行经过一段时间后,该值将不能反映系统当前值。

我用的是SQL server 6.5,(刚刚用,新手啦),原来放数据库的服务器要更换,请问如何转移?手边的这本书和我的操作界面不一样,很让我生气!我基本思路是这样的:先备份数据库----有了*.dat文件---在另一台机器上设置设备、库、表(将*.sql文件用isql生成表结构)---用restore恢复(应该是恢复表的内容)。
可做到最后一步,restore按钮总也不亮,不知我的思路可有错误,现在问题应该怎么解决,请大侠们出手相助!!!
azury (来自 202.111.130.166) 于 99-5-19 上午 11:58:10 加贴在 SQL数据库:
1 . 原有数据库服务器不要动。
2 . 重新安装一个Sql Server 服务器。
3 . 安装完毕在 Enterprise manager 中将两个服务器都映象进来
(其实,就是Register两个)
3 . 选择要转移的数据库
4 . 菜单中选Tools --> Database Backup/Restore
5 . 设置源/目的以及其他参数
6 . 进行转移(非常快)
试试吧。
  :)
露茜 (来自 202.111.130.166) 于 99-5-19 上午 11:56:52 加贴在 SQL数据库:
然后再把原来的目录全部拷过来,覆盖现有的文件就可以了
不过我也是听说的,没有试过,azury姐姐可能会有比较好的办法,但是她的方法可能会使数据出现一些错误
小懒 (来自 202.111.130.166) 于 99-5-19 下午 12:00:54 加贴在 SQL数据库:
在enterprise manager中的菜单--TOOL--DATABASE/OBJECT TRANSFER
选择原来的sql server服务器和库是source
destination就是你现在的server和database
visitor (来自 210.72.252.34) 于 99-5-19 下午 04:16:49 加贴在 SQL数据库:
MS在6.5升级到7.0时问题多多.
给他们的工程师打过电话,
至今也没能提供一个简便/可靠的方案.
若非不得以,
还是在7.0上从头开始吧!

[!--infotagslink--]

相关文章