1.MyBatis实现新增数据
1. MyBaits在 mapper.xml 中提供<insert>标签,标签没有返回值类型
<insert id="ins" parameterType="People">
insert into people values(default,#{name},#{age})
</insert>
2.通过 session.insert()调用新增方法
int index1 = session.insert("a.b.ins", p);
if(index1>0){
System.out.println("成功");
}else{
System.out.println("失败");
}
2.MyBatis实现修改
1.在 mapper.xml 中提供<update>标签
<update id="upd" parameterType="People">
update people set name = #{name} where id = #{id}
</update>
.2 编写代码
People peo = new People();
peo.setId(3);
peo.setName("王五");
int index = session.update("a.b.upd", peo);
if(index>0){
System.out.println("成功");
}else{
System.out.println("失败");
}
session.commit();
3.Mybatis实现删除
1. 在 mapper.xml 提供<delete>标签
<delete id="del" parameterType="int">
delete from people where id = #{0}
</delete>
2. 编写代码
int del = session.delete("a.b.del",3);
if(del>0){
System.out.println("成功");
}else{
System.out.println("失败");
}
session.commit();
4.事务管理
1. 在 mybatis 中默认是关闭了 JDBC 的自动提交功能
1.1 每一个 SqlSession 默认都是不自动提交事务.
1.2 session.commit()提交事务.
1.3 openSession(true);自动提交.setAutoCommit(true);
2. 在 openSession()时 Mybatis 会创建 SqlSession 时同时创建一个 Transaction(事务对象),同时 autoCommit 都为 false
2.1 如果出现异常,应该 session.rollback()回滚事务.