Mybatis——模糊查询

5 篇文章 0 订阅
4 篇文章 0 订阅

自己在做的时候,经常出现模糊查询不行,改了一个晚上,发现还是不行,回头几天再去做,突然又可以了。

根据name模糊查询数据

Inteface

public List<Scenery> findScenery(String sceneryname);

Mapper

        <select id="findScenery" resultType="Scenery"  >
        	select * from t_scenery where sceneryname like concat ('%',#{sceneryname},'%')
        </select>

Controller

	@RequestMapping("findScenery")
	public ModelAndView findScenery(
			@RequestParam(value="sceneryname",required=false)String sceneryname) throws UnsupportedEncodingException{
		ModelAndView mav = new ModelAndView();
		List<Scenery> sc = sceneryService.findScenery(sceneryname);
		mav.addObject("sc", sc);
		mav.setViewName("showScenery");
		return mav;
	}

在这里插入图片描述
进去的页面上面都没有,没有判空,添加判空。
Controller

	@RequestMapping("findScenery")
	public ModelAndView findScenery(
			@RequestParam(value="sceneryname",required=false)String sceneryname) throws UnsupportedEncodingException{
		ModelAndView mav = new ModelAndView();
		if(sceneryname!= null){
			sceneryname = new String(sceneryname.getBytes("ISO8859_1"), "UTF-8");
			List<Scenery> sc = sceneryService.findScenery(sceneryname);
			mav.addObject("sc", sc);
			mav.setViewName("showScenery");
			return mav;
		}else{
			mav.setViewName("findScenery");
			return mav;
		}
	}

进行查询,发现乱码,将sceneryname改为UTF-8

	@RequestMapping("findScenery")
	public ModelAndView findScenery(
			@RequestParam(value="sceneryname",required=false)String sceneryname) throws UnsupportedEncodingException{
		ModelAndView mav = new ModelAndView();
		if(sceneryname!= null){
			sceneryname = new String(sceneryname.getBytes("ISO8859_1"), "UTF-8");
			List<Scenery> sc = sceneryService.findScenery(sceneryname);
			mav.addObject("sc", sc);
			mav.setViewName("showScenery");
			return mav;
		}else{
			mav.setViewName("findScenery");
			return mav;
		}
	}

查询“山”,出现了2行记录
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值