- MyBatis可以如何实现分页查询?
Say.夏夜
mybatis
在MyBatis中实现分页查询,主要有以下几种方法:1.使用MyBatis分页插件:MyBatis有一个非常流行的分页插件叫做PageHelper。它允许你通过简单的配置就能实现分页查询。使用PageHelper,你只需要在你的Mapper接口的方法上添加@Select注解,然后在方法调用前使用PageHelper的startPage方法即可。例如://在Mapper接口中的方法@Select("
- MyBatis如何实现分页
思静语
#Mybatismybatis
文章目录MyBatis分页方式对比使用数据库厂商提供的分页查询语句通过自定义SQL实现分页逻辑1.使用RowBounds实现分页2.使用PageHelper实现分页数组分页使用MyBatis-Plus进行分页MyBatis物理分页和逻辑分页MyBatis手写一个拦截器分页在MyBatis中实现分页通常有两种方式:使用数据库厂商提供的分页查询语句(如MySQL的LIMIT)或者通过自定义SQL来实现
- mysql实用系列:查询语句开启分页
Ven%
mysql实用系列mysql数据库mybatis
在SpringBoot项目中使用MyBatis分页插件(PageHelper)的步骤如下:添加依赖:在项目的pom.xml文件中添加PageHelper的依赖。com.github.pagehelperpagehelper-spring-boot-starter最新版本配置属性:在application.properties或application.yml文件中配置PageHelper的属性。#a
- 分页查询的两种实现方法
cyt涛
javamybatisjava数据库分页查询intellijidea
第一种:mybatis-plus自带的分页方法,通过调用selectPage方法实现分页,适用于通过QueryWrapper拼装SQL。第二种:pagehelper分页组件适用于自定义sql的分页查询。pagehelper分页组件的原理如下:调用PageHelper.startPage方法设置分页参数,通过一层一层进入源码,最终将分页参数设置到ThreadLocalLOCAL_PAGE=newTh
- PageInfo
河hehe
MyBatismybatis
PageInfo是MyBatis分页插件PageHelper中的一个核心类,它主要用于封装分页查询的结果,提供了一系列方法以便开发者获取分页相关的详细信息。以下是关于PageInfo的详细介绍:一、PageInfo的作用PageInfo类封装了分页查询后的结果,包括当前页的数据列表、总记录数、总页数、当前页码、每页记录数等信息。通过调用PageInfo类提供的方法,开发者可以方便地获取这些分页信息
- List集合分页工具类,重新封装PageHelper,PageInfo实现
湖城彭于晏
#java工具类java
参看另一篇博客,仅需调用工具类内的一个方法即可对现有List分页,代码较为简洁,使用的PageHelper,PageInfo实现https://blog.csdn.net/weixin_44190087/article/details/114289432以下工具类方法较为繁琐,实现类中需要编写过多代码,每个接口实现分页都会重复编写部分代码,不建议使用;工具类packagecn.*.*.server
- 多年以后,PageHelper 又深深给我上了一课!
java
多年不用PageHelper了,最近新入职的公司,采用了此工具集成的框架,作为一个独立紧急项目开发的基础。项目开发起来,还是手到擒来的,但是没想到,最终测试的时候,深深的给我上了一课。我的项目发生了哪些奇葩现象?一切的问题都要从我接受的项目开始说起,在开发这个项目的过程中,发生了各种奇葩的事情,下面我简单说给你们听听:账号重复注册?你肯定在想这是什么意思?就是字面意思,已经注册的账号,可以再次注册
- MyBatis--08--分页插件PageHelper
知行合一。。。
Spring基础知识--SSMmybatisandroid
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录1.分页插件PageHelper1.1mysql中limit关键字含义1.2PageHelper官网https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/HowToUse.md](https://github.com/pagehelper/M
- mybatis整合plugin处理
我不是攻城狮
mybatis
1、注入SqlSessionFatory时候会初始化所有拦截器,2、发生在handle时期,将plugin加入到org.apache.ibatis.plugin.InterceptorChain的链路当中,3、methodinvoke方法执行拦截器中的拦截方法(比如myabatisplus里面的分库分表,pageHelper里面的修改sql,替换sql的操作。4、执行拦截器拦截后的sql操作,ex
- mybatis-plus、PageHelper分页插件
我不是攻城狮
mybatismybatis
PageHelper:轻量级插件,无须撰写limit语句。PageHelper.startPage(1,10);ListuserList=userMapper.getUsers();PageInfopageInfo=newPageInfowrapper=newQueryWrapper();wrapper.gt("age",20);Pagepage=newPageiPage=this.userMap
- RuoYi模块功能分析:第七章分页实现及mybatis分页插件实现原理
真让人秃头呀
Java开发专栏windowsjava
文章目录一、依赖二、若依的使用2.1、PageUtils工具类2.2、SQL注入一、依赖com.github.pagehelperpagehelper-spring-boot-starter二、若依的使用@PreAuthorize("@ss.hasPermi('monitor:operlog:list')")@GetMapping("/list")publicTableDataInfolist(S
- 3.MyBatis核心配置文件(mybatis-config.xml)
未禾
Mybatismybatisxmljava
目录1.Mybatis基本介绍2.Mybatis基本使用(三种方式)3.MyBatis核心配置文件(mybatis-config.xml)4.Mybatis映射文件(类名+Mapper.xml)5.Mybatis动态SQL6.Mybatis分页插件(PageHelper),解决PageHelper.startPage()不安全分页7.Mybatis一级缓存、二级缓存8.Mybatis核心类生命周期
- Spring boot 实战指南:Mybatis、动态绑定、多数据源、分页插件、Mybatis-Plus
java的小粉丝
文章目录二、整合Mybatis多数据源三、整合分页插件PageHelper1.搭建数据库、项目配置3.在代码中使用PageHelperMybatis在整个体系中的作用是负责连接并访问数据库层。搞过开发的同学都知道,没有数据库的项目一无是处,所以Mybatis的学习是很有必要的。准备工作:数据库:在进入正式学习前,先确保Mysql已经在电脑上安装好了,最好再安装一个可视化管理工具NavicatPre
- MyBatis分页插件之PageHelper详细介绍
小袁搬码
SpringbootMyBatismybatisSpringBootSpringPageHelper
MyBatis分页插件之PageHelper详细介绍文章目录MyBatis分页插件之PageHelper详细介绍1.官网及介绍1.官网2.特点1.物理分页2.支持多种分页方式3.使用QueryInterceptor规范2.引入分页插件1.引入Jar包2.使用Maven1.非SpringBoot2.使用Springboot3.使用gradle1.非SprinBoot2.使用SpringBoot3.配
- Mybatis PageHelper 异常 attempted to return null from a method with a primitive return type (long)问题分析
gclhaha
踩坑mybatisjava
MybatisPageHelper异常attemptedtoreturnnullfromamethodwithaprimitivereturntype(long)问题分析问题背景某天工程师群里发了个分页的问题,当时我手头没有急的工作,就帮忙看了下。一开始看到分页的字段使用的比较特殊,经过调整统一后,发现接口在第二页直接返回了错误:attemptedtoreturnnullfromamethodwi
- SpringBoot-基础篇03
小元祖
日常开发笔记springboot后端java
之前搭建了整个开发环境实现了登录注册,springBoot整合mybatis完成增删改查,今天完成分页查询,使用阿里云oss存储照片等资源,后期会尝试自己搭建分布式文件系统来实现。一,SpringBoot+Mybatis完成分页查询1,导入分页插件坐标,我们需要使用分页插件帮助我们实现分页查询:com.github.pagehelperpagehelper-spring-boot-starter1
- SpringBoot之整合PageHelper分页插件
小袁搬码
MyBatisJava17springboot后端javamybatisPageHelper
SpringBoot之整合PageHelper分页插件文章目录SpringBoot之整合PageHelper分页插件1.引入坐标2.application.yml配置3.基本使用4.对多个查询执行分页1.默认第一个Select语句会执行分页2.让Pagehelper也能执行多个分页的方法3.完整案例详细配置请查看官网或MyBatis分页插件之PageHelper详细介绍-CSDN博客1.引入坐标c
- PageHelper.startPage(pageNum, pageSize);分页总数不正确,避坑!
Cookie-a
mybatisjava
今天在调用一个查询列表的接口时,分页总数老是查的不正确:当pageSize选择10时,总数只有10条当pageSize选择20时,总数只有15条实际上总数为15条实在正确的,然后取看代码:@OverridepublicAjaxResultprojectCountDetail(Longid,StorageAccountaccount,StringfirstCategory,StringsecondC
- 5Why分析法——提测质量问题复盘
吴代庄
复盘职场发展
背景我们的产品致力于为金融领域的客户提供优质服务。在市场层面,我们拥有广泛的客户群体。由于开发周期和合同签订时间的差异,不同客户所使用的系统往往运行在不同版本的代码分支上。近期在排查一个PageHelper的使用问题时,具体文章参考《PageHelper缓存在线程中的分页对象未释放问题排查方案》。发现在最近一段时间内,有若干问题仅在我们最新的代码版本中得到了修正,而并未及时同步更新到每位客户所使用
- sharding-jdbc 与pageHelper分页报错踩坑
学的好秃的早
sql数据库mysql
遇到问题Sharding-jdbc4.0.1版本使用pageHelper运行count报错,而且只有部分sql不能运行:原始sqlSELECTuser_id,SUM(total_duration)totalDuration,SUM(live_total_duration)liveTotalDuration,SUM(replay_total_duration)replayTotalDurationF
- Mybatis 分页插件 PageHelper
有一个好名字
mybatisSpringBootmybatisjava数据库
今天记录下Mybatis分页插件pageHelper的使用。背景有一个员工表(employee),现在要使用pageHelper插件实现员工的分页查询。员工表createtableemployee(idbigintauto_incrementcomment'主键'primarykey,namevarchar(32)notnullcomment'姓名',usernamevarchar(32)notn
- 使用pagehelper插件进行分页查询
OnTheSummit
MyBatisspringjavamybatis
一、导入mybatis和pagehelper坐标org.mybatis.spring.bootmybatis-spring-boot-starter2.2.0com.github.pagehelperpagehelper-spring-boot-starter1.3.0二、配置数据库spring:main:allow-circular-references:truedatasource:druid
- PageHelper 的奇葩之处
LINgZone2
java数据库mybatis
多年不用PageHelper了,最近新入职的公司,采用了此工具集成的框架,作为一个独立紧急项目开发的基础。项目开发起来,还是手到擒来的,但是没想到,最终测试的时候,深深的给我上了一课。我的项目发生了哪些奇葩现象?一切的问题都要从我接受的项目开始说起,在开发这个项目的过程中,发生了各种奇葩的事情,下面我简单说给你们听听:账号重复注册?你肯定在想这是什么意思?就是字面意思,已经注册的账号,可以再次注册
- Mybatis的缓存机制 以及pageHelper分页
我真的是自愿的
缓存:暂时的存储一些数据;加快系统的查询速度..mybatis的缓存机制:Map:能保存查询的数据一级缓存:线程级别的缓存,本地缓存,SqlSession级别的缓存(只要是之前查询过的数据,mybatis就会保存在缓存中一个map,下次获取直接从缓存中拿)二级缓存:全局范围内的缓存;除了当前线程sqlSession可以用以外,其他的sqlSession也可以用一级缓存失效的几种情况:一级缓存是sq
- 多线程解压缩包
Zxdwr520
SpringBootjava
packagecom.my.tpp.utils;importcn.hutool.core.codec.Base64Encoder;importcn.hutool.core.date.DateTime;importcom.github.pagehelper.util.StringUtil;importlombok.extern.slf4j.Slf4j;importcom.google.common.
- java读取excel文件的内容(包括图片)
Zxdwr520
SpringBootjavaexcel开发语言
直接上代码packagecom.fan.li.utils;importcn.hutool.core.codec.Base64Encoder;importcom.github.pagehelper.util.StringUtil;importorg.apache.commons.lang3.StringUtils;importorg.apache.poi.EncryptedDocumentExcep
- springboot页面子查询助手及依赖
ikun,ikun
javaspringboot
实现代码需要传递页码,和展示的页数@Overridepublicbagebeamhuoquemp(Integerpage,IntegerageSize,Stringname,Bytegender,LocalDatebegin,LocalDateend){ //提交参数需要传递页码,和展示的页数PageHelper.startPage(page,ageSize); //所需要查询参数Listfong
- PageHelper学习使用
weixin_44877172
Java学习mybatis
基于mybatis源码和PageHelper源码进行的测试版本mybatis3.5.0,pageHelper6.0.0测试用例依赖mysqlmysql-connector-java8.0.15junitjunit4.11testcom.github.pagehelperpagehelper6.0.0org.mybatismybatis3.5.0如果引入上面这些依赖运行报下面这样的错误需要再引入两个
- 【MyBatis框架】第六章 PageHelper
阿斯卡码
Mybatismybatisoracle数据库
第六章PageHelper第六章PageHelper1.加入依赖pagehelper依赖2.在mybatis主配置文件,加入plugin声明3.在select语句之前,调用PageHelper.startPage(页码,每页大小)欢迎来到本博客作者简介:阿斯卡码,专注于研究Java框架/Vue,就读于河南中医药大学,刚刚入门项目开发CSDN编程比赛奖章获得者/Java领域创作者计划学习:深入学习S
- PageHelper分页原理解析
宏远十一冠王
springjava基础语法数据库javamybatis
大家好,我是Leo!今天给大家带来的是关于PageHelper原理的解析,最近遇到一个SQL优化的问题,顺便研究了一下PageHelper的原理,毕竟也是比较常用,源码也比较好看的懂,如果感兴趣的小伙伴可以跟着过程去DEBUG源码,相信会有一定收获,源码也采用了策略、工厂等设计模式总体流程在调用startPage时,将分页对象Page参数保存下来,留意setLocalPage方法,该方法是保存分页
- 关于旗正规则引擎下载页面需要弹窗保存到本地目录的问题
何必如此
jsp超链接文件下载窗口
生成下载页面是需要选择“录入提交页面”,生成之后默认的下载页面<a>标签超链接为:<a href="<%=root_stimage%>stimage/image.jsp?filename=<%=strfile234%>&attachname=<%=java.net.URLEncoder.encode(file234filesourc
- 【Spark九十八】Standalone Cluster Mode下的资源调度源代码分析
bit1129
cluster
在分析源代码之前,首先对Standalone Cluster Mode的资源调度有一个基本的认识:
首先,运行一个Application需要Driver进程和一组Executor进程。在Standalone Cluster Mode下,Driver和Executor都是在Master的监护下给Worker发消息创建(Driver进程和Executor进程都需要分配内存和CPU,这就需要Maste
- linux上独立安装部署spark
daizj
linux安装spark1.4部署
下面讲一下linux上安装spark,以 Standalone Mode 安装
1)首先安装JDK
下载JDK:jdk-7u79-linux-x64.tar.gz ,版本是1.7以上都行,解压 tar -zxvf jdk-7u79-linux-x64.tar.gz
然后配置 ~/.bashrc&nb
- Java 字节码之解析一
周凡杨
java字节码javap
一: Java 字节代码的组织形式
类文件 {
OxCAFEBABE ,小版本号,大版本号,常量池大小,常量池数组,访问控制标记,当前类信息,父类信息,实现的接口个数,实现的接口信息数组,域个数,域信息数组,方法个数,方法信息数组,属性个数,属性信息数组
}
&nbs
- java各种小工具代码
g21121
java
1.数组转换成List
import java.util.Arrays;
Arrays.asList(Object[] obj); 2.判断一个String型是否有值
import org.springframework.util.StringUtils;
if (StringUtils.hasText(str)) 3.判断一个List是否有值
import org.spring
- 加快FineReport报表设计的几个心得体会
老A不折腾
finereport
一、从远程服务器大批量取数进行表样设计时,最好按“列顺序”取一个“空的SQL语句”,这样可提高设计速度。否则每次设计时模板均要从远程读取数据,速度相当慢!!
二、找一个富文本编辑软件(如NOTEPAD+)编辑SQL语句,这样会很好地检查语法。有时候带参数较多检查语法复杂时,结合FineReport中生成的日志,再找一个第三方数据库访问软件(如PL/SQL)进行数据检索,可以很快定位语法错误。
- mysql linux启动与停止
墙头上一根草
如何启动/停止/重启MySQL一、启动方式1、使用 service 启动:service mysqld start2、使用 mysqld 脚本启动:/etc/inint.d/mysqld start3、使用 safe_mysqld 启动:safe_mysqld&二、停止1、使用 service 启动:service mysqld stop2、使用 mysqld 脚本启动:/etc/inin
- Spring中事务管理浅谈
aijuans
spring事务管理
Spring中事务管理浅谈
By Tony Jiang@2012-1-20 Spring中对事务的声明式管理
拿一个XML举例
[html]
view plain
copy
print
?
<?xml version="1.0" encoding="UTF-8"?>&nb
- php中隐形字符65279(utf-8的BOM头)问题
alxw4616
php中隐形字符65279(utf-8的BOM头)问题
今天遇到一个问题. php输出JSON 前端在解析时发生问题:parsererror.
调试:
1.仔细对比字符串发现字符串拼写正确.怀疑是 非打印字符的问题.
2.逐一将字符串还原为unicode编码. 发现在字符串头的位置出现了一个 65279的非打印字符.
 
- 调用对象是否需要传递对象(初学者一定要注意这个问题)
百合不是茶
对象的传递与调用技巧
类和对象的简单的复习,在做项目的过程中有时候不知道怎样来调用类创建的对象,简单的几个类可以看清楚,一般在项目中创建十几个类往往就不知道怎么来看
为了以后能够看清楚,现在来回顾一下类和对象的创建,对象的调用和传递(前面写过一篇)
类和对象的基础概念:
JAVA中万事万物都是类 类有字段(属性),方法,嵌套类和嵌套接
- JDK1.5 AtomicLong实例
bijian1013
javathreadjava多线程AtomicLong
JDK1.5 AtomicLong实例
类 AtomicLong
可以用原子方式更新的 long 值。有关原子变量属性的描述,请参阅 java.util.concurrent.atomic 包规范。AtomicLong 可用在应用程序中(如以原子方式增加的序列号),并且不能用于替换 Long。但是,此类确实扩展了 Number,允许那些处理基于数字类的工具和实用工具进行统一访问。
 
- 自定义的RPC的Java实现
bijian1013
javarpc
网上看到纯java实现的RPC,很不错。
RPC的全名Remote Process Call,即远程过程调用。使用RPC,可以像使用本地的程序一样使用远程服务器上的程序。下面是一个简单的RPC 调用实例,从中可以看到RPC如何
- 【RPC框架Hessian一】Hessian RPC Hello World
bit1129
Hello world
什么是Hessian
The Hessian binary web service protocol makes web services usable without requiring a large framework, and without learning yet another alphabet soup of protocols. Because it is a binary p
- 【Spark九十五】Spark Shell操作Spark SQL
bit1129
shell
在Spark Shell上,通过创建HiveContext可以直接进行Hive操作
1. 操作Hive中已存在的表
[hadoop@hadoop bin]$ ./spark-shell
Spark assembly has been built with Hive, including Datanucleus jars on classpath
Welcom
- F5 往header加入客户端的ip
ronin47
when HTTP_RESPONSE {if {[HTTP::is_redirect]}{ HTTP::header replace Location [string map {:port/ /} [HTTP::header value Location]]HTTP::header replace Lo
- java-61-在数组中,数字减去它右边(注意是右边)的数字得到一个数对之差. 求所有数对之差的最大值。例如在数组{2, 4, 1, 16, 7, 5,
bylijinnan
java
思路来自:
http://zhedahht.blog.163.com/blog/static/2541117420116135376632/
写了个java版的
public class GreatestLeftRightDiff {
/**
* Q61.在数组中,数字减去它右边(注意是右边)的数字得到一个数对之差。
* 求所有数对之差的最大值。例如在数组
- mongoDB 索引
开窍的石头
mongoDB索引
在这一节中我们讲讲在mongo中如何创建索引
得到当前查询的索引信息
db.user.find(_id:12).explain();
cursor: basicCoursor 指的是没有索引
&
- [硬件和系统]迎峰度夏
comsci
系统
从这几天的气温来看,今年夏天的高温天气可能会维持在一个比较长的时间内
所以,从现在开始准备渡过炎热的夏天。。。。
每间房屋要有一个落地电风扇,一个空调(空调的功率和房间的面积有密切的关系)
坐的,躺的地方要有凉垫,床上要有凉席
电脑的机箱
- 基于ThinkPHP开发的公司官网
cuiyadll
行业系统
后端基于ThinkPHP,前端基于jQuery和BootstrapCo.MZ 企业系统
轻量级企业网站管理系统
运行环境:PHP5.3+, MySQL5.0
系统预览
系统下载:http://www.tecmz.com
预览地址:http://co.tecmz.com
各种设备自适应
响应式的网站设计能够对用户产生友好度,并且对于
- Transaction and redelivery in JMS (JMS的事务和失败消息重发机制)
darrenzhu
jms事务承认MQacknowledge
JMS Message Delivery Reliability and Acknowledgement Patterns
http://wso2.com/library/articles/2013/01/jms-message-delivery-reliability-acknowledgement-patterns/
Transaction and redelivery in
- Centos添加硬盘完全教程
dcj3sjt126com
linuxcentoshardware
Linux的硬盘识别:
sda 表示第1块SCSI硬盘
hda 表示第1块IDE硬盘
scd0 表示第1个USB光驱
一般使用“fdisk -l”命
- yii2 restful web服务路由
dcj3sjt126com
PHPyii2
路由
随着资源和控制器类准备,您可以使用URL如 http://localhost/index.php?r=user/create访问资源,类似于你可以用正常的Web应用程序做法。
在实践中,你通常要用美观的URL并采取有优势的HTTP动词。 例如,请求POST /users意味着访问user/create动作。 这可以很容易地通过配置urlManager应用程序组件来完成 如下所示
- MongoDB查询(4)——游标和分页[八]
eksliang
mongodbMongoDB游标MongoDB深分页
转载请出自出处:http://eksliang.iteye.com/blog/2177567 一、游标
数据库使用游标返回find的执行结果。客户端对游标的实现通常能够对最终结果进行有效控制,从shell中定义一个游标非常简单,就是将查询结果分配给一个变量(用var声明的变量就是局部变量),便创建了一个游标,如下所示:
> var
- Activity的四种启动模式和onNewIntent()
gundumw100
android
Android中Activity启动模式详解
在Android中每个界面都是一个Activity,切换界面操作其实是多个不同Activity之间的实例化操作。在Android中Activity的启动模式决定了Activity的启动运行方式。
Android总Activity的启动模式分为四种:
Activity启动模式设置:
<acti
- 攻城狮送女友的CSS3生日蛋糕
ini
htmlWebhtml5csscss3
在线预览:http://keleyi.com/keleyi/phtml/html5/29.htm
代码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>攻城狮送女友的CSS3生日蛋糕-柯乐义<
- 读源码学Servlet(1)GenericServlet 源码分析
jzinfo
tomcatWebservlet网络应用网络协议
Servlet API的核心就是javax.servlet.Servlet接口,所有的Servlet 类(抽象的或者自己写的)都必须实现这个接口。在Servlet接口中定义了5个方法,其中有3个方法是由Servlet 容器在Servlet的生命周期的不同阶段来调用的特定方法。
先看javax.servlet.servlet接口源码:
package
- JAVA进阶:VO(DTO)与PO(DAO)之间的转换
snoopy7713
javaVOHibernatepo
PO即 Persistence Object VO即 Value Object
VO和PO的主要区别在于: VO是独立的Java Object。 PO是由Hibernate纳入其实体容器(Entity Map)的对象,它代表了与数据库中某条记录对应的Hibernate实体,PO的变化在事务提交时将反应到实际数据库中。
实际上,这个VO被用作Data Transfer
- mongodb group by date 聚合查询日期 统计每天数据(信息量)
qiaolevip
每天进步一点点学习永无止境mongodb纵观千象
/* 1 */
{
"_id" : ObjectId("557ac1e2153c43c320393d9d"),
"msgType" : "text",
"sendTime" : ISODate("2015-06-12T11:26:26.000Z")
- java之18天 常用的类(一)
Luob.
MathDateSystemRuntimeRundom
System类
import java.util.Properties;
/**
* System:
* out:标准输出,默认是控制台
* in:标准输入,默认是键盘
*
* 描述系统的一些信息
* 获取系统的属性信息:Properties getProperties();
*
*
*
*/
public class Sy
- maven
wuai
maven
1、安装maven:解压缩、添加M2_HOME、添加环境变量path
2、创建maven_home文件夹,创建项目mvn_ch01,在其下面建立src、pom.xml,在src下面简历main、test、main下面建立java文件夹
3、编写类,在java文件夹下面依照类的包逐层创建文件夹,将此类放入最后一级文件夹
4、进入mvn_ch01
4.1、mvn compile ,执行后会在