美文网首页java面试
第4章Spring集成MyBatis

第4章Spring集成MyBatis

作者: 努力学习的lfk | 来源:发表于2021-08-23 08:47 被阅读0次

第4章Spring集成MyBatis

使用的技术是ioc
为什么ioc能把mybatis和spring集成在一起,像一个框架?->ioc能创建对象,可以把mybatis框架中的对象交给spring统一创建,开发人员从spring获取对象。

mybatis使用步骤:
1.定义dao接口,StudentDao
2.定义mapper文件 StudentDao.xml
3.定义mybatis主配置文件 mybatis.xml
4.创建dao的dialing对象,
StudentDao dao =SqlSession.getMapper(StudentDao.class);
List<Student> students = dao.selectStudents();

要使用dao对象,需要使用getMapper()方法,使用getMapper方法需:
1.获取SqlSession对象,需要使用SqlSessionFactory的openSession()方法。
2.创建SqlSessionFactory对象。通过读取mybatis的主配置文件,能创建SqlSessionFactory对象。

用SqlSessionFactory对象使用Factory能获取SqlSession,有了SqlSession就能有dao,目的就是获取dao对象,Factory创建需要读取主配置文件。

主配置文件:
1.数据库信息(我们会使用独立的连接池类替换mybatis默认自带的,把连接池类也交给spring创建)

    <!--环境配置:数据库的连接信息
        default:必须和某个environments的id值一致,
        告诉mybatis使用哪个数据库的连接信息。即访问哪个数据库
    -->
    <environments default="DbMybatis">
        <!--environment:一个数据库信息的配置
            id:一个唯一值,自定义,表示环境的名称
        -->
        <environment id="DbMybatis">
            <!--transactionManager:mybatis的事务类型
                type:
                    1)JDBC:表示使用jdbc中的Connection对象的commit,rollback做事务处理:
                    2)MANAGED:表示把mybatis的事务处理委托给其他容器(可以是服务器软件、框架(spring))
            -->
            <transactionManager type="JDBC"/>
            <!--dataSource:表示数据源,连接数据库的
                type表示数据源的类型
                    1)POOLED表示使用连接池,mybatis会创建PooledDataSource类
                    2)UPOOLED表示不使用连接池,每次执行sql语句,先创建连接,执行sql,再关闭连接。
                                mybatis会创建一个UnPooledDataSource,管理Connection对象的使用
                    3)JNDI:java命名和目录服务(widows的注册表)
            -->
            <dataSource type="POOLED">
                <!--
                    driver、url、username、password是固定的不能自定义
                -->
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>
    </environments>

2.mapper文件的位置

    <!--sql mapper(sql映射文件)的位置-->
    <mappers>
        <!--一个mapper标签指定一个sql映射文件的位置
            从类路径开始的路径信息。 target/class(class后面开始的就是类路径)
        -->
        <!--第一种方式:指定多个mapper文件-->
        <mapper resource="com\bjpowernode\dao\StudentDao.xml"/>
        <mapper resource="com\bjpowernode\dao\OrderDao.xml"/>
        <!--第二种方式:使用包名,name=mapper文件所在的包名。(这个包所有xml文件一次性加载给mybatis)-->
        <!--mapper文件名称需和接口名称一样,区分大小写
        mapper文件和dao接口在同一目录-->
        <!--<package name="com.bjpowernode.dao"/>-->
    </mappers>

通过以上的说明,我们需要让spring创建以下对象:
1.独立的连接池类的对象,使用阿里的druid连接池
2.SqlSessionFactory对象
3.创建出dao对象

故需学习以上三个对象的创建语法,使用xml的bean标签(没有源代码无法使用注解)。

ch07-spring-mybatis:spring和mybatis的集成
步骤:
1.新建maven项目
2.加入maven的依赖
1)spring依赖
2)mybatis依赖
3)mysql驱动
4)spring的事务的依赖
5)mybatis和spring集成的依赖(mybatis官方提供的,用来在spring项目中创建mybatis对象的)
3.创建实体类
4.创建dao接口和mapper文件
5.创建mybatis主配置文件
6.创建Service接口和实现类,属性是dao
7.创建spring的配置文件:声明mybatis的对象交给spring创建
1)数据源
2)SqlSessionFactory
3)Dao对象
4)声明自定义的service
8.创建测试类,获取Service对象,通过service调用dao完成数据库的访问

2.加入maven的依赖

  <!--jdk属性信息-->
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
  </properties>

  <dependencies>

    <!--单元测试-->
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>

    <!--spring依赖-核心ioc-->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-context</artifactId>
      <version>5.2.5.RELEASE</version>
    </dependency>

    <!--spring事务-->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-tx</artifactId>
      <version>5.2.5.RELEASE</version>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-jdbc</artifactId>
      <version>5.2.5.RELEASE</version>
    </dependency>

    <!--mybatis依赖-->
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.5.1</version>
    </dependency>

    <!--mybatis和spring集成的依赖-->
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis-spring</artifactId>
      <version>1.3.1</version>
    </dependency>

    <!--mysql驱动-->
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>8.0.23</version>
    </dependency>

    <!--阿里公司的数据库连接池-->
    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>druid</artifactId>
      <version>1.1.12</version>
    </dependency>

  </dependencies>


  <build>

    <!--加入maven插件,编译时扫描src/main/java目录中的xml文件-->
    <resources>
      <resource>
        <directory>src/main/java</directory><!--所在的目录-->
        <includes><!--包括目录下的.properties、xml文件都会扫描到-->
          <include>**/*.properties</include>
          <include>**/*.xml</include>
        </includes>
        <filtering>false</filtering>
      </resource>
    </resources>

    <!--指定jdk的版本-->
    <plugins>
      <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.1</version>
        <configuration>
          <source>1.8</source>
          <target>1.8</target>
        </configuration>
      </plugin>
    </plugins>

  </build>

3.创建实体类

public class Student {
    //属性名和列名一样
    private Integer id;
    private String name;
    private String email;
    private Integer age;

    创建无参构造、有参构造、get和set方法、toString方法
}

4.创建dao接口和mapper文件

//dao接口
public interface StudentDao {
    int insertStudent(Student student);
    List<Student>selectStudents();
}
//mapper文件
<!--唯一值的,可以自定义,但要求:使用dao接口的全限定名称。(包括包名、类名)-->
<mapper namespace="com.bjpowernode.dao.StudentDao">
    
    <insert id="insertStudent">
        insert into student values (#{id},#{name},#{email},#{age})
    </insert>

    <!--id:接口的方法,resultType该方法的数据类型-->
    <select id="selectStudents" resultType="com.bjpowernode.domain.Student">
        select id,name,email,age from student order by id desc
    </select>
</mapper>

5.创建mybatis主配置文件

<!--根标签-->
<configuration>
    <!--settings:控制mybatis全局行为的-->
    <settings>
        <!--设置mybatis输出日志-->
        <setting name="logImpl" value="STDOUT_LOGGING"/>
    </settings>

    <!--设置别名-->
    <typeAliases>
        <!--name:实体类所在的包名-->
        <package name="com.bjpowernode.domain"/>
    </typeAliases>

    <!--sql mapper(sql映射文件)的位置-->
    <mappers>
        <!--name:包名,这个包中的所有mapper.xml一次都能加载-->
        <package name="com.bjpowernode.dao"/>
    </mappers> 
</configuration>

6.创建Service接口和实现类,属性是dao

//Service接口
public interface StudentService {
    int addStudent(Student student);
    List<Student> queryStudents();
}
//实现类
public class StudentServiceImpl implements StudentService {

    //引用类型
    private StudentDao studentDao;
    //使用set注入,赋值
    public void setStudentDao(StudentDao studentDao) {
        this.studentDao = studentDao;
    }

    @Override
    public int addStudent(Student student) {
        //代表已添加的行数
        int num=studentDao.insertStudent(student);
        return num;
    }

    @Override
    public List<Student> queryStudents() {
        List<Student>students=studentDao.selectStudents();
        return students;
    }
}

7.创建spring的配置文件:声明mybatis的对象交给spring创建
1)数据源

//先在resources目录下新建spring的配置文件
    <!--声明数据源DataSource,作用是连接数据库的-->
    <bean id="myDataSource" class="com.alibaba.druid.pool.DruidDataSource"
          init-method="init" destroy-method="close">
      <!--set注入给DruidDataSource体哦那个连接数据库信息-->
      <property name="url" value="jdbc:mysql://localhost:3306/ssm" />
      <property name="username" value="root" />
      <property name="password" value="abc1234." />
    </bean>

2)SqlSessionFactory

    <!--声明mybatis中所提供能SqlSessionFactoryBean类,
    这个类的内部是创建SqlSessionFactory的-->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!--set注入,把数据库的连接池赋给dataSource属性-->
        <property name="dataSource" ref="myDataSource"/>
        <!--value:mybatis主配置文件的位置
            configLocation是Resource类型的
        -->
        <property name="configLocation" value="classpath:mybatis.xml"/>
    </bean>

3)Dao对象(默认创建名称:接口名首字母小写)

    <!--创建dao对象,使用SqlSession的getMapper(StudentDao.class)
        MapperScannerConfigurer:在内部调用getMapper()生成每个dao接口的代理对象
    -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!--指定SqlSessionFactory对象id-->
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
        <!--指定包名,包名是dao接口所在的包名
            MapperScannerConfigurer会扫描这个包中的所有接口,
            把每个接口都执行一次getMapper()方法,得到每个接口的dao对象。
            创建好的dao对象放入到spring的容器中。-->
        <property name="basePackage" value="com.bjpowernode.dao"/>
    </bean>

4)声明自定义的service

    <!--声明service-->
    <bean id="studentService" class="com.bjpowernode.service.impl.StudentServiceImpl">
        <!--在上一步中创建了dao对象,且默认创建的名称是接口首字母小写(studentDao对象出处)-->
        <property name="studentDao" ref="studentDao"/>
    </bean>

8.创建测试类,获取Service对象,通过service调用dao完成数据库的访问

@Test
    public void testServiceInsert(){
        String config="applicationContext.xml";
        ApplicationContext ctx=new ClassPathXmlApplicationContext(config);

        //获取spring容器中的dao对象
        StudentService studentService= (StudentService) ctx.getBean("studentService");

        Student student = new Student();
        student.setId(1006);
        student.setName("浪里白条");
        student.setEmail("400820020@qq.com");
        student.setAge(57);

        int num=studentService.addStudent(student);
        System.out.println("成功添加"+num+"条数据");
    }

9.使用属性配置文件(.properties文件)

//jdbc.properties文件
jdbc.url=jdbc:mysql://localhost:3306/ssm
jdbc.username =root
jdbc.password=abc1234.
jdbc.maxActive=20
//spring配置文件(applicationContext.xml)
    <!--
        把数据库的配置信息,写在一个独立的文件,编译修改数据库的配置内容
        spring知道jdbc.properties文件的位置。
    -->
    <context:property-placeholder location="classpath:jdbc.properties"/>

<bean ......>
......
<!--
   使用属性配置文件中的数据,语法:${key}
-->
   <property name="url" value="${jdbc.url}" />
   <property name="username" value="${jdbc.username}" />
   <property name="password" value="${jdbc.password}" />
   <property name="maxActive" value="${jdbc.maxActive}"/>
</bean>

笔记来源:B站动力节点 spring学习视频

视频链接:https://www.bilibili.com/video/BV1nz4y1d7uy

相关文章

网友评论

    本文标题:第4章Spring集成MyBatis

    本文链接:https://www.haomeiwen.com/subject/dbzepltx.html