Spring Boot 整合 MyBatis和 SQL Server實踐

Profile
文章共 509字,閱讀大約需要 2分鐘 !
概 述
Spring Boot工程整合 MyBatis來實現 MySQL訪問的示例我們見過很多,而最近用到了微軟的 SQL Server資料庫,於是本文則給出一個完整的 Spring Boot + MyBatis + SQL Server 的工程示例。
注:本文首發於 ofollow,noindex"> My Personal Blog:CodeSheep·程式羊 ,歡迎光臨 小站
工程搭建
pom.xml
<!--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
後 記
由於能力有限,若有錯誤或者不當之處,還請大家批評指正,一起學習交流!
- My Personal Blog: CodeSheep 程式羊
- 我的半年技術部落格之路