1.mybatis传入map参数,map中包含list:

List<FukaModel> fukaModels = price.getSchemaPrice().getFukaList();

Map<String, Object> objectMap = new HashMap<>();

objectMap.put("schemaId", schemaId);

objectMap.put("list", fukaModels);

sqlSession.insert("cn.jj.mall.service.store.insertFukaData",objectMap);

<select id="insertFukaData" parameterType="map" >

<foreach collection="list" item="item" index="index" open="" separator=";" close="">

INSERT INTO jj_fokas_deduct (price_schema_id,min_num, max_num, user_grade)

VALUES (#{schemaId},0,#{item.num},#{item.userGrade})

</foreach>

</select>

2.

List<JjActivityRecommendSku> activityRecommendSkuList = new ArrayList<>();

sqlSession.insert("cn.jj.mall.service.insertActivityRecommendSkuList", activityRecommendSkuList);

<insert id="insertActivityRecommendSkuList" parameterType="cn.jj.mall.model.JjActivityRecommendSku" >

insert into jj_shop.jj_activity_recommend_sku (rec_sku_id, activity_id, sku_id,

sku_sort_order)

values

<foreach collection="list" item="item" index="index" separator=",">

(#{item.recSkuId,jdbcType=INTEGER}, #{item.activityId,jdbcType=INTEGER}, #{item.skuId,jdbcType=VARCHAR},

#{item.skuSortOrder,jdbcType=INTEGER})

</foreach>

</insert>

3.

<update id="unShelveGoodsSku" parameterType="java.util.List">

update jj_shop.jj_goods_sku set status = 5 where status = 4 and sku_id in

<foreach item="item" index="index" collection="list"

open="(" separator="," close=")">

#{item}

</foreach>

</update>

4.

List<String> skuIds = s.selectList(statement,param);

Map<String, Object> map = new HashMap<>();

map.put("storeId",storeId);

map.put("devType",devType);

map.put("list",skuIds);

WHERE SkuId In

<foreach item="sku_id" collection="list" index="index" open="(" separator="," close=")">

#{sku_id}

</foreach>

5.lambda表达式

currencyDataListTemp.stream().collect(Collectors.groupingBy(o-> new CurrencyData(o.getCurrencyDtID(),o.getCurrencyAtID(),o.getCurrencyOriID(),o.getCurrencyName()),Collectors.summingInt(o->o.getReturnAmount()))).forEach((k,v)->{

k.setReturnAmount(v);

currencyDataList.add(k);

});

重写CurrencyData的hash和equals方法:

@Override

public boolean equals(Object o) {

if (this == o) return true;

if (o == null || getClass() != o.getClass()) return false;

CurrencyData currencyData = (CurrencyData) o;

return Objects.equals(currencyDtID, currencyData.currencyDtID) &&

Objects.equals(currencyAtID, currencyData.currencyAtID) &&

Objects.equals(currencyOriID, currencyData.currencyOriID) &&

Objects.equals(currencyName, currencyData.currencyName) &&

Objects.equals(returnAmount, currencyData.returnAmount);

}

@Override

public int hashCode() {

return Objects.hash(currencyDtID, currencyAtID, currencyOriID,currencyName);

}

6.

public static <T>List<T> checkListRepeat(List<T> list) {

return list.stream()

.collect(Collectors.toMap(k -> k, v -> 1, (a, b) -> a + b))

.entrySet().stream()

.filter(entry -> entry.getValue() > 1)

.map(Map.Entry::getKey)

.collect(Collectors.toList());

}

7.

List<Test> list = new ArrayList<>();

//        list.add(new Test("一年级二班", "小明"));

list.add(new Test("一年级二班啊", "小芳"));

list.add(new Test("一年级二班", "小华"));

list.add(new Test("一年级三班啊", "翠花"));

list.add(new Test("一年级三班", "香兰"));

// 集合中对象属性转map

Map<String, String> map = list.stream().collect(Collectors.toMap(Test :: getClassName, Test :: getStudentName));

8.

double sumRate = lotteryProbList.stream().mapToDouble(Double::doubleValue).sum();

9.

Map<String, List<CommodityInfo>> listMap = commodityInfoList.stream().collect(Collectors.groupingBy(model -> model.getCommodityId()));

Mybatis工作原理

mybatis查询foreach使用的更多相关文章

  1. MyBatis的foreach查询(List、Array、Map)

    mybatis 中 foreach collection的三种用法 foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合. foreach元素的属性主要有 item,index ...

  2. mybatis中foreach的用法(转)

    foreach一共有三种类型,分别为List,[](array),Map三种. foreach属性 属性 描述 item 循环体中的具体对象.支持属性的点路径访问,如item.age,item.inf ...

  3. mybatis 查询 xml list参数

    mybatis 查询 xml list参数: <select id="getByIds" resultType="string" parameterTyp ...

  4. mybatis之foreach用法

    在做mybatis的mapper.xml文件的时候,我们时常用到这样的情况:动态生成sql语句的查询条件,这个时候我们就可以用mybatis的foreach了 foreach元素的属性主要有item, ...

  5. mybatis的foreach写用法

    一.mybatis查询 public abstract List<Model> findByIds(@Param("ids")List<Integer> i ...

  6. MySQL和mybatis查询相关

    0.mybatis的xml文件头 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapp ...

  7. mybatis map foreach遍历

    mybatis map foreach遍历 转至http://www.cnblogs.com/yg_zhang/p/4314602.html mybatis 遍历map实例 map 数据如下 Map& ...

  8. MyBatis 查询映射自定义枚举

    背景                  MyBatis查询若想映射枚举类型,则需要从 EnumTypeHandler 或者 EnumOrdinalTypeHandler 中选一个来使用         ...

  9. mybatis查询异常-Error querying database. Cause: java.lang.ClassCastException: org.apache.ibatis.executor.ExecutionPlaceholder cannot be cast to java.util.List

    背景,mybatis查询的时候直接取的sqlsession,没有包装成SqlSessionTemplate,没有走spring提供的代理. 然后我写的获取sqlsession的代码没有考虑到并发的情况 ...

随机推荐

  1. PorterDuffXfermode之PorterDuff.Mode.DST_IN

    package com.loaderman.customviewdemo.view; import android.animation.ValueAnimator; import android.co ...

  2. 011-多线程-基础-基于AbstractQueuedSynchronizer自定义同步组件

    一.概述 队列同步器AbstractQueuedSynchronizer,是用来构建锁或者其他同步组件的基础框架. 1.1.自定义独占锁同步组件 设计一个同步工具:该工具在同一时刻,只允许一个线程访问 ...

  3. 42 Flutter仿京东商城项目 修改默认收货地址 显示默认收货地址

    CheckOut.dart import 'package:flutter/material.dart'; import '../services/ScreenAdapter.dart'; impor ...

  4. 编译安装python3事出错:

    configure: error: no acceptable C compiler found in $PATH 问题解决 解决方法: yum intall gcc -y

  5. idea中Lombok的Buider构造器模式,getter/setter正确使用方法

    public class ApiUser implements Serializable { private Long id; /*** * 用户类型:single,org(organization) ...

  6. (二)UML之类图、接口、包

    一.概念 类图(Class Diagram): 类图是面向对象系统建模中最常用和最重要的图,是定义其它图的基础.类图主要是用来显示系统中的类.接口以及它们之间的静态结构和关系的一种静态模型. 类图的3 ...

  7. mysql使用truncate截断带有外键的表时报错--解决方案

    报错内容如:1701 - Cannot truncate a table referenced in a foreign key constraint 一.为什么要使用truncate 使用trunc ...

  8. Javascript的原型链与继承

    目录 1. ES5最经典的寄生组合式继承图 2. ES5和ES6的继承 Javascript语言的继承机制,它没有"子类"和"父类"的概念,也没有"类 ...

  9. AWS 存储服务(三)

    目录 AWS S3 业务场景 挑战 解决方案 S3的好处 S3 属性 存储桶 Buckets 对象 Object S3 特性 S3 操作 可用性和持久性 一致性 S3 定价策略 S3高级功能 存储级别 ...

  10. Flutter easyrefresh示例 上拉加载+下拉刷新

    官方示例,简单改了下,实现功能为主. 代码如下: import 'dart:async'; import 'package:flutter/material.dart'; import 'packag ...