hao947 : Mybatis resultMap配置插入和主键自增返回 : 好947

时间:2021-12-03 23:57:09

映射配置文件  好947

 <!-- type:映射实体类的数据类型 id:resultMap的唯一标识 -->
 <resultMap type="person" id="BaseResultMap">
  <!-- column:库表的字段名 property:实体类里的属性名 -->
  <id column="person_id" property="personId" />
  <result column="name" property="name" />
  <result column="gender" property="gender" />
  <result column="person_addr" property="personAddr" />
  <result column="birthday" property="birthday" />
 </resultMap>

映射配置查询语句  好947

<insert id="insert" parameterType="com.hao947.model.Person">
  <!--
  keyProperty:实体类中的id属性名,当返回主键的时候就是返回给keyProperty
  order:生成主键和运行insert语句的顺序,在mysql是AFTER,在oracle中使用BEFORE
  resultType:主键返回的数据类型,和实体类中的主键的类型一致
  select LAST_INSERT_ID():mysql中生成主键的sql,oracle中select xxxx.nextval from dual
   -->
  <selectKey keyProperty="personId" order="AFTER" resultType="java.lang.Integer">
   select last_insert_id();
  </selectKey>
  insert into person (person_id, name, gender, person_addr, birthday)
  values(#{personId}, #{name}, #{gender}, #{personAddr}, #{birthday})
 </insert>

映射管理库表文件  hao947

<!-- 集中管理库表的映射文件 -->
 <mappers>
  <mapper resource="com/hao947/sql/mapper/PersonMapper.xml" />
 </mappers>

測试文件  hao947

@Test
 public void insert() {
  SqlSession session = sqlSessionFactory.openSession();
  try {
   Person p = new Person();
  // p.setPersonId(3);
   p.setName("架构师");
   p.setGender(1);
   p.setPersonAddr("北京");
   p.setBirthday(new SimpleDateFormat("yyyy-MM-dd").parse("1985-03-14"));
   session.insert("com.hao947.sql.mapper.PersonMapper.insert", p);
   //运行完库表变更必需要提交事务
   session.commit();
  } catch (ParseException e) {
   session.rollback();
   e.printStackTrace();
  } finally{
   session.close();
  }
 }

大站喜欢採集:那就都採集吧! 好947:出品

hao947 : Mybatis resultMap配置插入和主键自增返回 : 好947的更多相关文章

  1. mybatis获取批量插入的主键自增id

    一.写一个实体类 public class UserInfo { private long userId; private String userAccount; private String use ...

  2. mybatis 注解方式插入,主键由uuid函数生成

    @SelectKey(keyProperty = "record.id", resultType = String.class, before = true, statement ...

  3. oracle批量插入带主键自增

    https://blog.csdn.net/qq_37630354/article/details/82792288

  4. MyBatis&plus;MySQL 返回插入的主键ID

    需求:使用MyBatis往MySQL数据库中插入一条记录后,需要返回该条记录的自增主键值. 方法:在mapper中指定keyProperty属性,示例如下: <insert id="i ...

  5. jdbc、Mybatis插入数据主键回显的实现方法

    插入数据的时候,往往需要获取主键值.但是有时候主键是自增长的那么,就不太适用手动添加主键值了,此时需要一种可以回显主键参数的方法, 下面以jdbc.mybatis的实现举例 此时使用的是jdbc的话或 ...

  6. &lpar;转&rpar;MyBatis&plus;MySQL 返回插入的主键ID

    MyBatis+MySQL 返回插入的主键ID 需求:使用MyBatis往MySQL数据库中插入一条记录后,需要返回该条记录的自增主键值. 方法:在mapper中指定keyProperty属性,示例如 ...

  7. Mybatis 返回插入的主键

    业务中,会遇到这样的问题,就是感觉返回的主键,插入作为其他表的外键. 那么问题来了,如何去实现,其实方法比较简单,这里就是重点记录下,会出现的误区. 用自动生成sql工具的话,加上下面这句话 < ...

  8. MyBatis返回插入的主键ID&lpar;Mysql数据库&rpar;

    1.Java代码: 1.1 entity类: User.java public class User { private int userId; private String userName; pr ...

  9. mybatis&plus;mysql返回插入的主键,参数只是提供部分参数

    mybatis+mysql返回插入的主键,参数只是提供部分参数 <insert id="insertByChannelIdOpenid" useGeneratedKeys=& ...

随机推荐

  1. Android Weekly Notes Issue &num;230

    Android Weekly Notes Issue #230 November 6th, 2016 Android Weekly Issue #230. Android Weekly笔记, 本期内容 ...

  2. mac

    command+R 刷新页面 command+shift+C 我的电脑 finder->应用程序 -> 实用程序 -> 终端 打开 cmd command+F3 显示桌面 comma ...

  3. Rebound-Android的弹簧动画库

    Rebound是facebook出品的一个弹簧动画库,与之对应的IOS版本有一个pop动画库,也是非常的强大给力.Facebook真是互联网企业中的楷模,开源了很多的实用开源库,大赞一个!!! 讲解R ...

  4. android UI-EditText的长度监听慎用TextWatcher

    在用户昵称的输入时,限定8个字符,本意是在输入超过8个时候,页面toast一个提示,就是下面的TextWatcher的监听,在afterTextChanged中处理. 原bug:huawei MT2- ...

  5. OpenCV手写数字字符识别&lpar;基于k近邻算法&rpar;

    摘要 本程序主要参照论文,<基于OpenCV的脱机手写字符识别技术>实现了,对于手写阿拉伯数字的识别工作.识别工作分为三大步骤:预处理,特征提取,分类识别.预处理过程主要找到图像的ROI部 ...

  6. datePicker&period;js 应用

    var calendar2 = new datePicker();calendar.init({ 'trigger': '#datetime-picker-start', /*选择器,触发弹出插件*/ ...

  7. python中map()函数用法

    map函数的原型是map(function, iterable, …),它的返回结果是一个列表. 参数function传的是一个函数名,可以是python内置的,也可以是自定义的. 参数iterabl ...

  8. 【原创】梵高油画用深度卷积神经网络迭代10万次是什么效果? A neural style of convolutional neural networks

    作为一个脱离了低级趣味的码农,春节假期闲来无事,决定做一些有意思的事情打发时间,碰巧看到这篇论文: A neural style of convolutional neural networks,译作 ...

  9. springboot2&period;1&period;3集成webservice及错误No operation was found with the name &lbrace;&period;&period;&period;&rcub;解决办法

    1.项目使用springboot 2.1.3版本,集成webservice使用的依赖如下 <parent> <groupId>org.springframework.boot& ...

  10. 【301】IDL与C&num;混合编程

    目录: 一.COM_IDL_CONNECT 1. 添加组件 2. 组件初始化 3. 功能调用 4. 数据传递 二.IDLDrawWidget组件 C# (C Sharp)是微软公司在2000年6月发布 ...