[MyBatis] 스프링(Spring)에 마이바티스(MyBatis) 연동하기 [MyBatis, SQL Mapper 프레임워크]

2022. 8. 11. 22:11·▣ Framework/MyBatis🐣
728x90


1. 마이바티스(MyBatis)란?

쿼리 기반 웹 애플리케이션을 개발할 때
가장 많이 사용되는 SQL Mapper 프레임워크

 

마이바티스는 JDBC로 처리하는 상당부분의 코드와 파라미터 설정 및 결과 매핑을 대신해준다.

2. 의존성 주입 : dependency 추가

DB에 대한 dependency는 따로 추가해줘야 한다.
<!-- mybatis -->
<dependency>
	<groupId>org.mybatis</groupId>
	<artifactId>mybatis</artifactId>
	<version>3.5.7</version>
</dependency>

<!-- Spring 연동 : mybatis-spring -->
<dependency>
	<groupId>org.mybatis</groupId>
	<artifactId>mybatis-spring</artifactId>
	<version>2.0.6</version>
</dependency>

<!-- Spring 연동 : spring-jdbc -->
<dependency>
	<groupId>org.springframework</groupId>
	<artifactId>spring-jdbc</artifactId>
	<version>${org.springframework-version}</version>
</dependency>

- Maven : mybatis

 

Maven Repository: org.mybatis » mybatis

The MyBatis SQL mapper framework makes it easier to use a relational database with object-oriented applications. MyBatis couples objects with stored procedures or SQL statements using a XML descriptor or annotations. Simplicity is the biggest advantage of

mvnrepository.com

- Maven : mybatis-spring

https://mvnrepository.com/artifact/org.mybatis/mybatis-spring

- Maven : spring-jdbc

https://mvnrepository.com/artifact/org.springframework/spring-jdbc


3. Spring에 MyBatis 연동하기

1) root-context.xml에 추가

typeAliasesPackage를 쓰면 쿼리문에서 사용할 객체의 이름을 조작할 수 있다.
<!-- sqlSessionFactory 추가 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  <property name="dataSource" ref="dataSource" />
  <property name="typeAliasesPackage" value="domain이 있는 패키지" />
</bean>

<!-- mapper 자동 스캔 -->
<mybatis-spring:scan base-package="mapper가 있는 패키지" />

 

root-context.xml 예시


2) mapper.java 파일 생성

mapper는 interface로 정의해야 한다.

interface로 mapper.java 파일 생성


3) mapper.xml 파일 생성

mapper.java 파일과 mapper.xml 파일의 이름은 일치해야 한다.
<!-- 마이바티스3 버전 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.crizen.mapper.BoardMapper">

	<!-- 쿼리문 작성 -->
    
</mapper>

 

src/main/resources에 mapper.xml을 생성한다.


- 참고자료

 

MyBatis – 마이바티스 3 | 소개

마이바티스는 무엇인가? 마이바티스는 개발자가 지정한 SQL, 저장프로시저 그리고 몇가지 고급 매핑을 지원하는 퍼시스턴스 프레임워크이다. 마이바티스는 JDBC로 처리하는 상당부분의 코드와

mybatis.org

 

4. SpringBoot와 MyBatis 연동

마이바티스(MyBatis)란마이바티스는 쿼리 기반 웹 애플리케이션을 개발할 때 가장 많이 사용되는 SQL Mapper 프레임워크이다. 마이바티스는 기존의 JDBC를 이용하여 개발하는 방식에 비해 개발자의

jung-max.github.io


728x90
'▣ Framework/MyBatis🐣' 카테고리의 다른 글
  • [MyBatis] MyBatis SQL : resultMap 구문 [Map 형태로 SQL 결과값 받기]
  • [MyBatis] MyBatis SQL : SQL 구문 [SQL 구문 재사용 가능하게 정의하기]
  • [MyBatis] MyBatis SQL : insert, update, delete [마이바티스로 데이터 변경하기]
  • [MyBatis] MyBatis SQL : select [마이바티스로 데이터 조회하기]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    Database
    백준 티어
    일상
    꿀팁
    spring
    jsp
    코딩 테스트
    Oracle
    SQL
    javascript
    자바스크립트
    html
    BOJ
    프로그래밍
    Error Note
    Project
    Java
    코딩
    백준
    CSS
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[MyBatis] 스프링(Spring)에 마이바티스(MyBatis) 연동하기 [MyBatis, SQL Mapper 프레임워크]
상단으로

티스토리툴바