博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mybatis 详解(三)------入门实例(基于注解)
阅读量:4338 次
发布时间:2019-06-07

本文共 2898 字,大约阅读时间需要 9 分钟。

1、创建MySQL数据库:mybatisDemo和表:user

  详情参考: 一致

 

2、建立一个Java工程,并导入相应的jar包,具体目录如下

   详情参考: 一致

 

3、在 MyBatisTest 工程中添加数据库配置文件 mybatis-configuration.xml

   详情参考: 一致

 

4、定义表所对应的实体类

   详情参考: 一致

 

5、定义操作 user 表的注解接口 UserMapper.java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
package 
com.ys.annocation;
 
import 
org.apache.ibatis.annotations.Delete;
import 
org.apache.ibatis.annotations.Insert;
import 
org.apache.ibatis.annotations.Select;
import 
org.apache.ibatis.annotations.Update;
 
import 
com.ys.po.User;
 
public 
interface 
UserMapper {
    
//根据 id 查询 user 表数据
    
@Select
(
"select * from user where id = #{id}"
)
    
public 
User selectUserById(
int 
id) 
throws 
Exception;
 
    
//向 user 表插入一条数据
    
@Insert
(
"insert into user(username,sex,birthday,address) value(#{username},#{sex},#{birthday},#{address})"
)
    
public 
void 
insertUser(User user) 
throws 
Exception;
     
    
//根据 id 修改 user 表数据
    
@Update
(
"update user set username=#{username},sex=#{sex} where id=#{id}"
)
    
public 
void 
updateUserById(User user) 
throws 
Exception;
     
    
//根据 id 删除 user 表数据
    
@Delete
(
"delete from user where id=#{id}"
)
    
public 
void 
deleteUserById(
int 
id) 
throws 
Exception;
     
}

  

 

6、向 mybatis-configuration.xml 配置文件中注册 UserMapper.java 文件

  

1
2
3
<mappers>
       
<mapper 
class
=
"com.ys.annocation.UserMapper"
/>
</mappers>

  

 

 7、创建测试类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
package 
com.ys.test;
 
import 
java.io.InputStream;
 
import 
org.apache.ibatis.session.SqlSession;
import 
org.apache.ibatis.session.SqlSessionFactory;
import 
org.apache.ibatis.session.SqlSessionFactoryBuilder;
import 
org.junit.Before;
import 
org.junit.Test;
 
import 
com.ys.annocation.UserMapper;
import 
com.ys.po.User;
 
public 
class 
UserAnnocationTest {
    
//定义 SqlSession
    
SqlSession session =
null
;
     
    
@Before
    
public 
void 
init(){
        
//定义mybatis全局配置文件
        
String resource = 
"mybatis-configuration.xml"
;
        
//加载 mybatis 全局配置文件
        
InputStream inputStream = CRUDTest.
class
.getClassLoader()
                                    
.getResourceAsStream(resource);
        
//构建sqlSession的工厂
        
SqlSessionFactory sessionFactory = 
new 
SqlSessionFactoryBuilder().build(inputStream);
        
//根据 sqlSessionFactory 产生 session
        
session = sessionFactory.openSession();
    
}
     
    
//注解的增删改查方法测试
    
@Test
    
public 
void 
testAnncationCRUD() 
throws 
Exception{
        
//根据session获取 UserMapper接口
        
UserMapper userMapper = session.getMapper(UserMapper.
class
);
        
//调用selectUserById()方法
        
User user = userMapper.selectUserById(
1
);
        
System.out.println(user);
         
        
//调用  insertUser() 方法
        
User user1 = 
new 
User();
        
user1.setUsername(
"aliks"
);
        
user1.setSex(
"不详"
);
        
userMapper.insertUser(user1);
         
        
//调用 updateUserById() 方法
        
User user2 = 
new 
User();
        
user2.setId(
6
);
        
user2.setUsername(
"lbj"
);
        
userMapper.updateUserById(user2);
         
        
//调用 () 方法
        
userMapper.deleteUserById(
6
);
         
        
session.commit();
        
session.close();
    
}
}

 

注意:注解配置我们不需要 userMapper.xml 文件了  

转载于:https://www.cnblogs.com/wojiaochuichui/p/8623701.html

你可能感兴趣的文章
小D课堂 - 零基础入门SpringBoot2.X到实战_第4节 Springboot2.0单元测试进阶实战和自定义异常处理_21、SpringBoot2.x配置全局异常返回自定义页面...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第8节 数据库操作之整合Mybaties和事务讲解_32..SpringBoot2.x持久化数据方式介绍...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第8节 数据库操作之整合Mybaties和事务讲解_34、SpringBoot整合Mybatis实操和打印SQL语句...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第8节 数据库操作之整合Mybaties和事务讲解_35、事务介绍和常见的隔离级别,传播行为...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第9节 SpringBoot2.x整合Redis实战_40、Redis工具类封装讲解和实战...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第9节 SpringBoot2.x整合Redis实战_37、分布式缓存Redis介绍...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第10节 SpringBoot整合定时任务和异步任务处理_42、SpringBoot常用定时任务配置实战...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第9节 SpringBoot2.x整合Redis实战_39、SpringBoot2.x整合redis实战讲解...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第14节 高级篇幅之SpringBoot多环境配置_59、SpringBoot多环境配置介绍和项目实战...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第10节 SpringBoot整合定时任务和异步任务处理_41、SpringBoot定时任务schedule讲解...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第10节 SpringBoot整合定时任务和异步任务处理_43、SpringBoot2.x异步任务实战(核心知识)...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_1_01课程简介
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第11节 Logback日志框架介绍和SpringBoot整合实战_45、SpringBoot2.x日志讲解和Logback配置实战...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_1_02技术选型
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_汇总
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_2_01传统架构演进到分布式架构
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_2_02 微服务核心基础讲解
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_2_04微服务下电商项目基础模块设计...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_3-03CAP原理、常见面试题
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_3-05 服务注册和发现Eureka Server搭建实战...
查看>>