您好,登錄后才能下訂單哦!
本篇文章為大家展示了如何進行Spring Boot 2.X集成MyBatis數據層開發,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
MyBatis 是一款優秀的持久層框架,支持定制化 SQL、存儲過程以及高級映射。它采用面向對象編程的方式對數據庫進行 CRUD 的操作,使程序中對關系數據庫的操作更方便簡單。它支持 XML 描述符配置文件和注解兩種方式執行 SQL 語句。“簡單靈活”是它在對象關系映射工具上的最大優勢。
過去使用 MyBatis 開發,需要各種配置文件、實體類、Dao 層映射關聯、還有一大推其它配置。經過進行不斷的優化后,終于他來了,mybatis-spring-boot-starter
可以做到無需配置只用注解開發,也可以使用簡單的配置輕松上手。 當然兩種方式都需要在 POM 文件引入mybatis-spring-boot-starter
:
<!-- mybaits --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.0</version> </dependency>
SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for t_user -- ---------------------------- DROP TABLE IF EXISTS `t_user`; CREATE TABLE `t_user` ( `id` int(8) NOT NULL AUTO_INCREMENT COMMENT 'ID', `user_name` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '用戶姓名', `user_sex` char(1) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '用戶性別', PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=23 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of t_user -- ---------------------------- BEGIN; INSERT INTO `t_user` VALUES (1, '劉備', '男'); INSERT INTO `t_user` VALUES (2, '孫尚香', '女'); INSERT INTO `t_user` VALUES (3, '周瑜', '男'); INSERT INTO `t_user` VALUES (4, '小喬', '女'); INSERT INTO `t_user` VALUES (5, '諸葛亮', '男'); INSERT INTO `t_user` VALUES (6, '黃月英', '女'); INSERT INTO `t_user` VALUES (7, '關羽', '男'); INSERT INTO `t_user` VALUES (8, '張飛', '男'); INSERT INTO `t_user` VALUES (9, '趙云', '男'); INSERT INTO `t_user` VALUES (10, '黃總', '男'); INSERT INTO `t_user` VALUES (11, '曹操', '男'); INSERT INTO `t_user` VALUES (12, '司馬懿', '男'); INSERT INTO `t_user` VALUES (13, '貂蟬', '女'); INSERT INTO `t_user` VALUES (14, '呂布', '男'); INSERT INTO `t_user` VALUES (15, '馬超', '男'); INSERT INTO `t_user` VALUES (16, '魏延', '男'); INSERT INTO `t_user` VALUES (17, '孟獲', '男'); INSERT INTO `t_user` VALUES (18, '大喬', '女'); INSERT INTO `t_user` VALUES (19, '劉嬋', '男'); INSERT INTO `t_user` VALUES (20, '姜維', '男'); INSERT INTO `t_user` VALUES (21, '廖化', '男'); INSERT INTO `t_user` VALUES (22, '關平', '男'); COMMIT; SET FOREIGN_KEY_CHECKS = 1;
public class UserEntity { private Long id; private String userName; private String userSex; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } public String getUserSex() { return userSex; } public void setUserSex(String userSex) { this.userSex = userSex; } }
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <!-- 熱部署模塊 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional> <!-- 這個需要為 true 熱部署才有效 --> </dependency> <!-- mysql 數據庫驅動. --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency> <!-- mybaits --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.0</version> </dependency> </dependencies>
#datasource spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://127.0.0.1:3306/db_test?useUnicode=true&characterEncoding=UTF-8&useSSL=true spring.datasource.username=root spring.datasource.password=root
在啟動類中添加對 mapper 包掃描@MapperScan
@SpringBootApplication @MapperScan("cn.zwqh.springboot.dao") public class SpringBootMybatisApplication { public static void main(String[] args) { SpringApplication.run(SpringBootMybatisApplication.class, args); } }
或者直接在 Mapper 類上面添加注解@Mapper,建議使用上面那種,不然每個 mapper 加個注解也挺麻煩的
public interface UserDao { //使用注解方式 /** * 獲取所有用戶 * @return */ @Select("select * from t_user") @Results({ @Result(property = "userName",column = "user_name"), @Result(property = "userSex",column = "user_sex") }) List<UserEntity> getAll2(); /** * 根據id獲取用戶 * @param id * @return */ @Select("select * from t_user where id=#{id}") @Results({ @Result(property = "userName",column = "user_name"), @Result(property = "userSex",column = "user_sex") }) List<UserEntity> getOne2(Long id); /** * 新增用戶 * @param user */ @Insert("insert into t_user (user_name,user_sex) values(#{userName},#{userSex})") void insertUser2(UserEntity user); /** * 修改用戶 * @param user */ @Update("update t_user set user_name=#{userName},user_sex=#{userSex} where id=#{id}") void updateUser2(UserEntity user); /** * 刪除用戶 * @param id */ @Delete("delete from t_user where id=#{id}") void deleteUser2(Long id); }
注解: @Select 是查詢類的注解,所有的查詢均使用這個 @Result 修飾返回的結果集,關聯實體類屬性和數據庫字段一一對應,如果實體類屬性和數據庫屬性名保持一致,就不需要這個屬性來修飾。 @Insert 插入數據庫使用,直接傳入實體類會自動解析屬性到對應的值 @Update 負責修改,也可以直接傳入對象 @delete 負責刪除
UserController
@RestController @RequestMapping("/user") public class UserController { @Autowired private UserDao userDao; //使用注解方式 /** * 獲取所有用戶 * @return */ @RequestMapping("/getAll2") public List<UserEntity> getAll2(){ return userDao.getAll2(); } /** * 根據id獲取用戶 * @return */ @RequestMapping("/getOne2") public List<UserEntity> getOne2(Long id){ return userDao.getOne2(id); } /** * 新增用戶 * @param user * @return */ @RequestMapping("/insertUser2") public String insertUser2(UserEntity user) { userDao.insertUser2(user); return "insert success"; } /** * 修改用戶 * @param user * @return */ @RequestMapping("/updateUser2") public String updateUser2(UserEntity user) { userDao.updateUser2(user); return "update success"; } /** * 刪除用戶 * @param user * @return */ @RequestMapping("/deleteUser2") public String deleteUser2(Long id) { userDao.deleteUser2(id); return "delete success"; } }
啟動項目后可以通過瀏覽器訪問 http://127.0.0.1:8080/user/getOne2?id=1
進行測試,其他雷同。也可以編寫單元測試進行測試。
#datasource spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://127.0.0.1:3306/db_test?useUnicode=true&characterEncoding=UTF-8&useSSL=true spring.datasource.username=root spring.datasource.password=root #mybatis mybatis.mapper-locations=classpath:/mapper/*.xml
public interface UserDao { //mapper.xml方式 /** * 獲取所有用戶 * @return */ List<UserEntity> getAll(); /** * 根據id獲取用戶 * @return */ List<UserEntity> getOne(Long id); /** * 新增用戶 * @param user */ void insertUser(UserEntity user); /** * 修改用戶 * @param user */ void updateUser(UserEntity user); /** * 刪除用戶 * @param id */ void deleteUser(Long id); }
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.4//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="cn.zwqh.springboot.dao.UserDao"> <resultMap type="cn.zwqh.springboot.model.UserEntity" id="user"> <id property="id" column="id"/> <result property="userName" column="user_name"/> <result property="userSex" column="user_sex"/> </resultMap> <!-- 獲取所有用戶 --> <select id="getAll" resultMap="user"> select * from t_user </select> <!-- 根據用戶ID獲取用戶 --> <select id="getOne" resultMap="user"> select * from t_user where id=#{id} </select> <!-- 新增用戶 --> <insert id="insertUser" parameterType="cn.zwqh.springboot.model.UserEntity"> insert into t_user (user_name,user_sex) values(#{userName},#{userSex}) </insert> <!-- 修改用戶 --> <update id="updateUser" parameterType="cn.zwqh.springboot.model.UserEntity"> update t_user set user_name=#{userName},user_sex=#{userSex} where id=#{id} </update> <!-- 刪除用戶 --> <delete id="deleteUser" parameterType="Long"> delete from t_user where id=#{id} </delete> </mapper>
個人覺得,注解方式適合輕量級的項目,現在的微服務項目比較適合這種模式;對于大型項目,復雜的多表聯合查詢sql用 xml 更適合。
<!-- pagehelper --> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>1.2.12</version> </dependency>
@RestController @RequestMapping("/user") public class UserController { @Autowired private UserDao userDao; /** * 使用pagehelper分頁插件 * @param pageNum * @param pageSize * @return */ @RequestMapping("/pagehelperTest") public List<UserEntity> pagehelperTest(int pageNum,int pageSize){ PageHelper.startPage(pageNum, pageSize); return userDao.getAll(); //直接使用上面的 mapper } }
瀏覽器直接訪問 http://127.0.0.1:8080/user/pagehelperTest?pageNum=1&pageSize=10
,改變參數試試。
上述內容就是如何進行Spring Boot 2.X集成MyBatis數據層開發,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。