Spring Data MyBatis Processor

Spring Data module for MyBatis repositories.

License

License

Categories

Categories

Data MyBatis ORM
GroupId

GroupId

io.easybest
ArtifactId

ArtifactId

spring-data-mybatis-processor
Last Version

Last Version

2.0.1.RELEASE
Release Date

Release Date

Type

Type

jar
Description

Description

Spring Data MyBatis Processor
Spring Data module for MyBatis repositories.
Project URL

Project URL

https://github.com/easybest/spring-data-mybatis
Project Organization

Project Organization

EasyBest
Source Code Management

Source Code Management

https://github.com/easybest/spring-data-mybatis

Download spring-data-mybatis-processor

How to add to project

<!-- https://jarcasting.com/artifacts/io.easybest/spring-data-mybatis-processor/ -->
<dependency>
    <groupId>io.easybest</groupId>
    <artifactId>spring-data-mybatis-processor</artifactId>
    <version>2.0.1.RELEASE</version>
</dependency>
// https://jarcasting.com/artifacts/io.easybest/spring-data-mybatis-processor/
implementation 'io.easybest:spring-data-mybatis-processor:2.0.1.RELEASE'
// https://jarcasting.com/artifacts/io.easybest/spring-data-mybatis-processor/
implementation ("io.easybest:spring-data-mybatis-processor:2.0.1.RELEASE")
'io.easybest:spring-data-mybatis-processor:jar:2.0.1.RELEASE'
<dependency org="io.easybest" name="spring-data-mybatis-processor" rev="2.0.1.RELEASE">
  <artifact name="spring-data-mybatis-processor" type="jar" />
</dependency>
@Grapes(
@Grab(group='io.easybest', module='spring-data-mybatis-processor', version='2.0.1.RELEASE')
)
libraryDependencies += "io.easybest" % "spring-data-mybatis-processor" % "2.0.1.RELEASE"
[io.easybest/spring-data-mybatis-processor "2.0.1.RELEASE"]

Dependencies

compile (5)

Group / Artifact Type Version
io.easybest : spring-data-mybatis-core jar 2.0.1.RELEASE
org.springframework.data : spring-data-commons jar 2.3.3.RELEASE
com.samskivert : jmustache jar 1.15
org.slf4j : slf4j-api jar 1.7.26
org.projectlombok : lombok Optional jar 1.18.12

Project Modules

There are no modules declared in this project.

Spring Data MyBatis

Build Status Gitter chat Maven Central License: Apache 2.0

Simplified Chinese

Documentation

Example Project

The primary goal of the Spring Data project is to make it easier to build Spring-powered applications that use data access technologies. This module deals with enhanced support for MyBatis based data access layers.

Features

  • Implementation of CRUD methods for normal Entities
  • Dynamic query generation from query method names
  • Implementation domain base classes providing basic properties
  • Support for transparent auditing (created, last changed)
  • Possibility to integrate custom repository code
  • Easy Spring integration with custom namespace
  • Support MySQL, Oracle, Sql Server, H2, PostgreSQL, etc.
  • Support SpringBoot 2.x

Getting Help

If you have any question, please record a issue to me.

Quick Start

Download the jar through Maven:

<dependency>
  <groupId>io.easybest</groupId>
  <artifactId>spring-data-mybatis</artifactId>
  <version>2.0.1.RELEASE</version>
</dependency>

The simple Spring Data Mybatis configuration with Java-Config looks like this:

@Configuration
@EnableMybatisRepositories(
        value = "org.springframework.data.mybatis.repository.sample",
        mapperLocations = "classpath*:/org/springframework/data/mybatis/repository/sample/mappers/*Mapper.xml"
)
public class TestConfig {

    @Bean
    public DataSource dataSource() throws SQLException {
        return new EmbeddedDatabaseBuilder().setType(EmbeddedDatabaseType.H2).addScript("classpath:/test-init.sql").build();
    }

    @Bean
    public SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource) {
        SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();
        factoryBean.setDataSource(dataSource);
        return factoryBean;
    }

    @Bean
    public PlatformTransactionManager transactionManager(DataSource dataSource) {
        return new DataSourceTransactionManager(dataSource);
    }

}

Create an entity:

@Entity
@Table(name = "user")
public class User extends LongId {

  
  @Condition
  private String firstname;
  @Condition(type=Condition.Type.CONTAINING)  private String lastname;
  private String fullName;
  @Conditions({@Condition, @Condition(type=Condition.Type.CONTAINING,properties = "fuzzyName")})
  private String fullName;
  @Transient
  private String fuzzyName;
  @Column(name = "usertype")
  private String status;
  // Getters and setters
  // (Firstname, Lastname)-constructor and noargs-constructor
  // equals / hashcode
}

When using findAll method of MybatisRepository the @Condition or @Conditions annotations will work

Create a repository interface in com.example.repositories:

public interface UserRepository extends MybatisRepository<User, Long> {
  List<User> findByLastname(String lastname);  
  
  @Query("select firstname from user")
  List<String> findUsersFirstName();
  
}

Write a test client:

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = AppConfig.class)
public class UserRepositoryIntegrationTest {
     
  @Autowired UserRepository repository;
     
  @Test
  public void sampleTestCase() {
    User dave = new User("Dave", "Matthews");
    dave = repository.save(dave);
         
    User carter = new User("Carter", "Beauford");
    carter = repository.save(carter);
         
    List<User> result = repository.findByLastname("Matthews");
    assertThat(result.size(), is(1));
    assertThat(result, hasItem(dave));
  }
}

Use Spring Boot

add the jar through Maven:

<dependency>
    <groupId>io.easybest</groupId>
    <artifactId>spring-data-mybatis-boot-starter</artifactId>
    <version>2.0.1.RELEASE</version>
</dependency>

If you need custom Mapper, you should add property in your application.yml like this:

mybatis:
  mapper-locations: "classpath*:/mapper/**/**Mapper.xml"

And you need not to define SqlSessionFactory manually.

The full test code like this:

@SpringBootApplication
public class SpringDataMybatisSamplesApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringDataMybatisSamplesApplication.class, args);
    }

    @Bean
    public CommandLineRunner dummyCLR(ReservationRepository reservationRepository) {
        return args -> {
            Stream.of("Tom", "Jack", "Apple")
                    .forEach(name -> reservationRepository.save(new Reservation(name)));
        };
    }

}

@RepositoryRestResource // here we use RepositoryRestResource
interface ReservationRepository extends MybatisRepository<Reservation, Long> {
}

@Entity
@Table(name = "user")
class Reservation extends LongId {

    private String reservationName;

    public Reservation() {
    }

    public Reservation(String reservationName) {
        this.reservationName = reservationName;
    }

    public String getReservationName() {
        return reservationName;
    }

    @Override
    public String toString() {
        return "Reservation{" +
                "reservationName='" + reservationName + '\'' +
                '}';
    }
}

The full example you can find in https://github.com/easybest/spring-data-mybatis-samples

Contributing to Spring Data MyBatis

Here are some ways for you to get involved in the community:

  • Github is for social coding: if you want to write code, we encourage contributions through pull requests from forks of this repository.

Help me better - Donation

paypal

Versions

Version
2.0.1.RELEASE