1. 程式人生 > 其它 >LeetCode 643. 子陣列最大平均數 I

LeetCode 643. 子陣列最大平均數 I

技術標籤:spring資料庫mybatisspringmysqlxml

前言

我們在學完mybatis有簡單的學習了spring現在我們要在spring中整合mybatis。
我們可以根據官方文件來進行學習官網
在這裡插入圖片描述
這裡我們使用合適的版本來進行測試。

測試一

首先需要進行導包這裡重點是匯入mybatis-spring,初次之外我們還需要帶入相依應的包 ,spring-jdbc導包是需要注意他的id是org.springframework

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>spring_sum</artifactId>
        <groupId>org.example</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>spring-mybatis</artifactId>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>


    <dependencies>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.47</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.6</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>5.3.3</version>
        </dependency>
<!--    需要匯入springjdbc-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.3.3</version>
        </dependency>

        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.9.6</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis-spring -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>2.0.6</version>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.16</version>
        </dependency>

    </dependencies>
</project>

現在寫一個實體類、一個介面、一個xml檔案

package aw.pojo;

import lombok.Data;

@Data
public class User {
    private int id;
    private String username;
    private String password;
}

package aw.mapper;

import aw.pojo.User;

import java.util.List;

public interface UserMapper {
    public List<User> selectUser();
}

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="aw.mapper.UserMapper">
    <select id="selectUser" resultType="user">
        select * from user;
    </select>

</mapper>

接下來是寫資原始檔

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!--    以上是頭部的宣告-->
        <typeAliases>
            <package name="aw.pojo"/>
        </typeAliases>
    <!--    環境-->
    <environments default="development">
        <environment id="development">
            <!--           事務管理者-->
            <transactionManager type="JDBC"/>
            <!--            資料庫連線池-->
            <dataSource type="POOLED">
                <!--                資料庫相關資訊-->
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=false&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>
    <!--    mappers 元素則包含了一組對映器(mapper),這些對映器的 XML 對映檔案包含了 SQL 程式碼和對映定義資訊。-->
    <mappers>
        <mapper resource="aw/mapper/UserMapper.xml"/>
    </mappers>
</configuration>

按照步驟我們就該寫他的測試類,如果是這樣那我們就沒在寫的必要了,現在我們不是使用這樣的xml檔案我們單獨寫一個。
標頭檔案使用spring的

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/aop
        https://www.springframework.org/schema/aop/spring-aop.xsd">

根據官方文件我們在這裡面寫SqlSsionFactory,我們之前倒是單獨寫一個工具類來實現,現在我們直接在<bean中實現,這裡需要注意他的路徑是org.mybatis.spring.SqlSessionFactoryBean。
我們需要通過屬性來繫結資料來源,我們還看到他屬性中還可以繫結一些mybatis的中屬性。

<!--    SqlSessionFactory -->
    <bean id="SqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
<!--        繫結mybatis中的配置檔案-->
        <property name="configLocation" value="classpath:mybatis-config.xml"/>
        <property name="mapperLocations" value="classpath:aw/mapper/*.xml"/>
    </bean>

我們這裡的資料來源是使用的jdbc,他可以是任意中

<!--    配置資料來源 他可以是任意一個我們這裡使用的是jdbc-->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=false&amp;useUnicode=true&amp;characterEncoding =UTF-8"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    </bean>

有了SqlSessionFactory我們就建立SqlSession但是這裡他的名字叫SqlSessionTemplate,切忌我們這裡真能使用構造方法給他進行傳遞SqlSessionFactory。

<!--    sqlsessionTemp-->
    <bean id="SqlSessionTemp" class="org.mybatis.spring.SqlSessionTemplate">
<!--        這裡只能使用構造方法  因為他沒有set方法-->
        <constructor-arg index="0" ref="SqlSessionFactory"/>
    </bean>

先在我們需要在寫一個實體類來來執行查詢,首先是我們需要設定一個SqlSessionTemplate。

package aw.mapper;

import aw.pojo.User;
import org.mybatis.spring.SqlSessionTemplate;

import java.util.List;

public class UserMapperImp implements UserMapper{

    private SqlSessionTemplate sqlSessionTemplate;

    public void setSqlSessionTemplate(SqlSessionTemplate sqlSessionTemplate) {
        this.sqlSessionTemplate = sqlSessionTemplate;
    }

    @Override
    public List<User> selectUser() {
        UserMapper mapper = sqlSessionTemplate.getMapper(UserMapper.class);
       return mapper.selectUser();
    }
}

寫完這個實體類我們需要把它註冊到spring中,同時給屬性進行一個賦值。

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/aop
        https://www.springframework.org/schema/aop/spring-aop.xsd">

<!--    配置資料來源 他可以是任意一個我們這裡使用的是jdbc-->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=false&amp;useUnicode=true&amp;characterEncoding =UTF-8"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    </bean>

<!--    SqlSessionFactory -->
    <bean id="SqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
<!--        繫結mybatis中的配置檔案-->
        <property name="configLocation" value="classpath:mybatis-config.xml"/>
        <property name="mapperLocations" value="classpath:aw/mapper/*.xml"/>
    </bean>

<!--    sqlsessionTemp-->
    <bean id="SqlSessionTemp" class="org.mybatis.spring.SqlSessionTemplate">
<!--        這裡只能使用構造方法  因為他沒有set方法-->
        <constructor-arg index="0" ref="SqlSessionFactory"/>
    </bean>

    <bean id="UserMapperImp" class="aw.mapper.UserMapperImp">
        <property name="sqlSessionTemplate" ref="SqlSessionTemp"/>
    </bean>

</beans>

測試類,現在我們的測試類直接獲取實體類的bean就可以了。

 public static void main(String[] args) {
        ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("spring-mybatis.xml");
        UserMapper userMapperImp = (UserMapper) applicationContext.getBean("UserMapperImp");

        for (User user : userMapperImp.selectUser()) {
            System.out.println(user);
        }
    }

方法二

我們的那個實體類給他繼承一個夫類SqlSessionDaoSupport,這個父類幫我們建立了SqlSessionTemplate,所以我們就直接獲取getSession。

package aw.mapper;

import aw.pojo.User;
import org.mybatis.spring.support.SqlSessionDaoSupport;

import java.util.List;

public class UserMapperImp2 extends SqlSessionDaoSupport implements UserMapper{
    @Override
    public List<User> selectUser() {

        return getSqlSession().getMapper(UserMapper.class).selectUser();
    }
}

我們需要在屬性中給他的父類傳遞一個SqlSessionFactory

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/aop
        https://www.springframework.org/schema/aop/spring-aop.xsd">

<!--    配置資料來源 他可以是任意一個我們這裡使用的是jdbc-->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=false&amp;useUnicode=true&amp;characterEncoding =UTF-8"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    </bean>

<!--    SqlSessionFactory -->
    <bean id="SqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
<!--        繫結mybatis中的配置檔案-->
        <property name="configLocation" value="classpath:mybatis-config.xml"/>
        <property name="mapperLocations" value="classpath:aw/mapper/*.xml"/>
    </bean>
<!--    我們這裡需要給他的父類進行傳遞一個引數-->
    <bean id="UserMapperImp2" class="aw.mapper.UserMapperImp2">
        <property name="sqlSessionFactory" ref="SqlSessionFactory"/>
    </bean>
</beans>