MyBatis实现动态查询、模糊查询

下面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()+" --- 地址:"+branches.getAddress());

}

List<Branches> list=new BranchesImpl().findLike("支行", "路"); for (Branches branches : list) { System.out.println("名称:"+branches.getName()+" --- 地址:"+branches.getAddress()); }

结果就是。。。

动态查询:

模糊查询:

大功告成!!!

经验分享 程序员 微信小程序 职场和发展