Всего в статье 509 слов, а чтение занимает около 2 минут!
Обзор
Мы видели много примеров проекта Spring Boot, интегрирующего MyBatis для доступа к MySQL, и недавно использовали базу данных Microsoft SQL Server, поэтому в этой статье дается полноеSpring Boot + MyBatis + SQL Serverинженерный пример.
Примечание:Эта статья была впервые опубликована вМой личный блог: CodeSheep · Program Sheep,Добро пожаловатьмаленькая станция
Инженерное сооружение
- Создайте новый проект 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
- 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="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>
- При этом здесь же приведен и интерфейс DAO, соответствующий XML.
public interface UserMapper {
List<User> getAllUsers();
int addUser( User user );
int deleteUser( User user );
}
Ради эксперимента, здесь данодобавить/удалить/проверитьТри операции с базой данных.
Написать сервис и тестовый контроллер
- После того, как вышеуказанные приготовления завершены, следующим шагом будет написание класса обслуживания базы данных CRUD.
@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 );
}
}
Сервисная функция здесь также в основном связана с таблицей данных.добавить/удалить/проверитьТри операции с базой данных.
- В отличие от вышеуказанного Сервиса, мы пишем Контроллер, соответствующий тесту интерфейса.
@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, чтобы увидеть ситуацию вставки данных следующим образом:
- Данные запроса
перечислитьGet /getAllUser
Интерфейс для получения нескольких только что вставленных данных
- удалить данные
перечислитьPost /deleteUser
Интерфейс, вы можете удалить соответствующего пользователя через имя пользователя
Постскриптум
Из-за ограниченных возможностей, если есть ошибки или неуместность, пожалуйста, критикуйте и исправьте их, учитесь и обменивайтесь мнениями вместе!
МожетНажмитеилисканированиеследующеебудь остороженподписаться на официальный аккаунт автораCodeSheep, получить большеПрагматичный, понятный, воспроизводимыйИсходный текст ↓↓↓