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 条评论
登录 后参与评论

相关文章

来自专栏余林丰

SqlSessionFactoryBuilder、SqlSessionFactory、SqlSession作用域(Scope)和生命周期

  可以说每个MyBatis都是以一个SqlSessionFactory实例为中心的。SqlSessionFactory实例可以通过SqlSessionFact...

2557
来自专栏游戏杂谈

bat与jscript开发工具时遇到的一些问题

之前使得bat调用luac进行编译时,会弹出一个“黑色的界面”,闪烁一下,感觉不太好。而脚本vbs或者jscript调用bat是可以利用Run方法,将其第二个参...

982
来自专栏Jack的Android之旅

刨解OkHttp之访问连接

因为OkHttp能讲的东西太多了,上一篇文章只是讲到了他的设计架构即责任链模式和异步多线程网络访问,这对于OkHttp只是冰山一角,对于一个网络请求框架,最重要...

1091
来自专栏微信公众号:Java团长

MyBatis入门

MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google c...

771
来自专栏Android研究院

Android组件化专题 - 路由框架原理

在路由框架之前,我们先了解什么是APT,并实践ButterKnife绑定findById的小功能。为什么先要讲解apt,因为路由的实现apt是核心的代码.看下面...

2451
来自专栏余林丰

MyBatis3入门

这里对mybatis的入门介绍以官方最新MyBatis3.4.1为准,具体文档及jar包请访问:https://github.com/mybatis/mybat...

1985
来自专栏Java技术分享圈

基于jsp+servlet的javaweb实现最基本的用户注册登陆注销功能

本案例的技术选型主要是jsp+servlet+JavaBean,采用三层架构的分层思想与MVC设计模式结合进行规范开发。

1452
来自专栏calvin

【nodejs】让nodejs像后端mvc框架(asp.net mvc)一orm篇【如EF般丝滑】typeorm介绍(8/8)

在使用nodejs开发过程中,刚好碰到需要做一个小工具,需要用到数据库存储功能。而我又比较懒,一个小功能不想搞一个nodejs项目,又搞一个后端项目。不如直接在...

2222
来自专栏hotqin888的专栏

engineercms利用pdf.js制作连续看图功能

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

1431
来自专栏Java帮帮-微信公众号-技术文章全总结

Java多线程详解5【面试+工作】

Java多线程详解【面试+工作】 Java线程:新特征-信号量 Java的信号量实际上是一个功能完毕的计数器,对控制一定资源的消费与回收有着很重要的意义,信号量...

40210

扫码关注云+社区