@[toc]
二、搭建MyBatis采用xml方式赤炒,驗(yàn)證CRUD(增刪改查操作)
2.1 開發(fā)環(huán)境
IDE
:idea 2021.1
構(gòu)建工具
:maven 3.8.4
MySQL版本
:MySQL 5.7.40
MyBatis版本
:MyBatis 3.5.7
數(shù)據(jù)庫表:
2.2 創(chuàng)建maven工程
項(xiàng)目初始目錄
引入依賴
<dependencies>
<!-- Mybatis核心 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>
<!-- junit測(cè)試 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13</version>
<scope>test</scope>
</dependency>
<!-- MySQL驅(qū)動(dòng) -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.31</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.22</version>
</dependency>
</dependencies>
2.3 創(chuàng)建User實(shí)體
com/mybatis/entity/User.java
package com.mybatis.entity;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;
/**
* @Author 211145187
* @Date 2023/4/17 22:33
**/
@Data
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class User {
//id
private Integer id;
//用戶名稱
private String username;
//用戶密碼
private String password;
//用戶手機(jī)號(hào)碼
private String mobile;
public User(String username, String password, String mobile, Integer gender) {
this.username = username;
this.password = password;
this.mobile = mobile;
this.gender = gender;
}
public User(String username, Integer gender) {
this.username = username;
this.gender = gender;
}
}
2.4 創(chuàng)建MyBatis的核心配置文件
-
習(xí)慣上命名為mybatis-config.xml
莺褒,這個(gè)文件名僅僅只是建議,并非強(qiáng)制要求遵岩。將來整合Spring
之后,這個(gè)配置文件可以省略舍哄,所以大家操作時(shí)可以直接復(fù)制誊锭、粘貼。
核心配置文件主要用于配置連接數(shù)據(jù)庫的環(huán)境以及MyBatis的全局配置信息
炉旷。核心配置文件存放的位置是src/main/resources目錄下
。
mybatis-config.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!--配置約束-->
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!--設(shè)置連接數(shù)據(jù)庫的環(huán)境-->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://192.168.31.20:3306/litemall"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>
<!--引入映射文件-->
<mappers>
<mapper resource="mapper/UserMapper.xml"/>
</mappers>
</configuration>
2.5 創(chuàng)建mapper接口
MyBatis中的mapper接口相當(dāng)于以前的dao饥追。但是區(qū)別在于罐盔,mapper僅僅是接口,我們不需要
提供實(shí)現(xiàn)類捏顺。
package com.mybatis.mapper;
public interface UserMapper {
/**
* MyBatis面向接口編程的兩個(gè)一致:
* 1纬黎、映射文件的namespace要和mapper接口的全類名保持一致
* 2、映射文件中SQL語句的id要和mapper接口中的方法名一致
*
* 表--實(shí)體類--mapper接口--映射文件
*/
/**
* 添加用戶信息
*/
int insertUser();
/**
* 修改用戶信息
*/
void updateUser();
/**
* 刪除用戶信息
*/
void deleteUser();
/**
* 根據(jù)id查詢用戶信息
*/
User getUserById();
/**
* 查詢所有的用戶信息
*/
List<User> getAllUser();
}
2.6 創(chuàng)建MyBatis的映射文件
相關(guān)概念
:ORM(Object Relationship Mapping)對(duì)象關(guān)系映射本今。
對(duì)象
:Java的實(shí)體類對(duì)象
關(guān)系
:關(guān)系型數(shù)據(jù)庫
映射
:二者之間的對(duì)應(yīng)關(guān)系
Java概念 | 數(shù)據(jù)庫概念 |
---|---|
類 | 表 |
屬性 | 字段/列 |
對(duì)象 | 記錄/行 |
-
映射文件的命名規(guī)則:
表所對(duì)應(yīng)的實(shí)體類的類名+Mapper.xml
例如:表litemall_user,映射的實(shí)體類為User挪凑,所對(duì)應(yīng)的映射文件為UserMapper.xml
因此一個(gè)映射文件對(duì)應(yīng)一個(gè)實(shí)體類,對(duì)應(yīng)一張表的操作
MyBatis映射文件用于編寫SQL搞旭,訪問以及操作表中的數(shù)據(jù)
MyBatis映射文件存放的位置是src/main/resources/mappers目錄下 -
MyBatis中可以面向接口操作數(shù)據(jù)菇绵,要保證兩個(gè)一致:
a>mapper接口的全類名和映射文件的命名空間(namespace)保持一致
b>mapper接口中方法的方法名和映射文件中編寫SQL的標(biāo)簽的id屬性保持一致
<?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.mybatis.mapper.UserMapper">
<insert id="insertUser">
insert into litemall.litemall_user(id, username, password, mobile) values(null,'張三','123456','15197289663')
</insert>
<update id="updateUser">
update litemall.litemall_user set username = '張三' where id = 4
</update>
<delete id="deleteUser">
delete from litemall.litemall_user where id = 2
</delete>
<!--
查詢功能的標(biāo)簽必須設(shè)置resultType或resultMap
resultType:設(shè)置默認(rèn)的映射關(guān)系
resultMap:設(shè)置自定義的映射關(guān)系
-->
<select id="getUserById" resultType="com.mybatis.entity.User">
select * from litemall.litemall_user where id = 3
</select>
<select id="getAllUser" resultType="com.mybatis.entity.User">
select * from litemall.litemall_user
</select>
</mapper>
2.7配置日志打印
添加log4j依賴
<!-- log4j日志 -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
創(chuàng)建log4j.xml配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
<param name="Encoding" value="UTF-8" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS} %m (%F:%L) \n" />
</layout>
</appender>
<logger name="java.sql">
<level value="debug" />
</logger>
<logger name="org.apache.ibatis">
<level value="info" />
</logger>
<root>
<level value="debug" />
<appender-ref ref="STDOUT" />
</root>
</log4j:configuration>
2.8 通過junit測(cè)試功能
package com.mybatis;
import com.mybatis.mapper.UserMapper;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
/**
* @Author 211145187
* @Date 2023/4/17 22:56
**/
public class MyBatisTest {
/**
* SqlSession默認(rèn)不自動(dòng)提交事務(wù)脸甘,若需要自動(dòng)提交事務(wù)
* 可以使用SqlSessionFactory.openSession(true);
*/
//測(cè)試插入
@Test
public void testMyBatisInsert() throws IOException {
//加載核心配置文件
InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
//獲取SqlSessionFactoryBuilder對(duì)象
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
//通過核心配置文件所對(duì)應(yīng)的字節(jié)輸入流創(chuàng)建工廠類SqlSessionFactory,生產(chǎn)SqlSession對(duì)象
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
//創(chuàng)建SqlSession對(duì)象钝的,此時(shí)通過SqlSession對(duì)象所操作的sql都會(huì)自動(dòng)提交铆遭,默認(rèn)openSession中形參為false
SqlSession sqlSession = sqlSessionFactory.openSession(true);
//通過代理模式創(chuàng)建UserMapper接口的代理實(shí)現(xiàn)類對(duì)象
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
//測(cè)試功能
int result = mapper.insertUser();
//提交事務(wù)
//sqlSession.commit();
System.out.println("result:"+result);
}
//測(cè)試【修改、刪除枚荣、單條查詢、集合查詢】
@Test
public void testMyBatisCRUD() throws IOException {
InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
SqlSession sqlSession = sqlSessionFactory.openSession(true);
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
//更新
// mapper.updateUser();
//刪除
// mapper.deleteUser();
//單條查詢
// User user = mapper.getUserById();
// System.out.println(user);
//集合查詢
// List<User> userList = mapper.getAllUser();
// userList.forEach(user -> System.out.println(user));
}
}
SqlSession:代表Java程序和數(shù)據(jù)庫之間的會(huì)話衙伶。(HttpSession是Java程序和瀏覽器之間的
會(huì)話)SqlSessionFactory:是“生產(chǎn)”SqlSession的“工廠”害碾。
工廠模式:如果創(chuàng)建某一個(gè)對(duì)象,使用的過程基本固定慌随,那么我們就可以把創(chuàng)建這個(gè)對(duì)象的
相關(guān)代碼封裝到一個(gè)“工廠類”中,以后都使用這個(gè)工廠類來“生產(chǎn)”我們需要的對(duì)象丸逸。
本人其他相關(guān)文章鏈接
1.一剃袍、MyBatis簡(jiǎn)介:MyBatis歷史、MyBatis特性民效、和其它持久化層技術(shù)對(duì)比、Mybatis下載依賴包流程
2.二埋同、搭建MyBatis采用xml方式棵红,驗(yàn)證CRUD(增刪改查操作)
3.三逆甜、MyBatis核心配置文件詳解
4.四交煞、MyBatis獲取參數(shù)值的兩種方式(重點(diǎn))
5.五素征、MyBatis的增刪改查模板(參數(shù)形式包括:String御毅、對(duì)象、集合凤粗、數(shù)組、Map)
6.六嫌拣、MyBatis特殊的SQL:模糊查詢呆躲、動(dòng)態(tài)設(shè)置表名、校驗(yàn)名稱唯一性
7.七歼秽、MyBatis自定義映射resultMap
8.八、(了解即可)MyBatis懶加載(或者叫延遲加載)
9.九箩祥、MyBatis動(dòng)態(tài)SQL
10.十肆氓、MyBatis的緩存
11.十一、MyBatis的逆向工程
12.十二谢揪、MyBatis分頁插件