MyBatis 是一款優秀的持久層框架,它支持定製化 SQL、存儲過程以及高級映射,目前很大一部分互聯網、軟件公司都在使用這套框架java
關於Mybatis-Generator的下載能夠到這個地址:https://github.com/mybatis/generator/releases,
mysql
下來來以後,咱們主要關注幾個文件git
配置文件:generator.propertiesgithub
主要是數據庫的相關配置,以及文件生成的根路徑web
generator.jdbc.driver=com.mysql.jdbc.Driver generator.jdbc.url=jdbc:mysql://192.168.xxx.xxx:4596/ek?useUnicode=true&characterEncoding=utf8 generator.jdbc.username=root #\u6570\u636e\u5e93\u5bc6\u7801\uff0c\u4e0d\u8981\u52a0\u5bc6\uff01\uff01\uff01 generator.jdbc.password=ek2018 #\u6570\u636e\u5e93\u540d generator.jdbc.database=ek #\u8868\u7684\u524d\u7f00 generator.jdbc.tablePrefix=t_ #\u751f\u6210\u7684package\u7ed3\u6784 generator.package.name=com.ek #\u751f\u6210\u5230\u7684\u9879\u76ee\u7684\u6839\u8def\u5f84\uff0c\u4f8b\u5982\uff1a\u751f\u6210\u5230\u9879\u76eeexue-authcenter-web\u4e0b\u65f6\uff0c\u53ef\u4ee5\u8fd9\u4e48\u914d\u7f6e\uff1a #generator.target.rootPath=E:/MLCS_HQB/workspace/git/exuePlat/exue-authcenter/exue-authcenter-web generator.target.rootPath=E:/WorkSpace/eke/code-generator
generatorConfig.xmlspring
這裏主要是引用配置文件裏的數據庫配置,標明model、MapperXml、Mapper等文件生成的路徑sql
<table>標籤裏寫須要生成文件的表有哪些數據庫
<!-- 數據庫鏈接 --> <jdbcConnection driverClass="${generator.jdbc.driver}" connectionURL="${generator.jdbc.url}" userId="${generator.jdbc.username}" password="exue2018" /> <!-- model生成 --> <javaModelGenerator targetPackage="com.exue.dao.model" targetProject="E:/WorkSpace/eLearning/exue-eLearning/exue-code-generator/src/main/java" /> <!-- MapperXML生成 --> <sqlMapGenerator targetPackage="com.exue.dao.mapper" targetProject="E:/WorkSpace/eLearning/exue-eLearning/exue-code-generator/src/main/java" /> <!-- Mapper接口生成 --> <javaClientGenerator targetPackage="com.exue.dao" targetProject="E:/WorkSpace/eLearning/exue-eLearning/exue-code-generator/src/main/java" type="XMLMAPPER" /> <!-- 須要映射的表 --> <!-- 須要映射的表 --> <table tableName="t_user_base" domainObjectName="UserBase"></table>
配置文件結束後,執行Generator.java裏的main方法,刷新項目,就ok了mybatis
在如今中,咱們可能須要對生成的文件內容作一些額外的配置,那就根據具體需求在模板文件裏修改app
該要的文件都有了,放到項目中的特定包下
下面看下pom.xml須要加哪些依賴包
<dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.0</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.41</version> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.1</version> </dependency> <!--mapper--> <dependency> <groupId>tk.mybatis</groupId> <artifactId>mapper-spring-boot-starter</artifactId> <version>1.2.4</version> </dependency> <!--pagehelper--> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>1.2.3</version> </dependency>
包括了mysql數據驅動,Mybatis的啓動包,數據庫鏈接池druid相關依賴
打開Spring Boot啓動類,在類上添加註解@MapperScan("com.example.demo.mapper"),記得要掃描mapper接口
@SpringBootApplication @MapperScan("com.example.demo.mapper") public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } }
而後來看下mysql的配置,打開application.properties
#datasource spring.datasource.url=jdbc:mysql://192.168.128.183:4596/eke?useUnicode=true&characterEncoding=UTF-8&useSSL=false spring.datasource.username=root spring.datasource.password=exue2018 spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.druid.initial-size=1 spring.datasource.druid.min-idle=5 spring.datasource.druid.max-active=20 spring.datasource.druid.max-wait-millis=60000 #mybatis mybatis.type-aliases-package=com.example.demo.pojo mybatis.mapper-locations=classpath:mapper/*.xml #pagehelper pagehelper.helperDialect=mysql pagehelper.reasonable=true pagehelper.supportMethodsArguments=true pagehelper.params=count=countSql
第一部分是dataSource的配置,包括了數據庫地址,庫名,用戶名,密碼以及相關數據庫鏈接池的配置
第二部分是Mybatis的配置,包括自定義pojo的包路徑,不須要加classpath: 以及Mapper xml的路徑
第三部分是分頁的相關配置
在service層定義接口pageUserBase ,最後返回是以分頁的形式展示
PageResult<UserBaseDTO> pageUserBase(UserBaseDTO searchCondition, Pagination page) throws Exception;
怎麼去實現這個分頁顯示
@Override public PageResult<UserBaseDTO> pageUserBase(UserBaseDTO userBaseDTO, Pagination page) throws Exception { // TODO Auto-generated method stub PageHelper.startPage(page.getPage(),page.getRows()); UserBaseExample UserBaseExamle = new UserBaseExample(); UserBaseExamle.setOrderByClause("p_id DESC"); List<UserBase> listUserBase = userBaseMapper.selectByExample(UserBaseExamle); List<UserBaseDTO> listUserBaseDTO = new ArrayList<UserBaseDTO>(); for(UserBase ub :listUserBase){ UserBaseDTO ubd = new UserBaseDTO(); ubd.setpId(ub.getpId()); ubd.setsPassword(ub.getsPassword()); ubd.setsPhone(ub.getsPhone()); listUserBaseDTO.add(ubd); } Pagination pagination = new Pagination(); pagination = SqlUtil.generatePagination(listUserBase); return new PageResult<>(listUserBaseDTO, pagination); }
PageHelper.startPage(page.getPage(),page.getRows());獲取客戶端傳來的頁碼和一頁顯示記錄數
Pagination pagination = new Pagination(); pagination = SqlUtil.generatePagination(listUserBase);
根據最後返回的list進行分頁處理
返回到controller層後,進行ResponseMsg的封裝後,返回客戶端
PageResult<UserBaseDTO> res = null; List<UserBaseDTO> list = null; UserBaseDTO ubt = new UserBaseDTO(); try { StringBuffer logOut = new StringBuffer(); logOut.append("\n"); logOut.append("cjq2測試"); logOut.append("\n"); LOGGER.debug(logOut.toString()); Pagination page = new Pagination(); page.setPage(1); page.setRows(10);; res = iUserbaseService.pageUserBase(ubt, page); list = res.getList(); } catch (Exception e) { // TODO: handle exception throw new BaseException("數據錯誤"); //LOGGER.error(e.getMessage()); } return new ResponseMsg(requestMsg.getRoute(), GeneralConstant.SUCCESS, "查詢成功", res);
啓動SpringBoot項目