实现数据的增删改查
前面已经讲到用接口的方式编程。这种方式,要注意的一个地方就是。在 User.xml 的配置文件中,mapper namespace="com.yihaomen.mybatis.inter.IUserOperation" ,命名空间非常重要,不能有错,必须与我们定义的 package 和 接口一致。如果不一致就会出错,这一章主要在上一讲基于接口编程的基础上完成如下事情:
- 用 mybatis 查询数据,包括列表
- 用 mybatis 增加数据
- 用 mybatis 更新数据
- 用 mybatis 删除数据
查询数据,前面已经讲过简单的,主要看查询出列表的
查询出列表,也就是返回 list, 在我们这个例子中也就是 List , 这种方式返回数据,需要在 User.xml 里面配置返回的类型 resultMap, 注意不是 resultType, 而这个 resultMap 所对应的应该是我们自己配置的
1 | <!-- 为了返回list 类型而定义的returnMap --> |
查询列表的语句在 User.xml 中
1 | <!-- 返回list 的select 语句,注意 resultMap 的值是指向前面定义好的 --> |
在 IUserOperation 接口中增加方法:public List selectUsers(String userName);
现在在 Test 类中做测试
1 | public void getUserList(String userName){ |
现在在 main 方法中可以测试:
1 | public static void main(String[] args) { |
可以看到,结果成功查询出来。如果是查询单个数据的话,用第二讲用过的方法就可以了。
用 mybatis 增加数据
在 IUserOperation 接口中增加方法:public void addUser(User user);
在 User.xml 中配置
1 | <!--执行增加操作的SQL语句。id和parameterType |
然后在 Test 中写测试方法:
1 | /** |
用 mybatis 更新数据
方法类似,先在 IUserOperation 中增加方法:public void addUser(User user);
然后配置 User.xml
1 | <update id="updateUser" parameterType="User" > |
Test 类总的测试方法如下:
1 | public void updateUser(){ |
用 mybatis 删除数据
同理,IUserOperation 增加方法:public void deleteUser(int id);
配置 User.xml
1 | <delete id="deleteUser" parameterType="int"> |
然后在 Test 类中写测试方法:
1 | /** |
这样,所有增删改查都完成了,注意在增加,更改,删除的时候要调用 session.commit(),这样才会真正对数据库进行操作,否则是没有提交的。
