目录
使用MyBatis框架操作数据, 在SpringBoot框架集成MyBatis
使用步骤:
mybatis起步依赖 : 完成mybatis对象自动配置, 对象放在容器中
pom.xml 指定把src/main/java目录中的xml文件包含到classpath中
创建实体类Student
创建Dao接口 StudentDao , 创建一个查询学生的方法
创建Dao接口对应的Mapper文件, xml文件, 写sql语句
创建Service层对象, 创建StudentService接口和他的实现类。 去dao对象的方法。完成数据库的操作
创建Controller对象,访问Service。
写application.properties文件
配置数据库的连接信息。
创建业务层对象配置文件 连接数据库
@Mapper:放在dao接口的上面, 每个接口都需要使用这个注解。
- /**
- * @Mapper:告诉MyBatis这是dao接口,创建此接口的代理对象。
- * 位置:在类的上面
- */
- @Mapper
- public interface StudentDao {
-
- Student selectById(@Param("stuId") Integer id);
- }
- /**
- * @MapperScan: 找到Dao接口和Mapper文件
- * basePackages:Dao接口所在的包名
- */
- @SpringBootApplication
- @MapperScan(basePackages = {"com.bjpowernode.dao","com.bjpowernode.mapper"})
- public class Application {
- }
现在把Mapper文件放在resources目录下
1)在resources目录中创建子目录 (自定义的) , 例如mapper
2)把mapper文件放到 mapper目录中
3)在application.properties文件中,指定mapper文件的目录
- #指定mapper文件的位置
- mybatis.mapper-locations=classpath:mapper/*.xml
- #指定mybatis的日志
- mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
4) 在pom.xml中指定 把resources目录中的文件 , 编译到目标目录中
- <resources>
- <resource>
- <directory>src/main/resourcesdirectory>
- <includes>
- <include>**/*.*include>
- includes>
- resource>
- resources>
Spring框架中的事务:
1) 管理事务的对象: 事务管理器(接口, 接口有很多的实现类)
例如:使用Jdbc或mybatis访问数据库,使用的事务管理器:DataSourceTransactionManager
2 ) 声明式事务: 在xml配置文件或者使用注解说明事务控制的内容
控制事务: 隔离级别,传播行为, 超时时间
3)事务处理方式:
1) Spring框架中的@Transactional
2) aspectj框架可以在xml配置文件中,声明事务控制的内容
SpringBoot中使用事务: 上面的两种方式都可以。
1)在业务方法的上面加入@Transactional , 加入注解后,方法有事务功能了。
2)明确的在主启动类的上面 ,加入@EnableTransactionManager
- /**
- * @Transactional: 表示方法的有事务支持
- * 默认:使用库的隔离级别, REQUIRED 传播行为; 超时时间 -1
- * 抛出运行时异常,回滚事务
- */
- @Transactional
- @Override
- public int addStudent(Student student) {
- System.out.println("业务方法addStudent");
- int rows = studentDao.insert(student);
- System.out.println("执行sql语句");
-
- //抛出一个运行时异常, 目的是回滚事务
- //int m = 10 / 0 ;
-
- return rows;
- }