1.SpringMVC和Spring
1.1 新建Maven工程,将之转换成Web工程
1.2 引入依赖
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
<spring.version>5.2.9.RELEASE</spring.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- freemarker -->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.30</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- Jackson 序列化Json数据 -->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.13.0</version>
</dependency>
</dependencies>
1.3 配置 DispatcherServlet
<servlet>
<servlet-name>spring-mvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servletclass>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</init-param>
<load-on-startup>0</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>spring-mvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
1.4解决乱码问题
1. 请求乱码
<filter>
<filter-name>characterFilter</filter-name>
<filterclass>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>characterFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
2. 响应乱码
<mvc:annotation-driven>
<mvc:message-converters>
<bean
class="org.springframework.http.converter.StringHttpMessageConverter">
<property name="supportedMediaTypes">
<list>
<value>text/html;charset=utf-8</value>
<value>application/json;charset=utf-8</value>
</list>
</property>
</bean>
</mvc:message-converters>
</mvc:annotation-driven>
1.5 整合freemarker模板引擎
<bean
class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
<property name="templateLoaderPath" value="/WEB-INF/ftl/"/>
<property name="freemarkerSettings">
<props>
<prop key="DefaultEncoding">UTF-8</prop>
</props>
</property>
</bean>
<bean
class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
<property name="suffix" value=".ftl"/>
<property name="contentType" value="text/html;charset=UTF-8"
</bean>
1.6 配置声明式事务
<!-- 配置事务管理器 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<!-- 声明式事务配置 -->
<tx:annotation-driven transaction-manager="transactionManager"/>
2.Spring整合Mybatis
2.1 环境要求
2.2 引入依赖
<!-- Spring和Mybatis的整合包 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.6</version>
</dependency>
<!-- mybatis -->
2.3 配置
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>
<!-- spring-jdbc -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- 根据自己的MySQL的版本引入相同的驱动包 SPI-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.22</version>
</dependency>
<!-- druid连接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.6</version>
</dependency>
2.3 配置
<!-- 相当于之前在Mybatis配置文件中引入
<properties resource="jdbc.properties"/>
-->
<context:property-placeholder location="classpath:jdbc.properties"/>
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="${jdbc.driverClassName}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<!-- 最大连接数 -->
<property name="maxActive" value="10"/>
<!-- 连接池初始化的连接数 -->
<property name="initialSize" value="4"/>
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<!-- 映射文件的位置 -->
<property name="mapperLocations" value="classpath:/mappers/*.xml"/>
<!-- Mybatis的配置文件的位置 -->
<property name="configLocation" value="classpath:mybatis-config.xml"/>
</bean>
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 扫描Mybatis需要动态代理的接口所在的包 -->
<property name="basePackage" value="com.softeem.dao"/>
</bean>
3. Spring-test整合Junit
3.1 引入依赖
<!-- 单元测试 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.0</version>
<scope>provided</scope>
</dependency>
3.2 测试用例编写
//@RunWith:Junit提供,代表指定以什么环境运行
//SpringJUnit4ClassRunner.class: Spring-test提供,代表Spring的环境
@RunWith(SpringJUnit4ClassRunner.class)
//@ContextConfiguration:Spring-test提供,用来定位Spring配置文件位置
@ContextConfiguration(locations = {"classpath:applicationContext.xml"})
@WebAppConfiguration //Spring-test提供的确定是web开发环境的路径资源(webapp)
public class StudentServiceImplTest {
@Autowired
private StudentService studentService;
@Test
public void queryById() {
Student student = studentService.queryById(1);
System.out.println(student);
}
}
4 . 分页插件
4.1 使用PageHelper
https://pagehelper.github.io/docs/howtouse/
4.1.1 依赖
<!-- 分页插件PageHelper -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.2.0</version>
</dependency>
4.1.2 配置
<!--
plugins在配置文件中的位置必须符合要求,否则会报错,顺序如下:
properties?, settings?,
typeAliases?, typeHandlers?,
objectFactory?,objectWrapperFactory?,
plugins?,
environments?, databaseIdProvider?, mappers?
-->
<plugins>
<!-- com.github.pagehelper为PageHelper类所在包名 -->
<plugin interceptor="com.github.pagehelper.PageInterceptor">
<!-- 使用下面的方式配置参数,后面会有所有的参数介绍 -->
<!-- 分页插件会自动检测当前的数据库链接,自动选择合适的分页方式。 你可以配置
helperDialect属性来指定分页插件使用哪种方言。配置时,可以使用下面的缩写值:
oracle,mysql,mariadb,sqlite,hsqldb,postgresql,db2,sqlserver,informix,h2,sqlserver2012,
derby
特别注意:使用 SqlServer2012 数据库时,需要手动指定为 sqlserver2012,否则会使用 SqlServer2005
的方式进行分页。
你也可以实现 AbstractHelperDialect,然后配置该属性为实现类的全限定名称即可使用自定义的实现方法。
-->
<property name="helperDialect" value="mysql"/>
<!--分页合理化参数,默认值为false。
当该参数设置为 true 时,pageNum<=0 时会查询第一页, pageNum>pages(超过总数时),
会查询最后一页。
默认false 时,直接根据参数进行查询。 -->
<property name="reasonable" value="true"/>
</plugin>
</plugins>
也可以在Spring配置文件中配置
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<!-- 映射文件的位置 -->
<property name="mapperLocations" value="classpath:/mappers/*.xml"/>
<!-- Mybatis的配置文件的位置 -->
<property name="configLocation" value="classpath:mybatis-config.xml"/>
<!-- 分页插件的配置也可以在Spring配置文件里面配置 -->
<property name="plugins">
<array>
<bean class="com.github.pagehelper.PageInterceptor">
<property name="properties">
<value>
params=value1
</value>
</property>
</bean>
</array>
</property>
</bean>
4.1.3 使用
/**
* 通过分页插件查询
*/
@Test
public void queryByPageInterceptor() {
/**
* 每页数据显示100条
* 查询第二页的数据
*/
PageHelper.startPage(2, 100);
Page<Student> studentList = (Page) studentDao.queryAll(null);
System.out.println(studentList.size());
System.out.println("总页数:"+studentList.getPages());
System.out.println("总局记录数:"+studentList.getTotal());
System.out.println("起始行号:"+studentList.getStartRow());
System.out.println("结束行号:"+studentList.getEndRow());
}
4.2 使用Mabatis-Plus(不仅仅是分页)
4.2.1. 引入依赖
<!-- mybatis-plus -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus</artifactId>
<version>3.3.2</version>
</dependency>
注意:mybatis-plus的包自带myabtis的包和mybatis-spring的包,所以为了避免jar包冲突,在使用
Mybatis-Plus的时候,一般把另外两个包去掉
4.2.2. 配置Mybatis-Plus的SqlSessionFactory
<!-- <bean id="sqlSessionFactory"
class="org.mybatis.spring.SqlSessionFactoryBean">-->
<bean id="sqlSessionFactory"
class="com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<!-- 映射文件的位置 -->
<property name="mapperLocations" value="classpath:/mappers/*.xml"/>
<!-- Mybatis的配置文件的位置 -->
<property name="configLocation" value="classpath:mybatis-config.xml"/>
</bean>
4.2.3. 常用注释
//@TableName 映射表
@TableName("student")
public class Student implements Serializable {
private static final long serialVersionUID = -69445972961557016L;
/**
* 主键
*/
//指定主键,并指定主键的生成策略
@TableId(type = IdType.AUTO)
//@TableField 映射字段
@TableField("id")
private Integer id;
/**
* 用户名
*/
@TableField("name")
private String name;
//将在表中不存在映射关系的属性排除在外
@TableField(exist = false)
private String meme;
4.2.4. 使用Mybatis-Plus封装条件查询
@Test
public void queryByIdWithMP() {
// Student student = studentDao.selectById(1);
//用来拼接条件的
QueryWrapper<Student> wrapper = new QueryWrapper<>();
wrapper.like("name", "丽热")
.select("name", "address");
// wrapper.select("name", "address");
List<Student> studentList = studentDao.selectList(wrapper);
for (Student student : studentList) {
System.out.println(student);
}
}
4.2.5. 分页+条件拼接
<plugins>
<plugin
interceptor="com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor">
</plugin>
</plugins>
/**
* <p>
* 查询:分页显示
* </p>
*
* @param page 分页对象,xml中可以从里面进行取值,传递参数 Page 即自动分页,必须放在第一
位(你可以继承Page实现自己的分页对象)
* @return 分页对象
*/
IPage<Student> selectPageVo(Page<Student> page, @Param(Constants.WRAPPER)
Wrapper<Student> wrapper);
<!--
* 获取自定义SQL 简化自定义XML复杂情况
* <p>使用方法</p>
* <p>`自定义sql` + ${ew.customSqlSegment}</p>
* <p>1.逻辑删除需要自己拼接条件 (之前自定义也同样)</p>
* <p>2.不支持wrapper中附带实体的情况 (wrapper自带实体会更麻烦)</p>
* <p>3.用法 ${ew.customSqlSegment} (不需要where标签包裹,切记!)</p>
* <p>4.ew是wrapper定义别名,可自行替换</p>
-->
<select id="selectPageVo" resultType="com.softeem.entity.Student">
SELECT * FROM student ${ew.customSqlSegment}
</select>
@Test
public void queryByPageWithMP() {
// Student student = studentDao.selectById(1);
//用来拼接条件的
QueryWrapper<Student> wrapper = new QueryWrapper<>();
wrapper.like("name", "热巴");
// .select("name", "address");
// wrapper.select("name", "address");
Page<Student> page = new Page<>(2,100);
IPage<Student> iPage = studentDao.selectPageVo(page,wrapper);
System.out.println("查询到的结果:"+iPage.getRecords());
System.out.println("总页数:"+iPage.getPages());
System.out.println("总记录数:"+iPage.getTotal());
System.out.println("***************");
}