单表的增加操作

前面我们看了如何搭建mybatis框架以及查询操作,这里我们说下如何使用mybatis进行增加用户的操作。首先是在user.xml文件中添加insert的方法。代码如下

       <!-- 添加用户 -->
<insertid="insertUser"parameterType="cn.itcast.mybatis.po.User">
insert into user(username,birthday,sex,address)
<!--这里的#{}中的值,必须和user类中的属性名称一致,建议直接粘贴过来-->
values(#{username},#{birthday},#{sex},#{address})
</insert>  

然后就是写个测试方法,代码如下:

// 添加用户信息
@Test
publicvoid testInsert() {
// 数据库会话实例
SqlSession sqlSession = null;
try {
// 创建数据库会话实例sqlSession
sqlSession = sqlSessionFactory.openSession();
// 添加用户信息
User user = new User();
user.setUsername("张小明");
user.setAddress("河南郑州");
user.setSex("1"); sqlSession.insert("test.insertUser", user);
//提交事务,这里需要手动提交
sqlSession.commit();
} catch (Exception e) {
e.printStackTrace();
} finally {
if (sqlSession != null) {
sqlSession.close();
}
}
}

注意:这里需要强调的是,由于使用的是jdbc的默认事物,mybatis会自动开启事物,但是不知道什么时候提交,所以需要手动进行事物的提交。
        有比较细心地同学可能注意到了,我们的insert语句中没有写id的值。这就要求我们的数据库是主键自增长的,但是依然有问题:我们添加进去的用户和我们的内存中的用户信息不一致——因为我们的内存中的user是没有主键的。怎么解决这个问题呢?我们需要在user.xml中尽心这些配置:

	<insert id="insertUser" parameterType="cn.itcast.pojo.User">
<!--
select LAST_INSERT_ID() mybatis函数作用是查询最后增加的数据的主键id keyProperty:将这个数据库函数查询出的数据放到传入参数的User对象的id属性中保存
order: 当前mysql函数相对于insert语句的执行顺序, 在insert前执行是before, 在insert后执行是after
resultType: keyProperty中指定的返回的id属性的类型
-->
<selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
select LAST_INSERT_ID()
</selectKey>
insert into user (username, birthday, sex, address) values(#{username}, #{birthday}, #{sex}, #{address})
</insert>

这里面的selectKey可以将数据库自动生成的主键进行返回,然后会将我们的主键自动赋值给我们的user对象,这样的话,数据库和系统内存中的数据就一致了。
          有的同学可能说,如果我不使用主键自增长,我使用uuid怎么办?这里向大家介绍下mybatis如何通过uuid生成主键。其实十分的简单,就是将我们的

select LAST_INSERT_ID()

换成

select uuid()

然后将after修改为before就可以了。代码如下:

<insert id="insertUser" parameterType="cn.itcast.mybatis.po.User">
<selectKey resultType="java.lang.String" order="BEFORE"
keyProperty="id">
select uuid()
</selectKey>
insert into user(id,username,birthday,sex,address)
values(#{id},#{username},#{birthday},#{sex},#{address})
</insert> 注意:这里使用的order是“BEFORE”

单表的删除操作

删除用户比较简单,这里就直接把我的代码贴上了

1.user.xml文件

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

2.测试代码

	@Test
publicvoidtestDelete() {
// 数据库会话实例
SqlSession sqlSession = null;
try {
// 创建数据库会话实例sqlSession
sqlSession = sqlSessionFactory.openSession();
// 删除用户
sqlSession.delete("test.deleteUserById",18);
// 提交事务
sqlSession.commit();
} catch (Exception e) {
e.printStackTrace();
} finally {
if (sqlSession != null) {
sqlSession.close();
}
}
}

单表的修改操作

修改代码比较简单,直接粘贴源代码了:

1.user.xml文件

	<updateid="updateUser"parameterType="cn.itcast.mybatis.po.User">
update user set username=#{username},birthday=#{birthday},sex=#{sex},address=#{address}
where id=#{id}
</update>

2.测试程序

	@Test
publicvoidtestUpdate() {
// 数据库会话实例
SqlSession sqlSession = null;
try {
// 创建数据库会话实例sqlSession
sqlSession = sqlSessionFactory.openSession();
// 添加用户信息
User user = new User();
user.setId(16);
user.setUsername("张小明");
user.setAddress("河南郑州");
user.setSex("1");
user.setPrice(1999.9f);
sqlSession.update("test.updateUser", user);
// 提交事务
sqlSession.commit();
 
} catch (Exception e) {
e.printStackTrace();
} finally {
if (sqlSession != null) {
sqlSession.close();
}
}
}

最新文章

  1. Sqlite 存储自定义对象
  2. Linux 自动同步服务器时间
  3. jQuery ui 框架
  4. JavaScript 一种轻量级的编程语言
  5. iOS 传值 委托(delegate)和block 对比
  6. spring ext 跨域
  7. UVALive 5009 Error Curves 三分
  8. 一步步学习NHibernate(1)&mdash;&mdash;NHibernate介绍
  9. 什么是系统,什么是算法 -- lemon OA 系统学习总结
  10. -_-#【JS】HTML5 API
  11. Java并发编程学习笔记 深入理解volatile关键字的作用
  12. DLP显示单元(威创)
  13. Hessian探究(一)Hessian与springMVC结合
  14. Nacos 发布 v0.8.0 Pre-GA版本,安全稳定上生产?
  15. AND 初识
  16. Vladik and Favorite Game CodeForces - 811D (思维+BFS+模拟+交互题)
  17. Linux命令学习之路——变更文档拥有者:chown
  18. jquery each循环遍历完再执行的方法 因为each是异步的 所以要加计数器.
  19. import 与 import static
  20. clipboard.js复制文字

热门文章

  1. LINUX系统一一CentOS6.5之tomcat安装
  2. spring boot 集成Thymeleaf
  3. centos 安装mysql数据库
  4. Python基础学习Day5 字典的增、删、改、查的用法 分别赋值
  5. Beanutils.copyProperties( )的使用与优化
  6. godep 包管理
  7. enum-枚举当做key-value业务使用
  8. .net 代理类(WebService代理类的详解 )
  9. Pandas基本功能之算术运算、排序和排名
  10. 665. Non-decreasing Array