MyBatis快速上手增删改查
引言-絮絮叨叨
作为一个快乐的小码农,在每一个阶段往往都在重复写着不同版本的,学生管理,用户管理,注册登录,从 JavaSE 的控制台版,或者 GUI 版,再到 JavaWeb的 JSP版,再到纯粹使用 HTML 作为前端展示的版本,以及使用一个更新的技术,在此其中,我们用过 txt 做数据库,用 XML 也可以,到现在常用的 MySQL,增删改查一直是我们必不可少的一部分内容,即使你不懂原理,即使你对这个技术的理解不是很深刻,拿出你的增删改查,噼里啪啦就是一段乱敲,好歹还是能让你着手先做起来(当然,对技术的理解还是很重要的),今天就和大家聊一聊 MyBatis 这门技术的 CURD (增删改查)
优化测试方法
在测试方法中,读取配置文件,生产 SqlSession,释放资源等等,在每一测试方法的时候,都是重复的,所以我们完全可以提出出这一部分,防止大量的重复代码
@Before
public void init() throws Exception{
//读取配置文件
inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");
//创建SqlSessionFactory工厂
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(inputStream);
//使用工厂生产SqlSession对象
sqlSession= factory.openSession();
//使用SqlSession创建Mapper接口的代理对象
userMapper = sqlSession.getMapper(UserMapper.class);
}
@After
public void destroy() throws Exception{
sqlSession.close();
inputStream.close();
}
在这两个方法上增加 @Before 和 @Aftrer 注解,就可以保证,init() 和 destory() 这两个方法,分别在我们真正被测试的方法的前后执行
(一) 增添操作
(1) 编写代码
首先,在 UserMapper 接口中 增加对应的方法
public interface UserMapper {
/**
* 增加用户
* @param user
*/
void addUser(User user);
}
接着,在SQL映射文件中,增加新增的映射配置,这些有关内容放在 <insert></insert>
标签对中,具体代码如下
<insert id="addUser" parameterType="cn.ideal.domain.User">
insert into user(username,telephone,birthday,gender,address)values(#{
username},#{
telephone},#{
birthday},#{
gender},#{
address})
</insert>
(2) 说明:
1、id 属性,自然是对应的方法名,而由于这里,我们并不需要拿到返回信息,所以这里并没有返回参数 resultType,而方法中的参数又为一个 JavaBean 类,也就是User实体类,所以需要在标签属性中,添加一个 parameterType 属性,其中需要指定这个实体类
2、在文本中书写插入的SQL语句,由于实体类中已经快捷生成了对应的 get set 方法,所一可以使用 #{}
的方式代表对应的值
3、提示,数据库中id为自增,所以并不需要设置 id
<