讓前端的下拉框支援單選、多選及全選,後臺MyBaits解決方案

落花桂發表於2021-10-01

一、解決思路

  讓前端的下拉框支援單選、多選及全選,後臺讓Mybatis使用** trim **標籤拼接動態SQL,實現

select * from order 
where startDate = sysdate
and (name="A" or name="B" or name="C")
-----------------------------------------------
--當使用者全選時,捨棄掉最後的 and() 條件
select * from order 
where startDate = sysdate

二、請求引數

入參說明

// 單選
{
  "date":"2021-10-1",
  "name":["A"]
}

// 多選
{
  "date":"2021-10-1",
  "name":["A","B","C"]
}

// 全選
{
  "date":"2021-10-1",
  "nameList":["all"]
}

三、後臺相關程式碼

  • 1、請求的入參對應的實體類
@Data
public SelectReq{
  private String date;
  private List<String> nameList;
}

* 2、Mybatis對映檔案

<select id="selectByBeans" resultMap="BaseResultMap" parameterType="com.wg.demo.po.SelectReq">
  select
  *
  from employee 
  where date = to_date(#{date},'yyyy-mm-dd')
  <trim prefix="and (" suffix=")" suffixOverrides="and | or">
    <foreach collection="nameList"  item="item">
      <if test='name != "all"'>
        name=#{item} or
      </if>
    </foreach>
  </trim>
</select>

四、Mybatis注意要點

  • trim標籤一般用於去除sql語句中多餘的and關鍵字,逗號,或者給sql語句前拼接 “where“、“set“以及“values(“ 等字首,或者新增“)“等字尾
prefix 給sql語句拼接的字首
suffix 給sql語句拼接的字尾
prefixOverrides 去除sql語句前面的關鍵字或者字元,該關鍵字或者字元由prefixOverrides屬性指定,假設該屬性指定為"AND",當sql語句的開頭為"AND",trim標籤將會去除該"AND"
suffixOverrides 去除sql語句後面的關鍵字或者字元,該關鍵字或者字元由suffixOverrides屬性指定
  • foreach表示迴圈操作,具體的引數含義如下:
foreach 元素的屬性主要有 item,index,collection,open,separator,close。
item 表示集合中每一個元素進行迭代時的別名
index 指定一個名字,用於表示在迭代過程中,每次迭代到的位置
open 表示該語句以什麼開始
separator 表示在每次進行迭代之間以什麼符號作為分隔符
close 表示以什麼結束
  • if 標籤判斷字串
<if test = 'sex == "Y"'>
這裡注意,外層用單引號,字串用雙引號包裹

相關文章