本身如今也是在初學springboot,在以前開發時用過ssm架構,以爲步驟有點繁瑣,進而瞭解到springboot。java
SpringBoot對上述Spring的缺點進行的改善和優化,基於約定優於配置的思想,可讓開發人員沒必要在配置與邏輯業務之間進行思惟的切換,全身心的投入到邏輯業務的代碼編寫中,從而大大提升了開發的效率,必定程度上縮短了項目週期。mysql
起步依賴web
起步依賴本質上是一個Maven項目對象模型(Project Object Model,POM),定義了對其餘庫的傳遞依賴,這些東西加在一塊兒即支持某項功能。spring
簡單的說,起步依賴就是將具有某種功能的座標打包到一塊兒,並提供一些默認的功能。sql
自動配置數據庫
Spring Boot的自動配置是一個運行時(更準確地說,是應用程序啓動時)的過程,考慮了衆多因素,才決定Spring配置應該用哪一個,不應用哪一個。該過程是Spring自動完成的。springboot
<!--mybatis起步依賴-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.1.1</version>
</dependency>
<!-- MySQL鏈接驅動 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
複製代碼
#DB Configuration:
spring.datasource.driverClassName=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://127.0.0.1:3306/test? useUnicode=true&characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=root
複製代碼
-- ---------------------------- -- Table structure for `user` -- ---------------------------- DROP TABLE IF EXISTS `user`; CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(50) DEFAULT NULL,
`password` varchar(50) DEFAULT NULL,
`name` varchar(50) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES ('1', 'zhangsan', '123', '張三'); INSERT INTO `user` VALUES ('2', 'lisi', '123', '李四');
複製代碼
<!--lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.6</version>
</dependency>
複製代碼
@Data
public class user {
private Integer id;
private String username;
private String password;
private String name;
}
複製代碼
@Mapper
public interface UserMapper {
public List<User> queryUserList();
}
複製代碼
注意:@Mapper標記該類是一個mybatis的mapper接口,能夠被spring boot自動掃描到spring上下文中bash
在src\main\resources\mapper路徑下加入UserMapper.xml配置文件mybatis
<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.itheima.mapper.UserMapper">
<select id="queryUserList" resultType="user">
select * from user
</select>
</mapper>
複製代碼
#spring集成Mybatis環境
#pojo別名掃描包
mybatis.type-aliases-package=com.itheima.domain
#加載Mybatis映射文件
mybatis.mapper-locations=classpath:mapper/*Mapper.xml
複製代碼
@Controller
public class MapperController {
@Autowired
private UserMapper userMapper;
@RequestMapping("/queryUser")
@ResponseBody
public List<User> queryUser(){
List<User> users = userMapper.queryUserList();
return users;
}
}
複製代碼
@SpringBootApplication
public class SpringbootMybatisApplication {
public static void main(String[] args) {
SpringApplication.run(SpringbootMybatisApplication.class, args);
}
}
複製代碼
<!--測試的起步依賴-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
複製代碼
@RunWith(SpringRunner.class)
@SpringBootTest(classes = SpringbootMybatisApplication.class)
public class MybatisTest {
@Autowired
private UserMapper userMapper;
@Test
public void test(){
List<User> users = userMapper.queryUserList();
System.out.println(users);
}
}
複製代碼
其中, SpringRunner繼承自SpringJUnit4ClassRunner,使用哪個Spring提供的測試測試引擎均可以架構
public final class SpringRunner extends SpringJUnit4ClassRunner
複製代碼
@SpringBootTest的屬性指定的是引導類的字節碼對象。
在學習springboot的過程當中,要有一種深挖源碼的習慣,springboot在開發中給予了咱們極大的便利,可是本身要能清晰的明白每一個步驟底層的原理是怎樣實現的。