Spring Boot 集成 MyBatis 和 SQL Server 实践

本贴最后更新于 2309 天前,其中的信息可能已经斗转星移

Profile

文章共 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


后 记

由于能力有限,若有错误或者不当之处,还请大家批评指正,一起学习交流!



  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    173 引用 • 414 回帖 • 367 关注
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    21 引用 • 31 回帖
  • Spring

    Spring 是一个开源框架,是于 2003 年兴起的一个轻量级的 Java 开发框架,由 Rod Johnson 在其著作《Expert One-On-One J2EE Development and Design》中阐述的部分理念和原型衍生而来。它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 JavaEE 应用程序开发提供集成的框架。

    948 引用 • 1460 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...