mybatis 使用tips - 使用多个参数
2024-08-29 16:37:55
执行如下命令:
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);}
此方法不够直观,见到接口方法不能直接的知道要传的参数是什么。
最新文章
- WebForm基础
- SQL入门经典(十) 之事务
- 让你的APP支持iPhone5
- paper 92:图像视觉博客资源2之MIT斯坦福CMU
- IntelliJ IDEA添加过滤文件或目录
- CF Drazil and Factorial (打表)
- Java多线程——Semaphore信号灯
- 跨控制器操作-thinkphp
- Swift编程语言学习11—— 枚举全局变量、局部变量与类型属性
- BZOJ 3438: 小M的作物( 最小割 )
- bash内建命令
- swift的调用约定
- AT2046 Namori 图论
- 剑指offer(31)1~n整数中1出现的次数
- 百度前端技术学院-task2.18-2.19源码以及个人总结
- fgets、gets和scanf的区别
- 怎样安装Python3
- flask admin学习记录
- 使用HTTP协议访问网络(Android)
- 【java】抽象类继承关系