使用MyBatis怎么实现动态查询和模糊查询功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
要实现查询,咱们就先有个数据库,截图如下,其中cityAreaId是外键,本次可以忽略;
下面Branches是我的实体类,里面有name和address属性;
接口中方法:
public List<Branches> finDongTai(@Param("name")String name,@Param("add")String address);//动态
public List<Branches> findLike(@Param("name")String name,@Param("add")String address);//模糊
MyBatis的接口映射文件的代码:
动态查询:
<select id="finDongTai" resultType="com.wj.entity.Branches" >
SELECT * FROM Branches where 1=1
<if test="name!=''and name!=null">
and name =#{name}
</if>
<if test="add!=''and add!=null">
and address =#{add}
</if>
</select>
模糊查询:
<select id="findLike" resultType="com.wj.entity.Branches" >
SELECT * FROM Branches where name like "%"#{name}"%" and address like "%"#{add}"%"
</select>
然后就是main方法实现了:
List<Branches> list=new BranchesImpl().finDongTai("建设银行", "");
for (Branches branches : list) {
System.out.println("名称:"+branches.getName()+"\t---\t地址:"+branches.getAddress());
}
List<Branches> list=new BranchesImpl().findLike("支行", "路");
for (Branches branches : list) {
System.out.println("名称:"+branches.getName()+"\t---\t地址:"+branches.getAddress());
}
看完上述内容,你们掌握使用MyBatis怎么实现动态查询和模糊查询功能的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注天达云行业资讯频道,感谢各位的阅读!