最近在写一个查找文件的接口时,发现别人用Ftsearch去查找,居然还可以进行全文的检索,觉得挺厉害的,所以网上找了一下相关的资料。不过我对于Ftsearch如何写检索条件,还是有点模糊,所以借着写接口代码的时候顺便试了一下,要是有不对的地方,恳请斧正。
部分代码如下:
'将当前用户加入到搜索条件
If struiuser = "" Then
tempstr = ""
Else
vuiuser = Evaluate({@Name([CN];"} & struiuser & {")})
tempstr = {FIELD Reader="} & vuiuser(0) & {" OR FIELD Author="} & vuiuser(0) & {"}
End If
MsgBox "tempstr==" & tempstr
If Not appvi Is Nothing Then
'1、如果有检索条件,先根据检索条件检索视图,没有则获取视图所有条目
If strquery <> "" Then
i = appvi.Ftsearch(strquery, 0)
Set vwentrys = appvi.Allentries
Else
Set vwentrys = appvi.Allentries
End If
'2、添加当前人员为检索条件,检索当前用户能看到的文档
If tempstr <> "" Then
Call vwentrys.Ftsearch(tempstr, 0)
End If
MsgBox "共找到文件数量为:" & vwentrys.count
end if
1、Ftsearch(strquery, 0):第一个参数是需要查询的内容,第二个是条数限制,比如可以写成Ftsearch(“张三”, 0),就是查询包含"张三"的所有文档。
2、tempstr = {FIELD Reader="} & vuiuser(0) & {" OR FIELD Author="} & vuiuser(0) & {"}:这个是拼成的Ftsearch的检索条件,就是读者域或者作者域包含某个用户。
3、Call vwentrys.Ftsearch(tempstr, 0):这个是对视图进行第二次检索,就是在第一次查找的结果里再根据条件查找一次,最终得出找到的条数。