详解Spring boot上配置与使用mybatis plus

2025-05-29 0 56

http://mp.baomidou.com/#/?id=%e7%ae%80%e4%bb%8b这个是mybatisplus的官方文档,上面是mybtisplus的配置使用方法,以及一些功能的介绍

下面开始配置

maven依赖

?

1

2

3

4

5

6

7

8

9

10
<dependency>

<groupId>org.mybatis.spring.boot</groupId>

<artifactId>mybatis-spring-boot-starter</artifactId>

<version>1.1.1</version>

</dependency>

<dependency>

<groupId>com.baomidou</groupId>

<artifactId>mybatis-plus</artifactId>

<version>2.0-beta</version>

</dependency>

config文件

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61
@Configuration

public class MybatisPlusConfig {

@Autowired

private DataSource dataSource;

@Autowired

private MybatisProperties properties;

@Autowired

private ResourceLoader resourceLoader = new DefaultResourceLoader();

@Autowired(required = false)

private Interceptor[] interceptors;

@Autowired(required = false)

private DatabaseIdProvider databaseIdProvider;

/**

* mybatis-plus分页插件

*/

@Bean

public PaginationInterceptor paginationInterceptor() {

PaginationInterceptor page = new PaginationInterceptor();

page.setDialectType("mysql");

return page;

}

/**

* 这里全部使用mybatis-autoconfigure 已经自动加载的资源。不手动指定

* 配置文件和mybatis-boot的配置文件同步

* @return

*/

@Bean

public MybatisSqlSessionFactoryBean mybatisSqlSessionFactoryBean() {

MybatisSqlSessionFactoryBean mybatisPlus = new MybatisSqlSessionFactoryBean();

mybatisPlus.setDataSource(dataSource);

mybatisPlus.setVfs(SpringBootVFS.class);

if (StringUtils.hasText(this.properties.getConfigLocation())) {

mybatisPlus.setConfigLocation(this.resourceLoader.getResource(this.properties.getConfigLocation()));

}

mybatisPlus.setConfiguration(properties.getConfiguration());

if (!ObjectUtils.isEmpty(this.interceptors)) {

mybatisPlus.setPlugins(this.interceptors);

}

MybatisConfiguration mc = new MybatisConfiguration();

mc.setDefaultScriptingLanguage(MybatisXMLLanguageDriver.class);

mybatisPlus.setConfiguration(mc);

if (this.databaseIdProvider != null) {

mybatisPlus.setDatabaseIdProvider(this.databaseIdProvider);

}

if (StringUtils.hasLength(this.properties.getTypeAliasesPackage())) {

mybatisPlus.setTypeAliasesPackage(this.properties.getTypeAliasesPackage());

}

if (StringUtils.hasLength(this.properties.getTypeHandlersPackage())) {

mybatisPlus.setTypeHandlersPackage(this.properties.getTypeHandlersPackage());

}

if (!ObjectUtils.isEmpty(this.properties.resolveMapperLocations())) {

mybatisPlus.setMapperLocations(this.properties.resolveMapperLocations());

}

return mybatisPlus;

}

}

插件以@bean的形式添加在config文件里例如:

?

1

2

3

4

5

6
@Bean

public PaginationInterceptor paginationInterceptor() {

PaginationInterceptor page = new PaginationInterceptor();

page.setDialectType("mysql");

return page;

}

这是一个分页插件。

代码生成器参考官方文档,但是他的代码生成器可供修改的地方不多,只能控制一下代码生成路径之类的,自由度不高,推荐把mybatisplus 代码生成部分单独抽出来,修改成自己合适的,再打成jar包进行依赖。

springboot properties文件配置

?

1

2

3
# mybatis_config

mybatis.mapper-locations=classpath:com/boot/mapper/xml/*Mapper.xml

mybatis.typeAliasesPackage=com.boot.entity

前一个是xml文件的路径

后面一个时别名包路径

在springboot的启动类上加上注解

?

1

2

3
@MapperScan("com.boot.mapper*")

@SpringBootApplication

public class BootApplication {

@mapperscan 里面是dao的扫描路径

mybatisplus 提供了比较齐全的crud即增删改查,不需要在mapper.xml里写sql可以直接调用
例子:

?

1

2

3

4

5

6

7

8
//可以在controller:

Egg egg = new Egg();

eggService.insert(egg);

//可以在service

Egg egg = new Egg();

this.selectList(new EntityWrapper<Egg >(egg));//mybatisplus提供依靠实体查询的方法的写法

//也可以

mapper.selectList(new EntityWrapper<Egg >(egg));

分页查询demo:

dao:返回list

复制代码 代码如下:


List<Role> getPage(Pagination page, RoleParam param) throws DataAccessException;

xml:照着普通sql写就可以了,其他的会自动拼接

?

1

2

3

4

5

6
<select id="getPage" resultMap="RoleResultMap">

select

<include refid="columns"/>

from ella_role

<include refid="where"/>

</select>

service:

?

1

2

3

4

5

6
public Page<EllaRole> getPage(RoleParam param) {

//new 一个page 初始化传入current当前页,size每页几个,order 排序(默认asc要改的话page.setAsc(false);)

Page<Role> page = new Page<Role>(param.getCurrent(), param.getSize(), param.getOrder());

page.setRecords(iRoleMapper.getPage(page, param));

return page;

}

end

接下来是一些小贴士

生成的实体里主键要加上@TableId注解不然会报错

数据库里有下划线的字段在查询返回是会取不到值,需要在config文件中的mybatisSqlSessionFactoryBean方法下加上

?

1
mybatisPlus.setDbColumnUnderline(true);

domain里的所有属性都会映射到数据库的字段上,如果你加上数据库里没有但要用的属性需要在上面加上@TableField(exist = false)标签,这样他会被忽略

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。

原文链接:http://blog.csdn.net/u014519194/article/details/53786630

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 详解Spring boot上配置与使用mybatis plus https://www.kuaiidc.com/116483.html

相关文章

发表评论
暂无评论