在Springboot2框架中,使用Mysql和Mybatis功能:
1. Mysql+Datasource集成
2. Mybatis+XML用法詳解html
採用了Oracle中的scott用戶下的四張表,遷移至MySQL下,詳見MySQL中創建Oracle中SCOTT數據示例java
本工程代碼採用idea進行構建mysql
一、新建工程web
二、 建立工程時,直接勾選所需依賴spring
三、工程建立完畢後,刪除無用文件sql
四、手動添加額外依賴,配置pom.xml數據庫
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.6.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.lock</groupId> <artifactId>smartmis-scott</artifactId> <version>0.0.1-SNAPSHOT</version> <name>smartmis-scott</name> <description>SmartMIS for Scott</description> <properties> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.0.1</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> <version>5.1.46</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.1.42</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
注意:手動修改一下mysql驅動的版本,默認版本比較高,應用時可能會有錯誤;我這裏手動指定爲5.1.46版本。apache
五、修改原application.properties爲application.yml,並作以下配置json
spring: datasource: driverClassName: com.mysql.jdbc.Driver url: jdbc:mysql://localhost:3306/scott?useUnicode=true&autoReconnect=true&allowMultiQueries=true&useSSL=false username: root password: **** server: port: 8686 mybatis: config-location: classpath:mybatis-config.xml
六、resources目錄下新增mybatis-config.xml配置文件api
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <typeAliases> <package name="com.lock"/> </typeAliases> <mappers> <mapper resource="mybatis/mapper/DeptMapper.xml"/> <mapper resource="mybatis/mapper/EmpMapper.xml"/> <mapper resource="mybatis/mapper/SalgradeMapper.xml"/> <mapper resource="mybatis/mapper/BonusMapper.xml"/> </mappers> </configuration>
對應DeptMapper.xml
<?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.lock.smartmis.business.vo.DeptVo"> <select id="getAllDepts" resultType="com.lock.smartmis.business.vo.DeptVo"> select * from dept </select> <select id="getDeptByNo" resultType="com.lock.smartmis.business.vo.DeptVo"> select * from dept where deptno = #{deptNo} </select> </mapper>
七、創建bo類(以Dept類爲例),並以此爲基礎創建vo類
package com.lock.smartmis.business.bo; import java.io.Serializable; public class Dept implements Serializable { private static final long serialVersionUID = 1L; private long deptNo; private String dName; private String loc; public long getDeptNo() { return deptNo; } public void setDeptNo(long deptNo) { this.deptNo = deptNo; } public String getdName() { return dName; } public void setdName(String dName) { this.dName = dName; } public String getLoc() { return loc; } public void setLoc(String loc) { this.loc = loc; } @Override public String toString(){ return getDeptNo() + "," + getdName() + "," + getLoc(); } }
package com.lock.smartmis.business.vo; import com.lock.smartmis.business.bo.Dept; public class DeptVo extends Dept{ private static final long serialVersionUID = 1L; }
八、Dao層接口及其實現
package com.lock.smartmis.business.dao; import com.lock.smartmis.business.vo.DeptVo; import java.util.List; public interface DeptDao { public List<DeptVo> getAllDepts(); public DeptVo getDeptByNo(Long id); }
package com.lock.smartmis.business.dao.impl; import com.lock.smartmis.business.dao.DeptDao; import com.lock.smartmis.business.vo.DeptVo; import org.mybatis.spring.SqlSessionTemplate; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.List; @Component public class DeptDaoimpl implements DeptDao { @Autowired public SqlSessionTemplate sqlSessionTemplate; @Override public List<DeptVo> getAllDepts() { return this.sqlSessionTemplate.selectList("getAllDepts"); } @Override public DeptVo getDeptByNo(Long deptNo) { return this.sqlSessionTemplate.selectOne("getDeptByNo", deptNo); } }
九、Controller層
package com.lock.smartmis.business.controller; import com.lock.smartmis.business.service.DeptService; import com.lock.smartmis.business.util.JsonResult; import com.lock.smartmis.business.util.ResultCode; import com.lock.smartmis.business.vo.DeptVo; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.util.List; @RestController @RequestMapping("/restapi") public class ScottController { protected static Logger logger = LoggerFactory.getLogger(ScottController.class); @Autowired private DeptService deptService; @GetMapping("/test") public String test() { return "API接口測試"; } @GetMapping("/depts") public JsonResult getAllDepts(){ List<DeptVo> list = this.deptService.getAllDepts(); return new JsonResult(ResultCode.SUCCESS, list); } @GetMapping("/dept/{deptNo}") public JsonResult getDeptByNo(@PathVariable("deptNo") Long deptNo){ DeptVo deptVo = this.deptService.getDeptByNo(deptNo); return new JsonResult(ResultCode.SUCCESS, deptVo); } }
十、項目運行起來,測試一下接口
~