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

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 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());
    }
  }
}


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
6月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
11月前
|
关系型数据库 MySQL 大数据
大数据新视界--大数据大厂之MySQL 数据库课程设计:MySQL 数据库 SQL 语句调优的进阶策略与实际案例(2-2)
本文延续前篇,深入探讨 MySQL 数据库 SQL 语句调优进阶策略。包括优化索引使用,介绍多种索引类型及避免索引失效等;调整数据库参数,如缓冲池、连接数和日志参数;还有分区表、垂直拆分等其他优化方法。通过实际案例分析展示调优效果。回顾与数据库课程设计相关文章,强调全面认识 MySQL 数据库重要性。为读者提供综合调优指导,确保数据库高效运行。
|
存储 SQL 关系型数据库
服务器数据恢复—云服务器上mysql数据库数据恢复案例
某ECS网站服务器,linux操作系统+mysql数据库。mysql数据库采用innodb作为默认存储引擎。 在执行数据库版本更新测试时,操作人员误误将在本来应该在测试库执行的sql脚本在生产库上执行,导致生产库上部分表被truncate,还有部分表中少量数据被delete。
316 25
|
11月前
|
SQL 缓存 关系型数据库
使用温InnoDB缓冲池启动MySQL测试
使用温InnoDB缓冲池启动MySQL测试
210 0
|
11月前
|
SQL 缓存 关系型数据库
MySQL8.4 Enterprise安装Firewall及测试
MySQL8.4 Enterprise安装Firewall及测试
367 0
|
11月前
|
安全 关系型数据库 MySQL
MySQL8使用物理文件恢复MyISAM表测试
MySQL8使用物理文件恢复MyISAM表测试
240 0
|
12月前
|
Oracle 关系型数据库 MySQL
使用崖山YMP 迁移 Oracle/MySQL 至YashanDB 23.2 验证测试
这篇文章是作者尚雷关于使用崖山YMP迁移Oracle/MySQL至YashanDB 23.2的验证测试分享。介绍了YMP的产品信息,包括架构、版本支持等,还详细阐述了外置库部署、YMP部署、访问YMP、数据源管理、任务管理(创建任务、迁移配置、离线迁移、校验初始化、一致性校验)及MySQL迁移的全过程。
|
SQL 关系型数据库 MySQL
数据库数据恢复——MySQL简介和数据恢复案例
MySQL数据库数据恢复环境&故障: 本地服务器,安装的windows server操作系统。 操作系统上部署MySQL单实例,引擎类型为innodb,表空间类型为独立表空间。该MySQL数据库没有备份,未开启binlog。 人为误操作,在用Delete命令删除数据时未添加where子句进行筛选导致全表数据被删除,删除后未对该表进行任何操作。
|
9月前
|
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`注解完成整合
1447 1
Spring boot 使用mybatis generator 自动生成代码插件
|
12月前
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
895 0

推荐镜像

更多