• 如何结合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>

  • 相关阅读:
    各系统添加根证书
    Nginx浏览目录配置及美化
    django-图形验证码(django-simple-captcha)
    django-manage.py参数
    js — 对象
    js — 数组Array
    js — 字符串
    js — 基础知识
    css — 定位、背景图、水平垂直居中
    css — 权重、继承性、排版、float
  • 原文地址:https://www.cnblogs.com/zhangyuhang3/p/6906044.html
Copyright © 2020-2023  润新知