mybatis学习之模糊查询用户例子
来源:互联网 发布:迅捷数据恢复注册问题 编辑:程序博客网 时间:2024/06/02 01:01
上接上一篇博客
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会将''也算进去执行。
阅读全文
0 0
- mybatis学习之模糊查询用户例子
- mybatis学习之路----模糊查询实现
- Mybatis之根据用户名称模糊查询用户信息(4)
- Mybatis学习总结之动态SQL与模糊查询
- Mybatis学习总结之动态SQL与模糊查询
- mybatis的日期查询与字段的模糊查询例子
- mybatis学习之根据id查找用户例子
- mybatis学习之删除和更新用户例子
- Mybatis学习----模糊查询和动态sql
- Mybatis之动态SQL 模糊查询
- Mybatis模糊查询之like写法
- mongdb 学习之 模糊查询
- Mybatis入门学习篇(三)之模糊查询的两种写法
- Mybatis学习之查询
- mybatis模糊查询
- Mybatis各种模糊查询
- mybatis 模糊查询
- Mybatis各种模糊查询
- linux下安装及配置jenkins
- Android Json解析中如何解析没有key的解析办法
- 二级联动实现
- Use "adb disable-verity" to disable verity.
- /Debug-iphonesimulator/✖️✖️.build/Script-817CB3AD1B3BC68D0004AFEA.sh: line 2: ./.../.framework
- mybatis学习之模糊查询用户例子
- 深入理解计算机系统-笔记-CH 1 并发与并行
- JSP数据交互
- 一道好玩的题的解题代码
- pycharm加速安装python包的速度
- MyBatis学习(二)之双向一对多关联映射查询
- Servlet接口的常用方法
- 2017.6.17
- c++:尽量用new/delete代替malloc/free