1.mybatis中查询方式有3种

//查询单个值
@Test
public void testFindOne()throws IOException{
SqlSession session = MybatisUtil.getSqlSession();
User user = (User)session.selectOne("cn.sxt.vo.UserMapper.findOne", 1);
System.out.println(user);
session.close();
}
//查询list
@Test
public void testFindAll() throws IOException{
SqlSession session = MybatisUtil.getSqlSession();
List<User> list = session.selectList("cn.sxt.vo.UserMapper.findAll");
for(User u:list){
System.out.println(u);
}
session.close();
}
//查询map
@Test
public void testFindMap()throws IOException{
SqlSession session = MybatisUtil.getSqlSession();
//selectMap 传递的参是 map集合的key值。
Map map=session.selectMap("cn.sxt.vo.UserMapper.findMap", "name");
for(Iterator iter=map.keySet().iterator();iter.hasNext();){
Object key=iter.next();
System.out.println(key+"---"+map.get(key));
}
session.close();
}

映射文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.sxt.vo.UserMapper">
<!-- 查询单个对象 -->
<select id="findOne" resultType="User">
select * from t_user where id=#{id}
</select>
<!-- 查询list -->
<select id="findAll" resultType="User">
select * from t_user
</select>
<!-- 查询map -->
<select id="findMap" resultType="Map">
select * from t_user where id=1
</select>
<!--
begin=(currentPage-1)*pageSize
size=pageSize
-->
<select id="page1" resultType="User">
select * from t_user limit #{begin},#{size}
</select>
<select id="pageRow" resultType="User">
select * from t_user
</select>
</mapper>

2.分页

mybatis中有3种方式实现分页

映射文件

    <select id="page1" resultType="User">
select * from t_user limit #{begin},#{size}
</select>
<select id="pageRow" resultType="User">
select * from t_user
</select>

代码

//通过sql语句进行分页,参数传入的是对象
@Test
public void testPage() throws IOException{
SqlSession session = MybatisUtil.getSqlSession();
PageInfo pi = new PageInfo();
pi.setBegin(3);
pi.setSize(3);
List<User> list = session.selectList("cn.sxt.vo.UserMapper.page1",pi);
for(User u:list){
System.out.println(u);
}
}
//通过sql语句进行分页,参数传入的是map
@Test
public void testPage1() throws IOException{
SqlSession session = MybatisUtil.getSqlSession();
Map map = new HashMap();
map.put("begin", 0);
map.put("size", 3);
List<User> list = session.selectList("cn.sxt.vo.UserMapper.page1",map);
for(User u:list){
System.out.println(u);
}
}
//通过RowBounds来实现分页
@Test
public void testPage2() throws IOException{
SqlSession session = MybatisUtil.getSqlSession();
//第一个 参数 相当于index,第二个参数 每页显示记录数
RowBounds bounds = new RowBounds(3, 3);
List<User> list = session.selectList("cn.sxt.vo.UserMapper.pageRow",null,bounds);
for(User u:list){
System.out.println(u);
}
}

java之mybatis之查询及分页的更多相关文章

  1. Java基础-SSM之mybatis的统计函数和分页查询

    Java基础-SSM之mybatis的统计函数和分页查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.

  2. Oracle使用MyBatis中RowBounds实现分页查询

    Oracle中分页查询因为存在伪列rownum,sql语句写起来较为复杂,现在介绍一种通过使用MyBatis中的RowBounds进行分页查询,非常方便. 使用MyBatis中的RowBounds进行 ...

  3. SSM整合 mybatis多条件查询与分页

    多条件查询与分页: 通过页面的houseName.floorage获取值传到前端视图(HouseSearchVO)实体类中的houseName,floorage建立houseSearchVO对象. 通 ...

  4. Mybatis的插件 PageHelper 分页查询使用方法

    参考:https://blog.csdn.net/ckc_666/article/details/79257028 Mybatis的一个插件,PageHelper,非常方便mybatis分页查询,国内 ...

  5. Java之mybatis详解

    文章大纲 一.mybatis介绍二.mybatis代码实战三.项目源码下载四.参考文章   一.mybatis介绍 1. mybatis是什么?   mybatis是一个持久层的框架,是apache下 ...

  6. MyBatis Generator实现MySQL分页插件

    MyBatis Generator是一个非常方便的代码生成工具,它能够根据表结构生成CRUD代码,可以满足大部分需求.但是唯一让人不爽的是,生成的代码中的数据库查询没有分页功能.本文介绍如何让MyBa ...

  7. java:easyui(jQueryEasyUI,分页)

    1.介绍: jQuery EasyUI是一组基于jQuery的UI插件集合体,而jQuery EasyUI的目标就是帮助web开发者更轻松的打造出功能丰富并且美观的UI界面.开发者不需要编写复杂的ja ...

  8. 九:SpringBoot-整合Mybatis框架,集成分页助手插件

    九:SpringBoot-整合Mybatis框架,集成分页助手插件 1.Mybatis框架 1.1 mybatis特点 1.2 适用场景 2.SpringBoot整合MyBatis 2.1 核心依赖 ...

  9. myBatis批量查询操作,xml中使用foreach案例

    使用场景:有一个订单表,实体类为OrderBase.java,订单有个状态为status值可能为"1,2,3,4,5,6",现在需要查询状态为"2,3,4"的订 ...

随机推荐

  1. OpenFOAM——圆柱绕流对流换热

    本算例来自<ANSYS FLUENT技术基础与工程应用:流动传热与环境污染控制领域> TOP和DOWN为对称边界(symmetry),入口速度为0.01m/s,入口温度为300K,圆柱温度 ...

  2. unicode欺骗—— hctf - admin

    查看源代码,发现<!-- you are not admin --> 提示要以管理员身份登陆 尝试注册管理员账号,提示The username has been registered 于是 ...

  3. SAS 分层抽样示例代码

    PROC SURVEYSELECT DATA=B OUT=C(DROP=SelectionProb SamplingWeight) METHOD=SRS SEED=100 SAMPSIZE=1; ST ...

  4. Log4j 1.x版 引发线程blocked死锁问题(2008)

    1. https://blog.csdn.net/zl378837964/article/details/84884934 2. 去掉debug

  5. vs2017下载安装

    https://docs.microsoft.com/en-us/visualstudio/releasenotes/vs2017-relnotes

  6. shell整数与小数比较,小数之间比较的方法【转】

    在shell脚本中,无法对浮点数进行比较,如: max=0.1 min=0.01 if [ "$max" -gt "$min" ] then echo &quo ...

  7. 蓝牙BLE: ATT和GATT的概念

    BLE通信由两种设备类型构成—— Client和Server. Server提供数据服务,所以一般来说设备是Server,手机是Client.Server和Client通过ATT PDU进行交互,Se ...

  8. Deepin系统中手动开启swap的方法

    Deepin系统中手动开启swap的方法 如何设置 swap(交换空间)的大小建议设置和你的实际物理内存一样大,如你的内存是8G的,则可将下面的count的值设为8192(当然这只是参考值,你可根据你 ...

  9. BicycleGAN: Toward Multimodal Image-to-Image Translation - 1 - 论文学习,成对数据

    Abstract 许多图像到图像的翻译问题是有歧义的,因为一个输入图像可能对应多个可能的输出.在这项工作中,我们的目标是在一个条件生成模型设置中建立可能的输出分布.将模糊度提取到一个低维潜在向量中,在 ...

  10. DSCP 标

    DSCP差分服务代码点(Differentiated Services Code Point).它在每个数据包IP头部的服务类别TOS标识字节中,利用已使用的6比特和未使用的2比特,通过编码值来区分优 ...