List<Map>转sql的Insert语句

package com.cheche365.dictonary.datatrans.datatrans.until;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

/**
 * @author sunyan
 * @date 2022/12/19 17:13
 * @description
 */
public class ObjectUntil {
    //插入数据 传进来需要插入数据库的Map类型和数据库表名
    public static String insertFromMap(List<Map<String,Object>> map, String tablename){

        //存入key的字符串数组
        ArrayList<Object> arrKey = new ArrayList<>();

        //拼接sql
        for (String key : map.get(0).keySet()) {
            arrKey.add(key);
        }

        StringBuffer strKey = new StringBuffer();
        //遍历存的key字符串数组拼接sql
        for (int j = 0; j < arrKey.size(); j++) {
            strKey.append(arrKey.get(j));
            if (j != arrKey.size() - 1) {//拼上","最后一个不拼
                strKey.append(",");
            }
        }

        String stringEntryKey = strKey.toString();

        StringBuilder sb = new StringBuilder();
        map.forEach(mapitem->{
            StringBuilder strVal = new StringBuilder();
            for (String keys : mapitem.keySet()) {
                //存入value的字符串数组
                ArrayList<Object> arrValue = new ArrayList<>();
                if(mapitem.get(keys) instanceof String){
                    mapitem.put(keys,((String) mapitem.get(keys)).replaceAll("\\\\","\\\\\\\\").replaceAll("\'","\\\\"+"\'"));
                }
                arrValue.add(mapitem.get(keys));
                //遍历存的value字符串数组拼接sql
                for (int j = 0; j < arrValue.size(); j++) {
                    if (null != arrValue.get(j) && !"".equals(arrValue.get(j))) {
                        strVal.append("'" + arrValue.get(j) + "'");//拼接单引号
                    } else if ("".equals(arrValue.get(j))) {
                        strVal.append("" + null + "");
                    } else {
                        strVal.append(arrValue.get(j));
                    }
                    strVal.append(",");

                }

            }
            String stringEntryVal = "("+strVal.substring(0,strVal.length()-1)+"),";
            sb.append(stringEntryVal);
        });

        //插入sql语句
        String sqlEntry = "INSERT INTO " + tablename + " (" + stringEntryKey + ") VALUES "+sb.substring(0,sb.length()-1)+";\n";
        //使用entityManager执行sql语句
        return sqlEntry;
    }

}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值