zoukankan      html  css  js  c++  java
  • MyBatis应用记录:MyBatis如何得到插入数据之后的主键值、嵌套结果与嵌套查询2种方式

    一、MyBatis如何得到插入数据之后的主键值

    1、第一种:数据库设置主键自增机制。

      userMapper.xml 文件中定义:

      <!-- 向 user 表插入一条数据 -->
        <insert id="insertUser" parameterType="com.ys.po.User">
            <!-- 将插入的数据主键返回到 user 对象中
                 keyProperty:将查询到的主键设置到parameterType 指定到对象的那个属性
                 select LAST_INSERT_ID():查询上一次执行insert 操作返回的主键id值,只适用于自增主键
                 resultType:指定 select LAST_INSERT_ID() 的结果类型
                 order:AFTER,相对于 select LAST_INSERT_ID()操作的顺序
             -->
            <selectKey keyProperty="id" resultType="int" order="AFTER">
                select LAST_INSERT_ID()
            </selectKey>
            insert into user(username,sex,birthday,address)
                value(#{username},#{sex},#{birthday},#{address})
        </insert>

    2、第二种:非自增主键机制

      <!-- 向 user 表插入一条数据 -->
        <insert id="insertUser" parameterType="com.ys.po.User">
            <!-- 将插入的数据主键返回到 user 对象中
            流程是:首先通过 select UUID()得到主键值,然后设置到 user 对象的id中,在进行 insert 操作
                 keyProperty:将查询到的主键设置到parameterType 指定到对象的那个属性
                 select UUID():得到主键的id值,注意这里是字符串
                 resultType:指定 select UUID() 的结果类型
                 order:BEFORE,相对于 select UUID()操作的顺序
             -->
            <selectKey keyProperty="id" resultType="String" order="BEFORE">
                select UUID()
            </selectKey>
            insert into user(id,username,sex,birthday,address)
                value(#{id},#{username},#{sex},#{birthday},#{address})
        </insert>

    二、嵌套结果与嵌套查询2种方式

    -- 方式一:嵌套结果
    select * from orders o,user u where o.user_id=u.id and o.id=#{id}
    
    -- 方式二:嵌套查询
    select * from order WHERE id=1;  -- 得到user_id
    select * from user WHERE id=1   -- 1 是上一个查询得到的user_id的值
    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE mapper
      PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
      "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <mapper namespace="one.to.one.mapper.OrdersMapper">
        <!--
        方式一:嵌套结果:使用嵌套结果映射来处理重复的联合结果的子集封装联表查询的数据(去除重复的数据)
         select * from orders o,user u where o.user_id=u.id and o.id=#{id}
         -->
        <select id="selectOrderAndUserByOrderID" resultMap="getOrderAndUser">
            select * from orders o,user u where o.user_id=u.id and o.id=#{id}
        </select>
        <resultMap type="com.ys.po.Orders" id="getOrderAndUser">
            <!--
                id:指定查询列表唯一标识,如果有多个唯一标识,则配置多个id
                column:数据库对应的列
                property:实体类对应的属性名
              -->
            <id column="id" property="id"/>
            <result column="user_id" property="userId"/>
            <result column="number" property="number"/>
            <!--association:用于映射关联查询单个对象的信息
                property:实体类对应的属性名
                javaType:实体类对应的全类名
              -->
            <association property="user" javaType="com.ys.po.User">
                <!--
                    id:指定查询列表唯一标识,如果有多个唯一标识,则配置多个id
                    column:数据库对应的列
                    property:实体类对应的属性名
                  -->
                <id column="id" property="id"/>
                <result column="username" property="username"/>
                <result column="sex" property="sex"/>
            </association>
        </resultMap>
         
         
        <!-- 方式二:嵌套查询:通过执行另外一个SQL映射语句来返回预期的复杂类型
             select user_id from order WHERE id=1;//得到user_id
             select * from user WHERE id=1   //1 是上一个查询得到的user_id的值
             property:别名(属性名)    column:列名 -->
        <select id="getOrderByOrderId" resultMap="getOrderMap">
            select * from order where id=#{id}
        </select>
        <resultMap type="com.ys.po.Orders" id="getOrderMap">
            <id column="id" property="id"/>
            <result column="number" property="number"/>
            <association property="userId"  column="id" select="getUserByUserId">
            </association>
        </resultMap>
        <select id="getUserByUserId" resultType="com.ys.po.User">
            select * from user where id=#{id}
        </select>
         
    </mapper>
  • 相关阅读:
    DJANGO-天天生鲜项目从0到1-011-订单-订单提交和创建
    DJANGO-天天生鲜项目从0到1-010-购物车-购物车操作页面(勾选+删改)
    DJANGO-天天生鲜项目从0到1-009-购物车-Ajax实现添加至购物车功能
    DJANGO-天天生鲜项目从0到1-009-搜索功能实现(django-haystack+whoosh+jieba)
    DJANGO-天天生鲜项目从0到1-008-列表页
    lombok 注解
    java 枚举
    Java反射的理解(六)-- 通过反射了解集合泛型的本质
    Java反射理解(五)-- 方法反射的基本操作
    Java反射理解(四)-- 获取成员变量构造函数信息
  • 原文地址:https://www.cnblogs.com/goloving/p/14854772.html
Copyright © 2011-2022 走看看