java之mybatis之查询及分页
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之查询及分页的更多相关文章
- Java基础-SSM之mybatis的统计函数和分页查询
Java基础-SSM之mybatis的统计函数和分页查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.
- Oracle使用MyBatis中RowBounds实现分页查询
Oracle中分页查询因为存在伪列rownum,sql语句写起来较为复杂,现在介绍一种通过使用MyBatis中的RowBounds进行分页查询,非常方便. 使用MyBatis中的RowBounds进行 ...
- SSM整合 mybatis多条件查询与分页
多条件查询与分页: 通过页面的houseName.floorage获取值传到前端视图(HouseSearchVO)实体类中的houseName,floorage建立houseSearchVO对象. 通 ...
- Mybatis的插件 PageHelper 分页查询使用方法
参考:https://blog.csdn.net/ckc_666/article/details/79257028 Mybatis的一个插件,PageHelper,非常方便mybatis分页查询,国内 ...
- Java之mybatis详解
文章大纲 一.mybatis介绍二.mybatis代码实战三.项目源码下载四.参考文章 一.mybatis介绍 1. mybatis是什么? mybatis是一个持久层的框架,是apache下 ...
- MyBatis Generator实现MySQL分页插件
MyBatis Generator是一个非常方便的代码生成工具,它能够根据表结构生成CRUD代码,可以满足大部分需求.但是唯一让人不爽的是,生成的代码中的数据库查询没有分页功能.本文介绍如何让MyBa ...
- java:easyui(jQueryEasyUI,分页)
1.介绍: jQuery EasyUI是一组基于jQuery的UI插件集合体,而jQuery EasyUI的目标就是帮助web开发者更轻松的打造出功能丰富并且美观的UI界面.开发者不需要编写复杂的ja ...
- 九:SpringBoot-整合Mybatis框架,集成分页助手插件
九:SpringBoot-整合Mybatis框架,集成分页助手插件 1.Mybatis框架 1.1 mybatis特点 1.2 适用场景 2.SpringBoot整合MyBatis 2.1 核心依赖 ...
- myBatis批量查询操作,xml中使用foreach案例
使用场景:有一个订单表,实体类为OrderBase.java,订单有个状态为status值可能为"1,2,3,4,5,6",现在需要查询状态为"2,3,4"的订 ...
随机推荐
- Nexus OSS私服仓库的备份与迁移
背景 在上一篇博客 [Maven学习]Nexus OSS私服仓库的安装和配置 中,我们已经在机房搭建好了新的Nexus OSS私服仓库.下面是两个版本的Nexus OSS私服仓库的对比图. 老的Nex ...
- Unity3D普通开发人员,U3D主程分别需要掌握的技能
Unity3D普通开发人员 1.会查看和搜索unity API文档,熟悉一些3D术语单词 2.查看别人的代码,能够依葫芦画瓢 3.能够制作一些常见的UI效果,善用缓动类插件,如Do Tween pro ...
- linux驱动由浅入深系列:高通sensor架构实例分析之二(驱动代码结构)【转】
本文转载自:https://blog.csdn.net/radianceblau/article/details/73498303 本系列导航: linux驱动由浅入深系列:高通sensor架构实例分 ...
- Django入门2开发工具pycharm的配置
在pycharm中新建django项目 查看django是否安装成功 运行django 设置pycharm快捷键 设置python模板,新建的python文件就会自动生成一些信息 设置django启动 ...
- [ERROR] ionic-app-scripts has unexpectedly closed (exit code 1).
这个错误是因为缺失 '@ionic/app-scripts',只要安装 '@ionic/app-scripts' 即可. 解决方法:npm install @ionic/app-scripts@lat ...
- 🐯 php项目中类的自动加载
主要函数:spl_autoload_register() — 注册给定的函数作为 __autoload() 的实现 将函数注册到SPL __autoload函数队列中.如果该队列中的函数尚未激活,则激 ...
- 消息中间件 kafka rabbitmq 选型差异
https://www.zhihu.com/question/43557507 https://baijiahao.baidu.com/s?id=1610644333184173190&wfr ...
- vs2015 debug时出现 C2039“cout”: 不是“std”的成员
今天想起电脑上的vs2015,发现好久没用了,用了下,遇到了一个问题 由于不常用c++,还是觉得应该记录下来,以免下次遇到,不知怎么处理 新建项目Hello Hello.cpp #include &q ...
- SPI ServiceLoader源码分析
public class ddd { public static void main(String[] args) { ServiceLoader1<Hello> sl = Service ...
- LinkedHashSet有没有重复的元素
1.LinkedHashSet 的概述和使用 llinkedHashSet 的特点: 是唯一能保证怎么存就怎么输出的 set 集合,并且去重复 1 LinkedHashSet<String& ...