springboot(8)springboot整合mybatis

一、使用starter, maven倉庫地址:http://mvnrepository.com/artifact/org.mybatis.spring.boot/mybatis-spring-boot-starterhtml

二、加入依賴(能夠用 http://start.spring.io/ 下載)

<!-- 引入starter-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
<scope>runtime</scope>
</dependency>

<!-- MySQL的JDBC驅動包 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!-- 引入第三方數據源 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.6</version>
</dependency>java

三、加入配置文件
#mybatis.type-aliases-package=net.xdclass.base_project.domain
#能夠自動識別
#spring.datasource.driver-class-name =com.mysql.jdbc.Drivermysql

spring.datasource.url=jdbc:mysql://localhost:3306/movie?useUnicode=true&characterEncoding=utf-8
spring.datasource.username =root
spring.datasource.password =password
#若是不使用默認的數據源 (com.zaxxer.hikari.HikariDataSource)
spring.datasource.type =com.alibaba.druid.pool.DruidDataSourcegit

加載配置,注入到sqlSessionFactory等都是springBoot幫咱們完成github

四、啓動類增長mapper掃描
@MapperScan("net.xdclass.base_project.mapper")spring

技巧:保存對象,獲取數據庫自增id
@Options(useGeneratedKeys=true, keyProperty="id", keyColumn="id")sql

四、開發mapper
參考語法 http://www.mybatis.org/mybatis-3/zh/java-api.html數據庫

五、sql腳本
CREATE TABLE `user` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(128) DEFAULT NULL COMMENT '名稱',
`phone` varchar(16) DEFAULT NULL COMMENT '用戶手機號',
`create_time` datetime DEFAULT NULL COMMENT '建立時間',
`age` int(4) DEFAULT NULL COMMENT '年齡',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=18 DEFAULT CHARSET=utf8;api


相關資料:
http://www.mybatis.org/spring-boot-starter/mybatis-spring-boot-autoconfigure/#Configurationmybatis

https://github.com/mybatis/spring-boot-starter/tree/master/mybatis-spring-boot-samples

整合問題集合:
https://my.oschina.net/hxflar1314520/blog/1800035
https://blog.csdn.net/tingxuetage/article/details/80179772

講解場景的隔離級別
Serializable: 最嚴格,串行處理,消耗資源大
Repeatable Read:保證了一個事務不會修改已經由另外一個事務讀取但未提交(回滾)的數據
Read Committed:大多數主流數據庫的默認事務等級
Read Uncommitted:保證了讀取過程當中不會讀取到非法數據。


講解常見的傳播行爲
PROPAGATION_REQUIRED--支持當前事務,若是當前沒有事務,就新建一個事務,最多見的選擇。

PROPAGATION_SUPPORTS--支持當前事務,若是當前沒有事務,就以非事務方式執行。

PROPAGATION_MANDATORY--支持當前事務,若是當前沒有事務,就拋出異常。

PROPAGATION_REQUIRES_NEW--新建事務,若是當前存在事務,把當前事務掛起, 兩個事務之間沒有關係,一個異常,一個提交,不會同時回滾

PROPAGATION_NOT_SUPPORTED--以非事務方式執行操做,若是當前存在事務,就把當前事務掛起。

PROPAGATION_NEVER--以非事務方式執行,若是當前存在事務,則拋出異常

相關文章
相關標籤/搜索