执行如下命令:

mvn -Dmybatis.generator.overwrite=true mybatis-generator:generate

可以使用mybatis generator

mybatis 使用多个参数

自定义方法需要根据多个查询条件去查询:

SELECT * FROM `db_demo`.`hot_topic` WHERE lang='english' AND category='' AND  topic_type='video' ORDER BY score DESC;

推荐使用注解的方式:

需要自定义方法:

mapper文件中

  //  使用注解
JSONArray selectByLangAndCategoryAndTopicType(@Param("lang") String lang, @Param("category") String category, @Param("topicType") String topicType);

mapper.xml文件中:

<select id="selectByLangAndCategoryAndTopicType" resultMap="ResultMapWithBLOBs" >
<!--
WARNING - @mbggenerated
This element is automatically generated by MyBatis Generator, do not modify.
This element was generated on Thu Oct 12 14:51:34 CST 2017.
-->
select
<include refid="Base_Column_List" />
,
<include refid="Blob_Column_List" />
from hot_topic
where lang= #{lang,jdbcType=VARCHAR} AND category = #{category,jdbcType=VARCHAR} AND topic_type=#{topicType,jdbcType=VARCHAR}
</select>

其他方法

DAO层的函数方法

Public User selectUser(String name,String area);

对应的Mapper.xml

<select id="selectUser" resultMap="BaseResultMap">
select * from user_user_t where user_name = #{0} and user_area=#{1}
</select>

其中,#{0}代表接收的是dao层中的第一个参数,#{1}代表dao层中第二参数,更多参数一致往后加即可。


其他方法

此方法采用Map传多参数.

Dao层的函数方法

Public User selectUser(Map paramMap);

对应的Mapper.xml

<select id=" selectUser" resultMap="BaseResultMap">
select * from user_user_t where user_name = #{userName,jdbcType=VARCHAR} and user_area=#{userArea,jdbcType=VARCHAR}
</select>

Service层调用

Private User xxxSelectUser(){
Map paramMap=new hashMap();
paramMap.put(“userName”,”对应具体的参数值”);
paramMap.put(“userArea”,”对应具体的参数值”);
User user=xxx. selectUser(paramMap);}

此方法不够直观,见到接口方法不能直接的知道要传的参数是什么。

最新文章

  1. WebForm基础
  2. SQL入门经典(十) 之事务
  3. 让你的APP支持iPhone5
  4. paper 92:图像视觉博客资源2之MIT斯坦福CMU
  5. IntelliJ IDEA添加过滤文件或目录
  6. CF Drazil and Factorial (打表)
  7. Java多线程——Semaphore信号灯
  8. 跨控制器操作-thinkphp
  9. Swift编程语言学习11—— 枚举全局变量、局部变量与类型属性
  10. BZOJ 3438: 小M的作物( 最小割 )
  11. bash内建命令
  12. swift的调用约定
  13. AT2046 Namori 图论
  14. 剑指offer(31)1~n整数中1出现的次数
  15. 百度前端技术学院-task2.18-2.19源码以及个人总结
  16. fgets、gets和scanf的区别
  17. 怎样安装Python3
  18. flask admin学习记录
  19. 使用HTTP协议访问网络(Android)
  20. 【java】抽象类继承关系

热门文章

  1. win10开启开发人员模式
  2. Linux知识温习
  3. Python实践练习:疯狂填词
  4. eclipse自动生成.apt_generated、factory path
  5. Xcode 中设置部分文件ARC支持
  6. Node.js中的express框架获取http参数
  7. Graphics.Blit
  8. 【bzoj1096】仓库建设 斜率优化dp
  9. 利用 Chrome 原生工具进行网页长截图
  10. opennebula 补丁制作与补丁升级