映射配置文件  好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+MySQL 返回插入的主键ID

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

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

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

  6. (转)MyBatis+MySQL 返回插入的主键ID

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

  7. Mybatis 返回插入的主键

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

  8. MyBatis返回插入的主键ID(Mysql数据库)

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

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

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

随机推荐

  1. java socket线程通信

    关于socket线程通信的一些知识整理 一般我们需要要让两台机子进行通信,需要创建一个Server 类,一个Client类,还需要创建一个线程类 server public class Server ...

  2. 微软新一代输入法框架 TSF - Text Service Framework 小小的研究

    实际上windows中有两套输入法框架,一套叫做imm32.一套叫做tsf,win7以后的新系统都是优先使用tsf的,现在新出的输入法基本也是基于tsf的. 你可以参考一下这篇文章,虽然是c++的代码 ...

  3. JAVA刚碰见的问题( java.lang.SecurityException: The jurisdiction policy files are not signed by a trusted signer)

    原文:刚碰见的问题 1.  failed to load the jni shared library jre bin server jvm.dll 解决:这个主要是eclipse的版本和安装的jdk ...

  4. (SQL SERVER) (ORACLE) (ACCESS)(POSTGRE SQL)四种数据库操作C#代码

    将对这四种数据库的操作封装到了2个类中可以拷贝过去直接使用. public sealed class OleDbClass { #region private utility methods & ...

  5. 高级特性(6)- 高级Swing

    6.1 列表 6.1.1 JList构件 6.1.2 列表模式 6.1.3 插入和移除值 6.1.4 值的绘制6.2 表格 6.2.1 简单表格 6.2.2 表格模型 6.2.3 对行和列的操作 6. ...

  6. 基于visual Studio2013解决C语言竞赛题之0707月份输出

     题目 解决代码及点评 /* 编一程序,打入月份号,输出该月的英文月名. 例如,输入"3",则输出"March",要求用指针数组处理. */ #includ ...

  7. Unix/Linux环境C编程新手教程(24) MySQL 5.7.4 for Red Hat Enterprise 7(RHEL7)的安装

    远观历史, MySQL的主要目的是为了可以在单处理器核心的商业服务器上执行.现在MySQL的一个变化用户可能不会注意到,那就是甲骨文已经開始又一次架构MySQL的代码,使它大量的模块化.如软件解析器, ...

  8. stm32智能小车之路之小车启动

           首先.安装完小车后最激动的还是想让他跑动,那么就開始吧.写个简单的程序測试下电机是否正常.打开keil软件新建一个project,详细简历keilproject不会的请百度.或者call ...

  9. Ch06 验证

    6.1  服务器端验证 6.1.1  Data Annotations验证 6.1.2  扩展ModelMetadtaProvider 6.2  客户端验证 6.2.1  客户端验证初步 6.2.2  ...

  10. 阿根廷探戈舞会- 一起salsa百科 - 一起salsa网 - Powered by HDWiki!

    阿根廷探戈舞会- 一起salsa百科 - 一起salsa网 - Powered by HDWiki! 阿根廷探戈舞会 编辑词条 发表评论(2)     目录 • 京城阿根廷探戈资源 • 上海阿根廷探戈 ...