Mybatis+mysql动态分页查询数据案例——测试类HouseDaoMybatisImplTest)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: Mybatis+mysql动态分页查询数据案例——测试类HouseDaoMybatisImplTest)
package cn.bdqn.mhouse.dao.impl;
import static org.junit.Assert.*;
import java.util.Date;
import java.util.List;
import org.junit.Test;
import cn.bdqn.mhouse.dao.IHouseDao;
import cn.bdqn.mhouse.entity.District;
import cn.bdqn.mhouse.entity.House;
import cn.bdqn.mhouse.entity.HouseCondition;
import cn.bdqn.mhouse.entity.Street;
import cn.bdqn.mhouse.entity.Types;
import cn.bdqn.mhouse.entity.Users;
import cn.bdqn.mhouse.util.Page;
/**
 * 
*    
* 项目名称:mhouse   
* 类名称:HouseDaoMybatisImplTest   
* 类描述:   测试房屋信息的测试类
* 创建人:Mu Xiongxiong  
* 创建时间:2017-3-15 下午8:20:44   
* 修改人:Mu Xiongxiong   
* 修改时间:2017-3-15 下午8:20:44   
* 修改备注:   
* @version    
*
 */
public class HouseDaoMybatisImplTest {
  IHouseDao houseDao=new HouseDaoMybatisImpl();
  HouseCondition houseC=new HouseCondition();
  District district=new District();
  House house=new House();
  Users users=new Users();
  Types types=new Types();
  Street street=new Street();
  /**
   * 
  * @Title: testInsert
  * @Description: 该方法的主要作用:
  * @param   设定文件  
  * @return  返回类型:void   
  * @throws
   */
  @Test
  public void testInsert() {
    users.setId(1000);
    types.setId(1000);
    street.setId(1000);
    house.setUsers(users);
    house.setStreet(street);
    house.setTypes(types);
    house.setContact("穆雄雄");
    house.setDescription("描述");
    house.setFloorage(50);
    house.setPrice(2500F);
    house.setPubdate(new Date());
    house.setTitle("标题");
    int rel=houseDao.insert(house);
    if(rel>0){
      System.out.println("添加成功!");
    }else {
      System.out.println("添加失败!");
    }
  }
  /**
   * 
  * @Title: reCount
  * @Description: 该方法的主要作用:动态查询总记录数
  * @param   设定文件  
  * @return  返回类型:void   
  * @throws
   */
  @Test
  public void reCount(){
    houseC.setPriceBegin(50);
    houseC.setPriceEnd(4000);
    houseC.setFloorageBegin(10);
    houseC.setFloorageEnd(6000);
    types.setId(1000);
    houseC.setTypes(types);
    street.setId(1000);
    houseC.setStreet(street);
    int count=houseDao.reCount(houseC);
    System.out.println("总记录数:"+count);
  }
  /**
   * 
  * @Title: reCount
  * @Description: 该方法的主要作用:分页查询房屋信息
  * @param   设定文件  
  * @return  返回类型:void   
  * @throws
   */
  @Test
  public void getHouseInfoByDymanic(){
    Page page=new Page();
//    houseC.setPriceBegin(50);                      //起始价格
//    houseC.setPriceEnd(4000);                      //结束价格
//    houseC.setFloorageBegin(10);                   //起始面积
//    houseC.setFloorageEnd(6000);                   //最终面积
    types.setId(1003);                             //房屋类型
    houseC.setTypes(types);
    street.setId(1003);                //所在的街道
//    //street.setDistrict(district);
    houseC.setStreet(street);
    int pageIndex=3;
    page=houseDao.getHouseInfoByDymanic(houseC, pageIndex);
    System.out.println("当前页是:"+page.getPageIndex());
    System.out.println("下一页是:"+page.getNextPage());
    System.out.println("上一页是:"+page.getPrePage());
    System.out.println("总记录数:"+page.getRecord());
    System.out.println("总页数是:"+page.getTotalPageCount());
    System.out.println("页大小是:"+page.getPageSize());
    List<House> houselist=page.getHouseList();
    for (House house : houselist) {
      System.out.println("房屋标题:"+house.getTitle());
    }
  }
  /**
   * 
  * @Title: testGetHouseInfo
  * @Description: 查询所有的房屋 
  * @param     设定文件
  * @return void    返回类型
  * @throws
   */
  @Test
  public void testGetHouseInfo(){
    Page page=houseDao.getHouseInfo();
    List<House> housel=page.getHouseList();
    for (House house : housel) {
      System.out.println(house.getTitle());
    }
  }
  /**
   * 
  * @Title: testGetAllHousePage
  * @Description: 该方法的主要作用:测试分页查询房屋信息
  * @param   设定文件  
  * @return  返回类型:void   
  * @throws
   */
  @Test
  public void testGetAllHousePage(){
    Page page=houseDao.getHousePage(1);       //当前第一页
    System.out.println("=====================test===================");
    System.out.println("当前页是:"+page.getPageIndex());
    System.out.println("下一页是:"+page.getNextPage());
    System.out.println("上一页是:"+page.getPrePage());
    System.out.println("总记录数:"+page.getRecord());
    System.out.println("总页数是:"+page.getTotalPageCount());
    System.out.println("页大小是:"+page.getPageSize());
    List<House> housel=page.getHouseList();
    for (House house : housel) {
      System.out.println(house.getTitle());
    }
  }
}
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
6月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
|
4月前
|
SQL 人工智能 关系型数据库
如何实现MySQL百万级数据的查询?
本文探讨了在MySQL中对百万级数据进行排序分页查询的优化策略。面对五百万条数据,传统的浅分页和深分页查询效率较低,尤其深分页因偏移量大导致性能显著下降。通过为排序字段添加索引、使用联合索引、手动回表等方法,有效提升了查询速度。最终建议根据业务需求选择合适方案:浅分页可加单列索引,深分页推荐联合索引或子查询优化,同时结合前端传递最后一条数据ID的方式实现高效翻页。
254 0
|
3月前
|
存储 关系型数据库 MySQL
在CentOS 8.x上安装Percona Xtrabackup工具备份MySQL数据步骤。
以上就是在CentOS8.x上通过Perconaxtabbackup工具对Mysql进行高效率、高可靠性、无锁定影响地实现在线快速全量及增加式数据库资料保存与恢复流程。通过以上流程可以有效地将Mysql相关资料按需求完成定期或不定期地保存与灾难恢复需求。
307 10
|
4月前
|
SQL 存储 缓存
MySQL 如何高效可靠处理持久化数据
本文详细解析了 MySQL 的 SQL 执行流程、crash-safe 机制及性能优化策略。内容涵盖连接器、分析器、优化器、执行器与存储引擎的工作原理,深入探讨 redolog 与 binlog 的两阶段提交机制,并分析日志策略、组提交、脏页刷盘等关键性能优化手段,帮助提升数据库稳定性与执行效率。
131 0
|
5月前
|
Java 数据库连接 数据库
Spring boot 使用mybatis generator 自动生成代码插件
本文介绍了在Spring Boot项目中使用MyBatis Generator插件自动生成代码的详细步骤。首先创建一个新的Spring Boot项目,接着引入MyBatis Generator插件并配置`pom.xml`文件。然后删除默认的`application.properties`文件,创建`application.yml`进行相关配置,如设置Mapper路径和实体类包名。重点在于配置`generatorConfig.xml`文件,包括数据库驱动、连接信息、生成模型、映射文件及DAO的包名和位置。最后通过IDE配置运行插件生成代码,并在主类添加`@MapperScan`注解完成整合
954 1
Spring boot 使用mybatis generator 自动生成代码插件
|
8月前
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
669 0
|
10月前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
445 2
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
586 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
495 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
3014 2
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个

推荐镜像

更多