ibatis傳遞日期Date參數

這本來是一個簡單的問題,但是在網上查閱了半天也沒找到結果,最後閱讀官方文檔後,終於找到了方法。

其實非常簡單,只需要在接口方法參數上加上@Param註解。

另外如果需要傳遞多個參數時,可以使用該註解來實現。

例子:

public List<Teacher> selectTeacher(@Param(value="id") String id, @Param(value="sex") String sex, @Param(value="createTime") Date createTime);

XML

  <select id="selectTeacher" resultType="com.myapp.domain.Teacher">
  	select * from Teacher where c_id=#{id} and sex=#{sex} and create_time<#{createTime}
   </select>

遇到問題不要退縮,雖然解決這個問題還有其他方法(比如傳遞String,然後在sql裏轉換成日期類型,但這樣做會有數據庫兼容問題,比如oracle日期函數與mySQL的日期函數的寫法是不同的),但都不十分理想,仔細思考冷靜分析,堅持不懈便能找到答案。

我之所以執着於此,是因爲ibatis作爲一個orm框架,肯定考慮了數據庫兼容性(如hibernate就支持跨數據庫的hql),像是傳遞個Date日期類型的Java參數,ibatis怎麼會不支持呢,還要用Map、對象、String等笨方法,這本來就是一勞永逸的事,因此我認爲費電時間和精力是值得的。

在此mark下,分享給大家,希望大家再遇到此問題能很快就解決掉。

發佈了110 篇原創文章 · 獲贊 197 · 訪問量 320萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章