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

相关文章

来自专栏nnngu

01 Mybatis 的配置和使用

一、Mybatis 是什么 ? MyBatis 是一个支持普通SQL查询、存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的 JDBC 代码和...

2649
来自专栏用户2442861的专栏

MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

http://www.cnblogs.com/xdp-gacl/p/4262895.html

522
来自专栏LanceToBigData

Mybatis(二)基于注解的入门实例

上一篇简单的介绍了Mybatis的概念和基于XML来实现数据库的CRUD,这篇给大家实现基于注解的CRUD。

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

MyBatis入门

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

611
来自专栏哈雷彗星撞地球

iOS CoreBluetooth 的使用讲解概念分析代码实战

最近研究了iOS下连接蓝牙打印机,实现打印购物小票的功能,对iOS中BLE 4.0的使用有了一定的了解,这里记录一下对BLE 4.0的理解。 由于很多文章同时...

963
来自专栏余林丰

MyBatis3入门

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

1865
来自专栏wblearn

MyBatis入门学习

一、Mybatis简介 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置...

903
来自专栏一枝花算不算浪漫

MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

34210
来自专栏企鹅号快讯

优秀的持久层框架-Mybatis框架解析

Topic Mybatis步骤 mybatis解决原生态jdbc的问题 数据库连接,使用时连接,不使用时释放,对数据库进行频繁连接的开启和关闭,造成数据库资源浪...

1849
来自专栏Java技术栈

Druid-目前最好的连接池

Druid是什么 Druid是阿里开源的连接池,是Java语言中最好的数据库连接池.Druid能够提供强大的监控和扩展功能,是为监控而生的数据库连接池! Git...

35117

扫码关注云+社区