ホームページ >Java >&#&チュートリアル >Spring Boot での MyBatis の構成ガイド
Spring Boot に基づく MyBatis 構成の詳細な説明
Spring Boot は迅速なアプリケーション開発のためのフレームワークであり、MyBatis は人気のある永続化フレームワークです。 Spring Boot で MyBatis を使用すると、データベース アクセスとデータの永続化のプロセスを簡素化できます。この記事では、Spring Boot で MyBatis を構成して使用する方法を詳しく説明し、具体的なコード例を示します。
1. MyBatis の構成
MyBatis を使用する前に、まず関連する依存関係を pom.xml ファイルに追加する必要があります。
<dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.4</version> </dependency>
Spring Boot では、組み込み H2 データベースをデモンストレーションとして使用できます。 application.properties ファイルに次の構成を追加します:
spring.datasource.url=jdbc:h2:mem:testdb spring.datasource.driver-class-name=org.h2.Driver spring.datasource.username=sa spring.datasource.password=
application.properties ファイルに次の構成を追加します:
mybatis.mapper-locations=classpath:mapper/*.xml mybatis.type-aliases-package=com.example.domain
ここで、 mapper-locations
は MyBatis マッピング ファイルの場所を指定し、 type-aliases-package
はエンティティ クラスのパッケージ名を指定します。
サンプル エンティティ クラスとして User クラスを作成します:
package com.example.domain; public class User { private Long id; private String name; // 省略getter和setter方法 }
UserMapper インターフェイスを作成し、インターフェイスで実行する必要があるデータベース操作を定義します。
package com.example.mapper; import com.example.domain.User; import org.apache.ibatis.annotations.Mapper; @Mapper public interface UserMapper { User getUserById(Long id); void saveUser(User user); void updateUser(User user); void deleteUser(Long id); }
リソース ディレクトリに移動し、このフォルダーに UserMapper.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="com.example.mapper.UserMapper"> <resultMap id="BaseResultMap" type="com.example.domain.User"> <id column="id" property="id" jdbcType="BIGINT"/> <result column="name" property="name" jdbcType="VARCHAR"/> </resultMap> <select id="getUserById" resultMap="BaseResultMap"> SELECT * FROM user WHERE id = #{id} </select> <insert id="saveUser"> INSERT INTO user(name) VALUES(#{name}) </insert> <update id="updateUser"> UPDATE user SET name = #{name} WHERE id = #{id} </update> <delete id="deleteUser"> DELETE FROM user WHERE id = #{id} </delete> </mapper>
2. データベース操作に MyBatis を使用します
特定のデータベース操作を実行するために使用される UserService クラスを作成します。
package com.example.service; import com.example.domain.User; import com.example.mapper.UserMapper; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class UserService { @Autowired private UserMapper userMapper; public User getUserById(Long id) { return userMapper.getUserById(id); } public void saveUser(User user) { userMapper.saveUser(user); } public void updateUser(User user) { userMapper.updateUser(user); } public void deleteUser(Long id) { userMapper.deleteUser(id); } }
外部リクエストを受信し、対応する Service メソッドを呼び出すための UserController クラスを作成します。
package com.example.controller; import com.example.domain.User; import com.example.service.UserService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; @RestController @RequestMapping("/users") public class UserController { @Autowired private UserService userService; @GetMapping("/{id}") public User getUserById(@PathVariable Long id) { return userService.getUserById(id); } @PostMapping("/") public void saveUser(@RequestBody User user) { userService.saveUser(user); } @PutMapping("/{id}") public void updateUser(@PathVariable Long id, @RequestBody User user) { user.setId(id); userService.updateUser(user); } @DeleteMapping("/{id}") public void deleteUser(@PathVariable Long id) { userService.deleteUser(id); } }
スタートアップ クラスを作成し、@SpringBootApplication
アノテーションを追加します:
package com.example; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }
Postman などのツールを使用して、HTTP リクエストを送信し、インターフェイスの呼び出しをテストできます。たとえば、GET リクエスト: localhost:8080/users/1
を送信して、ID 1 のユーザー情報をクエリします。
結論
この記事では、Spring Boot ベースのプロジェクトで MyBatis を構成および使用するプロセスを詳細に説明し、関連するコード例を示します。上記の手順により、Spring Boot プロジェクトでのデータベース操作に MyBatis を簡単に統合して使用できます。この記事がお役に立てば幸いです!
以上がSpring Boot での MyBatis の構成ガイドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。