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)標簽,這樣他會被忽略
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://blog.csdn.net/u014519194/article/details/53786630