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

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 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());
    }
  }
}


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
16天前
|
缓存 NoSQL 关系型数据库
13- Redis和Mysql如何保证数据⼀致?
该内容讨论了保证Redis和MySQL数据一致性的几种策略。首先提到的两种方法存在不一致风险:先更新MySQL再更新Redis,或先删Redis再更新MySQL。第三种方案是通过MQ异步同步以达到最终一致性,适用于一致性要求较高的场景。项目中根据不同业务需求选择不同方案,如对一致性要求不高的情况不做处理,时效性数据设置过期时间,高一致性需求则使用MQ确保同步,最严格的情况可能涉及分布式事务(如Seata的TCC模式)。
44 6
|
24天前
|
SQL 关系型数据库 MySQL
轻松入门MySQL:保障数据完整性,MySQL事务在进销存管理系统中的应用(12)
轻松入门MySQL:保障数据完整性,MySQL事务在进销存管理系统中的应用(12)
|
2天前
|
SQL 关系型数据库 MySQL
Spring_jdbc数据连接池(mysql实现增、删、改、查)
Spring_jdbc数据连接池(mysql实现增、删、改、查)
8 0
|
4天前
|
存储 数据可视化 关系型数据库
MySQL字段的时间类型该如何选择?千万数据下性能提升10%~30%🚀
本文探讨MySQL中时间类型的选择,阐述datetime、timestamp、整形时间戳等类型特点以及它们在千万级数据量下的查询性能
MySQL字段的时间类型该如何选择?千万数据下性能提升10%~30%🚀
|
18天前
|
Java 关系型数据库 MySQL
【mybatis-plus】自定义多数据源,动态切换数据源事务失效问题
【mybatis-plus】自定义多数据源,动态切换数据源事务失效问题
【mybatis-plus】自定义多数据源,动态切换数据源事务失效问题
|
18天前
|
测试技术 C语言
网站压力测试工具Siege图文详解
网站压力测试工具Siege图文详解
26 0
|
1月前
|
JavaScript jenkins 测试技术
这10款性能测试工具,收藏起来,测试人的工具箱!
这10款性能测试工具,收藏起来,测试人的工具箱!
|
1月前
|
人工智能 监控 测试技术
利用AI辅助工具提升软件测试效率
【2月更文挑战第17天】 随着科技的不断发展,人工智能(AI)在各个领域的应用越来越广泛。在软件测试领域,AI技术也发挥着重要作用。本文将探讨如何利用AI辅助工具提升软件测试效率,包括自动化测试、智能缺陷识别和预测等方面。通过引入AI技术,软件测试过程将变得更加高效、准确和可靠。
195 1
|
1月前
|
Web App开发 前端开发 测试技术
探索自动化测试工具:Selenium的威力与应用
探索自动化测试工具:Selenium的威力与应用
探索自动化测试工具:Selenium的威力与应用
|
1月前
|
测试技术
现代软件测试中的自动化工具与挑战
传统软件测试面临着越来越复杂的系统架构和不断增长的测试需求,自动化测试工具应运而生。本文将探讨现代软件测试中自动化工具的应用和挑战,深入分析其优势与局限性,为软件测试领域的发展提供思路和启示。