(13)【MyBatis的启动流程与Spring boot配置】

一、Mybatis的启动流程

在这里插入图片描述

  1. 加载Mapper配置的映射文件或者注解相关sql内容
  2. 创建会话工厂,MyBatis通过读写配置文件中的数据源信息来构造会话工厂
  3. 创建会话,Mybatis通过会话工厂创建会话对象,会话对象是个接口,包含对数据库的增删改查方法
  4. 创建执行器,会话本身不能直接操作数据库,通过数据库执行器来帮它执行操作
  5. 封装Sql对象,执行器将代处理sql信息分到对象MappedStatement中,包括sql语句、输入输出、输出结果映射
  6. 操作数据库

二、Spring boot集成Mybatis

1.在项目pom文件引入Mybatis和数据库相关连接驱动 mysql
      <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.13</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>2.0.5</version>
        </dependency>
        
         <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
2.application.property配置
#mapper.xml 配置文件的路径
mybatis.mapper-locations=classpath:/mapper/*.xml
mybatis.type-aliases-package=com.linsq.ngf.entity
#数据库连接
spring.datasource.url=jdbc:mysql://localhost:3306/ngf?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&useSSL=true
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
3.启动类配置
@Spring BootApplication
@MapperScan("com.linsq.ngf")
public class Appliction{
  public static void main(String[] args){
     SpringApplication.run(Application.class,args);
  }
}
4.applicationContext

定义datasource

 <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
        <property name="driverClassName" value="${jdbc.driverClass}"/>
        <property name="url" value="${db1.url}"/>
        <property name="username" value="${db1.username}"/>
        <property name="password" value="${db1.password}"/>
 </bean>

定义SqlSessionFactory,关联MyBatis

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">
            <array>
                <value>classpath:META-INF/mapper/*.xml</value>
            </array>
        </property>
        
</bean>
5.测试(测试类无法自动获取上下文环境中的bean)

1.通过applicationcontext手动获取bean

public class PersonInfoServiceImplTest {
    @Test
    public void queryPersonList(){
        ApplicationContext context = new ClassPathXmlApplicationContext("classpath:META-INF/spring/applicationContext.xml");
        IPersonInfoDao personInfoDao = (IPersonInfoDao) context.getBean("IPersonInfoDao");
        //查询
        PersonInfoEntity personInfoEntity=personInfoDao.selectPersonInfobyId("0001322310");
        if(personInfoEntity !=null){
            System.out.println("PersonID:"+personInfoEntity.getPersonId()+",Name:"+personInfoEntity.getName());
        }
    }
}

2.改变测试类的运行环境实现自动注入bean

@RunWith(SpringRunner.class)
@SpringBootTest(classes = {AppStart.class})
public class PersonInfoServiceImplTest {
    @Autowired
    private IPersonInfoDao personInfoDao;

    @Test
    public void queryPersonList(){
        //查询
        PersonInfoEntity personInfoEntity=personInfoDao.selectPersonInfobyId("0001322310");
        if(personInfoEntity !=null){
            System.out.println("PersonID:"+personInfoEntity.getPersonId()+",Name:"+personInfoEntity.getName());
        }
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis是一个支持动态创建表的Java持久层框架,而Spring Boot是一个用于快速开发Java应用程序的框架。下面是一个简单的示例,展示了如何在Spring Boot项目中使用MyBatis来动态创建表。 首先,我们需要在pom.xml文件中添加MyBatis数据库驱动的依赖。可以根据自己使用的数据库类型进行相应的配置。 ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.2.0</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.21</version> </dependency> ``` 接下来,我们需要创建一个实体类来表示要创建的表及其字段。可以在该类上使用注解来指定表名和字段名。 ```java @Entity @Table(name = "my_table") // 表名 public class MyTable { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; // 省略getter和setter } ``` 然后,创建一个Mapper接口,用来定义与数据库交互的接口方法。可以使用@Mapper注解标记这个接口,让MyBatis扫描到它。 ```java @Mapper public interface MyTableMapper { @CreateTable // 自定义注解,用来标记动态创建表的方法 @Insert("CREATE TABLE my_table (id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(255))") void createTable(); } ``` 在启动类中,使用@MapperScan注解来扫描Mapper接口,并在创建数据库连接的配置文件中添加@EnableTransactionManagement注解,以支持事务。 ```java @SpringBootApplication @MapperScan("com.example.mapper") @EnableTransactionManagement public class MyApplication { public static void main(String[] args) { SpringApplication.run(MyApplication.class, args); } } ``` 最后,创建一个自定义注解@CreateTable,用来标记动态创建表的方法。 ```java @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface CreateTable { } ``` 在Mapper接口的实现类中,可以使用@Around注解拦截所有带有@CreateTable注解的方法,并在方法执行前、执行后执行相应的逻辑。在执行前,可以通过MyBatis的Mapper接口对象来动态创建表。 ```java @Aspect @Component public class CreateTableAspect { @Around("@annotation(com.example.annotation.CreateTable)") public Object createTable(ProceedingJoinPoint joinPoint) throws Throwable { // 获取Mapper接口对象 MyTableMapper mapper = (MyTableMapper) joinPoint.getTarget(); // 动态创建表 mapper.createTable(); // 执行原方法 return joinPoint.proceed(); } } ``` 以上是一个使用MyBatis动态创建表的简单示例。通过Spring Boot的整合,我们可以方便地在项目中使用MyBatis来动态创建表。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值