mybatis 详解(三)------入门实例(基于注解)

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

  详情参考:mybatis 详解(二)------入门实例(基于XML) 一致

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

   详情参考:mybatis 详解(二)------入门实例(基于XML) 一致

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

   详情参考:mybatis 详解(二)------入门实例(基于XML) 一致

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

   详情参考:mybatis 详解(二)------入门实例(基于XML) 一致

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

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 文件

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

7、创建测试类

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 文件了  

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Danny的专栏

【EJB学习笔记】——远程调用和本地调用

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/huyuyang6688/article/...

632
来自专栏服务端技术杂谈

Motan源码阅读--调用示例

异步调用和同步调用基本配置一样,只需要在接口类中加@MotanAsync注解,然后Client端稍作修改,server端不需要做任何修改。

893
来自专栏服务端技术杂谈

优雅的实现拦截器及统一异常处理

面向所有Controller的方法做拦截,获取Cookie信息 @Aspect@Componentpublic class HomeworkAuthorizeA...

2796
来自专栏java 成神之路

Spring mvc HandlerMapping 实现机制

2825
来自专栏面朝大海春暖花开

springMVC

1.用户发送请求至前端控制器DispatcherServlet 2.DispatcherServlet收到请求调用HandlerMapping处理器映射器。 3...

731
来自专栏大神带我来搬砖

刨根问底:Spring Boot中HandlerInterceptor没有拦截静态资源问题

2265
来自专栏java系列博客

IDEA中scope 为 provided的问题

1292
来自专栏weixuqin 的专栏

mybatis 学习笔记(四):mybatis 和 spring 的整合

在这里我们通过原始 dao 开发和,mapper 代理开发 dao 层两种方式来举例 mybatis 和 spring 整合的操作。

1032
来自专栏冷冷

Spring Boot Admin 2 值得了解的新变化

6.19号,spring团队发布了期待已久的 Spring Cloud Finchley.RELEASE 版本。 期间Spring Boot Admin 也发布...

1831
来自专栏服务端技术杂谈

spring boot整合hessian

首先添加hessian依赖 <dependency> <groupId>com.caucho</groupId> <artifactId>he...

2974

扫码关注云+社区