Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

使用MyBatis对表执行CRUD操作——基于XML的实现

1.创建(create)用户:在userMapper.xml文件中增加:

<!-- 创建用户Create -->
<insert id="addUser" parameterType="com.fpc.Entity.User">
insert into users(name,age) values(#{name},#{age})
</insert>

在测试类测试:

String statement1 = "com.fpc.Mapping.userMapper.addUser";
User user1 = new User();
user1.setName("fpc");
user1.setAge(28);
int retResult = session.insert(statement1,user1);
session.commit();
session.close();
System.out.println(retResult);

执行的结果:

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

执行之前查询数据库中的值:

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

执行完,数据库users表中的数据为:

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

2.删除(delete)用户:在userMapper.xml文件中增加:

<!--删除用户 -->
<delete id="deleteUser" parameterType="int">
delete from users where id=#{id}
</delete>

单元测试类中测试:

String statement1 = "com.fpc.Mapping.usrMapper.deleteUser";
int retResult = session.delete(statement1,3);
session.close();
System.out.println(retResult);

执行的结果,查询数据库,select * from users;得到的结果是:

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

可以看到id为3的记录已经被删除了。

3.更新(update)用户

在userMapper.xml中增加:

<!-- 更新用户 -->
<update id="updateUser" parameterType="com.fpc.Entity.User">
update users set name=#{name},age=#{age} where id=#{id}
</update>

测试类Test1中添加如下代码进行测试:

String statement1 = "com.fpc.Mapping.userMapper.updateUser";
User user = new User();
user.setId(1);
user.setName("Michiel");
user.setAge(30);
int retResult = session.delete(statement1,user);
session.commit();
// *-session.close();
System.out.println(retResult); String statement2 = "com.fpc.Mapping.userMapper.getUser";
User user2 = (User) session.selectOne(statement2,1);
System.out.println("Id: " +user2.getId() + " name : " + user2.getName() + " age: " + user2.getAge());

执行结果为:

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

使用Mybatis对表执行CRUD操作——基于注解的实现

package com.fpc.Mapping;

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.fpc.Entity.User; public interface UserMapperI {
//使用@Insert注解指明add方法要执行的SQL
@Insert("insert into users(name,age) values(#{name},#{age})")
public int add(User user); //使用@Delete注解指明deleteById方法要执行的SQL
@Delete("delete from users where id=#{id}")
public int deleteById(int id); //使用Update注解指明update方法要执行的SQL
@Update("update users set name=#{name},age=#{age} where id=#{id}")
public int update(User user); //使用Seletce注解指明getById方法要执行的SQL
@Select("select * from users where id=#{id}")
public User getById(int id);
}

需要说明的是,我们不需要针对UserMapper接口去编写具体的实现类代码,这个具体的实现类由Mybatis帮我们动态构建出来,我们只需要直接拿来使用即可。

2.在conf.xml文件中注册这个映射接口

在con.xml中添加:

<!-- 注册UserMapper映射接口 -->
<mapper class="com.fpc.Mapping.UserMapperI"></mapper>

特别注意:一开始用的jar包是mybatis-3.0.2.jar,但是运行项目是报错了,报错信息如下:

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

而lineNumber:23指的就是conf.xml中添加的接口配置文件。

经过了各种查找原因,都没效果。但是看到有篇文章提到mybatis 3.2版本以下是不支持注解的形式的。抱着试试看的态度,我将mybatis的jar包换成了mybatis-3.4.5.

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

然后再运行项目,不再报错。至于是不是必须得是3.2版本以上才支持注解的形式,这个不得而知,但3.0.3版本的mybatis是肯定不行的。

3.单元测试类代码:

创建用户:

UserMapperI mapper = session.getMapper(UserMapperI.class);
User user = new User();
user.setName("userrrrrr");
user.setAge(25);
int add = mapper.add(user);
session.close();
System.out.println(add);

运行完的结果:

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

删除用户:

UserMapperI mapper = session.getMapper(UserMapperI.class);
int delete = mapper.deleteById(4);
session.close();

运行结果,id为4的用户被删除了:

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

更新用户:

UserMapperI mapper = session.getMapper(UserMapperI.class);
User user = new User();
user.setId(1);
user.setName("Lily");
user.setAge(24);
int update = mapper.update(user);

运行结果:

Mybatis框架学习总结-使用Mybatis对表执行CRUD操作

上一篇:MyBatis学习笔记(二)——使用MyBatis对表执行CRUD操作


下一篇:Windows API 的数据类型与 Delphi 数据类型对照表