zoukankan      html  css  js  c++  java
  • 如何结合IbatisNet的LIST遍历实现模糊查询

    我仿照Java的Spring+Ibatis+Struct用Castle+IBatisNet+Asp.net的开发框架的DAO的基类:BaseSqlMapDao内定义了一个内部类来辅助模糊查询。内部类代码如下:
    protected internal  class KeyWordSearch
      {
       private IList keywordList = new ArrayList();

       public KeyWordSearch(String keywords)
       {
        StringTokenizer splitter = new StringTokenizer(keywords, " ", false);
        string token = null;

        IEnumerator enumerator = splitter.GetEnumerator();

        while (enumerator.MoveNext())
        {
         token = (string)enumerator.Current;
         keywordList.Add("%" + token + "%");
        }
       }

       public IList KeywordList
       {
        get
        {
         return keywordList;
        }
       }
      }
    在需要使用模糊查询的数据访问类的方法中使用方法如下:
    例如数据访问类PersonInfoDao继承自BaseSqlMapDao,方法
    /// <summary>
      /// 检索求职者信息,根据关键字检索
      /// </summary>
      public IList SearchPersonInfoList(string keywords)
      {
       object parameterObject = new KeyWordSearch(keywords);
       return this.ExecuteQueryForList("SearchPersonList", parameterObject);
      }

    <select id="SearchPersonList" resultMap="PersonResult">
       select UserId,UserName,Sex,Birthday,Mobile,HomeTel,EMail,LivingArea,
                RegisteredLocus,GraduateSchool,MajorSpecialty,JobExperience,MonthlyPay,
                Special,Resume,city.code,city.name,person.NationId,Nation.NationName,
                person.JobId,job.jobName,person.degreeId,degree.DegreeName
                from Career_PersonInfo person ,Career_Nation nation,Career_Job job,Career_City city,Career_Degree degree
                where person.CityCode = city.code and person.NationId = nation.NationId and person.jobid = job.jobId
                and person.degreeId = degree.degreeId
                <dynamic prepend="and">
        <iterate property="KeywordList" open="" close="" conjunction="OR">
         lower(job.jobName) like #KeywordList[]#
        </iterate>
       </dynamic>
      </select>

  • 相关阅读:
    CAP
    plugins for ST3 to frontend
    OAuth 2.0 详解
    Git SSH生成
    Android FrameWork 学习之Android 系统源码调试
    node.js安装步骤
    数据结构-- 队列 循环与顺序
    jsp之认识 servlet (基础、工作原理、容器请求处理)
    android 蓝牙开发---与蓝牙模块进行通讯 基于eclipse项目
    Android 仿微信调用第三方应用导航(百度,高德、腾讯)
  • 原文地址:https://www.cnblogs.com/shanyou/p/206026.html
Copyright © 2011-2022 走看看