首頁 >Java >java教程 >如何使用Java Fluent Mybatis驗證對資料庫的操作

如何使用Java Fluent Mybatis驗證對資料庫的操作

PHPz
PHPz轉載
2023-04-22 18:43:171404瀏覽

依賴補充

依照官方給予的程式碼依賴是不夠的,這裡需要對maven的pom檔進行補充。

<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>
            <scope>runtime</scope>
        </dependency>

資料庫檔案配置

這裡我們還是使用mysql作為測試資料庫,fm(fluent mybatis的簡稱)可以支援很多種資料庫,暫時我們不考慮其他的資料庫。

在application.properties檔案中加入mysql資料庫配置,至於druid連線池的使用後面的篇章用到再說。也可以用application.yml,這個隨意。

spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.url=jdbc:mysql://192.168.0.108:3306/test?useSSL=false&useUnicode=true&characterEncoding=utf-8
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

測試程式碼

再測試套件中加入測試程式碼,主要是做一個簡單的插入資料測試。

程式碼如下:

package com.hy.fmp.test;
 
import com.hy.fmp.Application;
import com.hy.fmp.fluent.entity.TestFluentMybatisEntity;
import com.hy.fmp.fluent.mapper.TestFluentMybatisMapper;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
 
import java.util.Date;
 
@SpringBootTest(classes = Application.class)
public class InsertTest {
  @Autowired TestFluentMybatisMapper testFluentMybatisMapper;
 
  @Test
  public void testInsertDefaultValue() {
    // 插入数据
    testFluentMybatisMapper.insert(
        new TestFluentMybatisEntity()
            .setAge(18)
            .setName("法外狂徒张三")
            .setCreateTime(new Date())
            .setDelFlag(0));
  }
}

說明:

1、注意TestFluentMybatisMapper是target套件內的mapper類別。

2、表實體TestFluentMybatisEntity可以透過鍊式的程式碼寫法。

@Accessors(
    chain = true
)

增加掃描mapper註解

掃描的mapper也是target套件內的mapper目錄

@SpringBootApplication
@MapperScan({"com.hy.fmp.fluent.mapper"})
public class Application {
 
  public static void main(String[] args) {
    SpringApplication.run(Application.class, args);
  }
}

Java Fluent Mybatis如何验证代码操作数据库情况

執行測試程式碼

下面我們測試一下插入程式碼

Java Fluent Mybatis如何验证代码操作数据库情况

發現這裡報了個異常,調整程式碼

Java Fluent Mybatis如何验证代码操作数据库情况

發現這裡報了個異常,調整程式碼,增加設定類別。

Java Fluent Mybatis如何验证代码操作数据库情况程式碼如下,增加MapperFactory注入。

package com.hy.fmp.config;
 
import cn.org.atool.fluent.mybatis.spring.MapperFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
 
@Configuration
public class ApplicationConfig {
 
  //  @Bean("dataSource")
  //  public DruidDataSource newDataSource() {
  //    return DataSourceCreator.create("datasource");
  //  }
  //
  //  @Bean
  //  public SqlSessionFactoryBean sqlSessionFactoryBean() throws Exception {
  //    SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
  //    bean.setDataSource(newDataSource());
  //    ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
  //    // 以下部分根据自己的实际情况配置
  //    // 如果有mybatis原生文件, 请在这里加载
  //    bean.setMapperLocations(resolver.getResources("classpath*:mapper/*.xml"));
  //    /* bean.setMapperLocations(
  //    /*      new ClassPathResource("mapper/xml1.xml"),
  //    /*      new ClassPathResource("mapper/xml2.xml")
  //    /* );
  //    */
  //    org.apache.ibatis.session.Configuration configuration =
  //        new org.apache.ibatis.session.Configuration();
  //    configuration.setLazyLoadingEnabled(true);
  //    configuration.setMapUnderscoreToCamelCase(true);
  //    bean.setConfiguration(configuration);
  //    return bean;
  //  }
 
  // 定义fluent mybatis的MapperFactory
  @Bean
  public MapperFactory mapperFactory() {
    return new MapperFactory();
  }
}

重新執行看看效果。

Java Fluent Mybatis如何验证代码操作数据库情况

###執行成功,看看表裡的資料。 ok,完美。 ############

以上是如何使用Java Fluent Mybatis驗證對資料庫的操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除