Spring Boot 整合 MyBatis和 SQL Server實踐

CodeSheep發表於2018-12-17

文章共 509字,閱讀大約需要 2分鐘 !


概 述

Spring Boot工程整合 MyBatis來實現 MySQL訪問的示例我們見過很多,而最近用到了微軟的 SQL Server資料庫,於是本文則給出一個完整的 Spring Boot + MyBatis + SQL Server 的工程示例。

注: 本文首發於 My Personal Blog:CodeSheep·程式羊,歡迎光臨 小站


工程搭建

  • 新建 Spring Boot工程
  • pom.xml 中新增 MyBatis和 SQL Server相關的依賴
<!--for mybatis-->
<dependency>
	<groupId>org.mybatis.spring.boot</groupId>
	<artifactId>mybatis-spring-boot-starter</artifactId>
	<version>1.3.2</version>
</dependency>

<!--for SqlServer-->
<dependency>
	<groupId>com.microsoft.sqlserver</groupId>
	<artifactId>sqljdbc4</artifactId>
	<version>4.0</version>
</dependency>
複製程式碼
  • 配置 application.properties

這裡同樣主要是對於 MyBatis 和 SQL Server連線相關的配置

server.port=89

# mybatis 配置
mybatis.type-aliases-package=cn.codesheep.springbt_mybatis_sqlserver.entity
mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.configuration.map-underscore-to-camel-case=true

## -------------------------------------------------

## SqlServer 配置
spring.datasource.url=jdbc:sqlserver://xxxx:1433;databasename=MingLi
spring.datasource.driver-class-name=com.microsoft.sqlserver.jdbc.SQLServerDriver
spring.datasource.username=xxxx
spring.datasource.password=xxxx
複製程式碼

建立 SQL Server資料表和實體類

  • 首先在 SQL Server資料庫中新建資料表 user_test作為測試用表
DROP TABLE [demo].[user_test]
GO
CREATE TABLE [dbo].[user_test] (
[user_id] int NOT NULL ,
[user_name] varchar(50) NOT NULL ,
[sex] tinyint NOT NULL ,
[created_time] varchar(50) NOT NULL 
)

GO
複製程式碼
  • 然後在我們的工程中對應建立的 User實體類

其欄位和實際資料表的欄位一一對應

public class User {

    private Long userId;
    private String userName;
    private Boolean sex;
    private String createdTime;

    public Long getUserId() {
        return userId;
    }

    public void setUserId(Long userId) {
        this.userId = userId;
    }

    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }

    public Boolean getSex() {
        return sex;
    }

    public void setSex(Boolean sex) {
        this.sex = sex;
    }

    public String getCreatedTime() {
        return createdTime;
    }

    public void setCreatedTime(String createdTime) {
        this.createdTime = createdTime;
    }
}
複製程式碼

Mybatis Mapper對映配置

  • MyBatis對映配置的 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="cn.codesheep.springbt_mybatis_sqlserver.mapper.UserMapper">

    <resultMap id="userMap" type="cn.codesheep.springbt_mybatis_sqlserver.entity.User">
        <id property="userId" column="user_id" javaType="java.lang.Long"></id>
        <result property="userName" column="user_name" javaType="java.lang.String"></result>
        <result property="sex" column="sex" javaType="java.lang.Boolean"></result>
        <result property="createdTime" column="created_time" javaType="java.lang.String"></result>
    </resultMap>

    <select id="getAllUsers" resultMap="userMap">
        select * from user_test
    </select>

    <insert id="addUser" parameterType="cn.codesheep.springbt_mybatis_sqlserver.entity.User">
        insert into user_test ( user_id, user_name, sex, created_time ) values ( #{userId}, #{userName}, #{sex}, #{createdTime} )
    </insert>

    <delete id="deleteUser" parameterType="cn.codesheep.springbt_mybatis_sqlserver.entity.User">
        delete from user_test where user_name = #{userName}
    </delete>

</mapper>
複製程式碼
  • 與此同時,這裡也給出對應 XML的 DAO介面
public interface UserMapper {
    List<User> getAllUsers();
    int addUser( User user );
    int deleteUser( User user );
}
複製程式碼

為了試驗起見,這裡給出了 增 / 刪 / 查 三個資料庫操作動作。


編寫 Service 和測試Controller

  • 上面這些準備工作完成之後,接下來編寫資料庫 CRUD的 Service類
@Service
@Primary
public class UserServiceImpl implements IUserService {

    @Autowired
    private UserMapper userMapper;

    @Override
    public List<User> getAllUsers() {
        return userMapper.getAllUsers();
    }

    @Override
    public int addUser(User user) {
        SimpleDateFormat form = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        user.setCreatedTime( form.format(new Date()) );
        return userMapper.addUser( user );
    }

    @Override
    public int deleteUser(User user) {
        return userMapper.deleteUser( user );
    }
}
複製程式碼

這裡的 Service功能同樣主要關於資料表的 增 / 刪 / 查 三個資料庫操作動作。

  • 對照著上面的Service,我們編寫一個對應介面測試的Controller
@RestController
public class UserController {

    @Autowired
    private IUserService userService;

    @RequestMapping(value = "/getAllUser", method = RequestMethod.GET)
    public List<User> getAllUser() {
        return userService.getAllUsers();
    }

    @RequestMapping(value = "/addUser", method = RequestMethod.POST)
    public int addUser( @RequestBody User user ) {
        return userService.addUser( user );
    }

    @RequestMapping(value = "/deleteUser", method = RequestMethod.POST)
    public int deleteUser( @RequestBody User user ) {
        return userService.deleteUser( user );
    }

}
複製程式碼

實驗測試

  • 插入資料

依次用 POSTMAN通過 Post /addUser介面插入三條資料:

{"userId":1,"userName":"劉能","sex":true}
{"userId":2,"userName":"趙四","sex":false}
{"userId":3,"userName":"王大拿","sex":true}
複製程式碼

插入完成後去 SQL Server資料庫裡看一下資料插入情況如下:

去SQL Server資料庫裡看一下資料插入情況

  • 查詢資料

呼叫 Get /getAllUser介面,獲取剛插入的幾條資料

查詢資料

  • 刪除資料

呼叫 Post /deleteUser介面,可以通過使用者名稱來刪除對應的使用者

image.png


後 記

由於能力有限,若有錯誤或者不當之處,還請大家批評指正,一起學習交流!



長按掃描 下面的 小心心 來訂閱作者公眾號 CodeSheep,獲取更多 務實、能看懂、可復現的 原創文 ↓↓↓

CodeSheep · 程式羊


相關文章