首页 > 开发 > Asp > 正文

结合asp和存储过程做的搜索程序

2020-06-20 14:07:23
字体:
来源:转载
供稿:网友
比较复杂,可以支持多种逻辑符,包括 + - and or 空格等,并且根据需要随便增加。可以根据条件选择在那个表中搜索,对速度也做了优化,可以说是很快的。当然因为是以前写的,存在不少毛病。存储过程中用到几乎所有sql server的特性,如光标(记录集分页)等。好了,不吹了,自己看程序吧。

asp 函数
复制代码 代码如下:

  function AnalyseKeyword(a_strSource)
      dim m_strDest , m_intLoop 
      dim m_intBeginPos , m_intEndPos
      dim m_strHead , m_strMiddle , m_strTail
      m_strDest = a_strSource

      '------------------------------处理空格------------------------------------------------------

      '首先去掉头尾空格
      m_strDest = ltrim(rtrim(m_strDest))

      '将& , " and " 等替换成 +、 -、空格
      m_strDest = replace(m_strDest , "&" , "+")
      m_strDest = replace(m_strDest , " AND " , "+")
      m_strDest = replace(m_strDest , " OR " , chr(32))
      m_strDest = replace(m_strDest , " NOT " , "-")  

      '初始化变量,以使下面的循环进行
      m_intBeginPos = 1

      do while m_intBeginPos <> 0
         m_intBeginPos = instr(m_strDest ,chr(32))
         if m_intBeginPos <> 0 then               '如果找到空格
            m_strHead = rtrim(ltrim(left ( m_strDest , m_intBeginPos )))
            call print("[AnalyseKeyword()]:处理空格m_strHead = " + m_strHead) 
            m_strTail = rtrim(ltrim(right (m_strDest , len(m_strDest) - m_intBeginPos)))
            call print("[AnalyseKeyword()]:处理空格m_strTail = " + m_strTail) 
            m_strDest = m_strHead + "*" + m_strTail
         else
            exit do
         end if
      loop                
      m_strDest = replace (m_strDest , "*" , chr(32))    
      call print("[AnalyseKeyword()]:处理空格完毕后m_strDest = " + m_strDest) 
      '-------------------------------空格处理完毕-------------------------------------------------
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表