SSM整合

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("***************");
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值