mybatis学习之模糊查询用户例子

原创 2017年06月19日 19:22:17

上接上一篇博客

1、配置数据库映射文件(User.xml)

在其中加入如下代码:

   <!--
     根据用户名称模糊查询用户信息
     注意:此处resultType不管单条多条结果记录,都为所映射成的java对象
     ${}表示拼接sql串,将接受到的参数的内容不加任何修饰拼接在sql语句中
     使用${}符号可能会引起sql注入问题
     -->
    <select id="findUserByName" parameterType="String" resultType="pojo.User">
        SELECT * FROM USER WHERE username LIKE '%${value}%'
    </select>


2、编写程序

//根据用户的名称模糊查询用户信息
    @Test
    public void findUserByNameTest(){
        //mybatis配置文件
        String resource = "SqlMapConfig.xml";
        SqlSession sqlSession = null;
        try {
            InputStream inputStream = Resources.getResourceAsStream(resource);
            //创建会话工厂,传入mybatis的配置信息
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            //通过工厂得到SqlSession
            sqlSession = sqlSessionFactory.openSession();
            //通过SqlSession来操作数据库
            //List中的User泛型,和resultType中指定的类型一致
            List<User> list = sqlSession.selectList("test.findUserByName","测试");
            System.out.print(list);
        }catch (IOException e){
            e.printStackTrace();
        }finally {
            //释放资源
            sqlSession.close();
        }
    }

运行后如下图:



在此处要注意的几点问题:

返回多条记录和返回单调记录,在映射文件中配置resultType类型仍为该表的po类,在后面的接受参数时,直接定义一个泛型为该类的List集合来接收

模糊查询提到了一个占位符的另外一种表现形式,即${},这样是不加任何修饰直接插入,但这样使用可能会引起sql注入的问题,比如你要插入一串now()函数,程序运 运行sql会将''也算进去执行。

版权声明:本文为博主原创文章,未经博主允许不得转载。

mybatis的动态SQL与模糊查询

现在以一个例子来介绍mybatis的动态SQL和模糊查询:通过多条件查询用户记录,条件为姓名模糊匹配,并且年龄在某两个值之间。    新建表d_user:create table d_user( ...
  • xiangwanpeng
  • xiangwanpeng
  • 2016年12月21日 20:22
  • 7398

Mybatis基础-多条件查询和模糊查询实例

模糊查询 1. 修改Category.xml,提供listCategoryByName查询语句 select * from category_ where name like concat('...
  • wo_shi_LTB
  • wo_shi_LTB
  • 2018年02月07日 03:41
  • 3

MyBatis映射文件(集合数据的添加与获取,条件查询,模糊查询)

MyBatis映射文件(集合数据的添加与获取,条件查询,模糊查询) 继续上次的MyBatis的映射文件, EmployeeMapper.xml ...
  • zhupengqq
  • zhupengqq
  • 2017年11月18日 20:19
  • 243

框架学习系列 mybatis 第五篇 mybatis入门程序之需求开发2根据用户名模糊查询

本节主要内容 1:根据上节课中提出的需求完成②:根据用户名模糊查询${}的使用 2:测试代码实现 3:总结&下节预告 本文是《凯哥陪你学系列-框架学习之mybatis框架学习》中第五篇 myb...
  • gebitan505
  • gebitan505
  • 2017年08月04日 18:23
  • 343

mybatis 多参数模糊查询sql

java部分: List selectByDeptId(@Param("name")String name,@Param("depyId")Integer deptId); xml部分 SE...
  • eumenides_
  • eumenides_
  • 2016年06月28日 19:02
  • 194

模糊查询的例子

  • 2014年03月21日 11:09
  • 310KB
  • 下载

模糊查询的例子-最简单的VB查询入门

  • 2008年10月08日 11:30
  • 29KB
  • 下载

模糊查询在mybatis配置xml文件中的写法

由于不希望在使用ssm框架时,手动添加为模糊查询添加%,对字段又修改,容易出错,所以模糊查询的%%写在xml里面。 常见写法有    拼接方式, AND user_name like '%#{us...
  • Angel_Over_
  • Angel_Over_
  • 2017年07月27日 00:17
  • 1300

(4).Mybatis模糊查询MySQL中记录的的常用三种方法

mybatis的模糊查询功能使用的很广泛,以MySQL数据库为例(不同的数据库,有些可能不支持) 常用的模糊查询有三种方法: 直接使用 % 拼接字符串,如 ‘%’name’%’ 或 “%”nam...
  • qgfjeahn
  • qgfjeahn
  • 2016年11月11日 10:46
  • 2955

Mybatis 的逆向工程案例

为了能让大家更好的敲代码,而不是浪费大量时间去写mapper.java,mapper.xml、po等代码,mybatis官方提供逆向工程功能. 文件配置 ...
  • bushanyantanzhe
  • bushanyantanzhe
  • 2018年01月24日 13:14
  • 29
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:mybatis学习之模糊查询用户例子
举报原因:
原因补充:

(最多只允许输入30个字)