SqlUtils工具类mysql和oracle的java通用新增和更新sql

SqlUtils工具类
低代码平台可能会用的比较多一点
主要用于mysql和oracle的通用新增和更新
primaryKey 未主键key



import org.junit.Test;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.StringJoiner;

/**
 * @Classname SqlUtils
 * @Description TODO
 * @Date 2022/12/8 13:48
 * @Created by XiongXiong
 * @Author: X.I.O
 */
public class SqlUtils {



        private static String insertSqlOracle(String tableName,Map<String,Object> map){
                StringBuilder stringBuilder=new StringBuilder();
                StringJoiner field=new StringJoiner(",","(",")");
                StringJoiner value=new StringJoiner(",","(",")");
                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                for (Map.Entry< String,Object> entry : map.entrySet()) {
                        String key=entry.getKey();
                        Object val=entry.getValue();
                        if(val==null || "".equals(val)){
                                continue;
                        }
                        field.add(key);
                        if(val instanceof Date){
                                Date date = (Date) val;
                                val="to_date('"+sdf.format(date)+"' , 'yyyy-mm-dd hh24:mi:ss')";
                                value.add(String.valueOf(val));
                        }else {
                                val="'"+val+"'";
                                value.add(String.valueOf(val));
                        }

                }
                stringBuilder.append("insert into ").append(tableName).append(" ").append(field.toString()).append(" VALUES ").append(value.toString());
                String sql=stringBuilder.toString();
                return sql;
        }

		
        private static String updateSqlOracle(String tableName,String primaryKey,Map<String,Object> map){
                StringBuilder sb = new StringBuilder();
                StringJoiner stringJoiner=new StringJoiner(",");
                sb.append("UPDATE ").append(tableName).append(" SET ");
                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                for (Map.Entry< String,Object> entry : map.entrySet()){
                        String key = entry.getKey();
                        Object value = entry.getValue();
                        if(key.equals(primaryKey)){
                                continue;
                        }
                        if(value==null){
                                continue;
                        }
                        if("".equals(value)){
                                continue;
                        }
                        if(value instanceof Date){
                                Date date = (Date) value;
                                value="to_date('"+sdf.format(date)+"' , 'yyyy-mm-dd hh24:mi:ss')";
                                stringJoiner.add("" + key + "" + "="  + value );
                        }else {
                                stringJoiner.add("" + key + "" + "=" + "'" + value + "'");
                        }
                }
                sb.append(stringJoiner.toString());
                Object primaryValue=map.get(primaryKey);
                sb.append(" WHERE ").append(primaryKey).append("=").
                        append("'").append(primaryValue).append("'");
                return sb.toString();
        }

        private static String updateSqlMySql(String tableName,String primaryKey,Map<String,Object> map){
                StringBuilder sb = new StringBuilder();
                StringJoiner stringJoiner=new StringJoiner(",");
                sb.append("UPDATE ").append("`").append(tableName).append("`").append(" SET ");
                for (Map.Entry< String,Object> entry : map.entrySet()){
                        String key = entry.getKey();
                        Object value = entry.getValue();
                        if(key.equals(primaryKey)){
                                continue;
                        }
                        if(value==null){
                                continue;
                        }
                        if("".equals(value)){
                                continue;
                        }
                        if(value instanceof Date){
                                SimpleDateFormat dft=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                                Date date = (Date) value;
                                value=dft.format(date);
                        }
                        stringJoiner.add("`" + key + "`" + "=" + "'" + value + "'");
                }
                sb.append(stringJoiner.toString());
                Object primaryValue=map.get(primaryKey);
                sb.append(" WHERE ").append("`").append(primaryKey).append("`").append("=").
                        append("'").append(primaryValue).append("'");
                return sb.toString();
        }

        private static String insertSqlMySql(String tableName, Map<String,Object> map){
                StringBuilder stringBuilder=new StringBuilder();
                StringJoiner field=new StringJoiner("`,`","(`","`)");
                StringJoiner value=new StringJoiner("','","('","')");
                for (Map.Entry< String,Object> entry : map.entrySet()) {
                        String key=entry.getKey();
                        Object val=entry.getValue();
                        if(val==null || "".equals(val)){
                                continue;
                        }
                        if(val instanceof Date){
                                Date date = (Date) val;
                                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                                val=sdf.format(date);
                        }
                        field.add(key);
                        value.add(String.valueOf(val));
                }
                stringBuilder.append("insert into ").append(tableName).append(" ").append(field.toString()).append(" VALUES ").append(value.toString());
                String sql=stringBuilder.toString();
                return sql;
        }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
package com.hexiang.utils; /** * SQLUtils utils = new SQLUtils(User.class); utils.setWhereStr("", "id", "=", 100).setWhereStr("and", "name", " ", "is null").setWhereStr("and", "date", ">=", new Date()); utils.setOrderByStr("id", "desc").setOrderByStr("name", "asc"); System.out.println(utils.buildSelectSQL()); System.out.println(utils.buildCountSQL()); */ import java.sql.Timestamp; import java.text.SimpleDateFormat; import java.util.Date; import java.util.LinkedHashMap; import java.util.LinkedList; import java.util.List; import java.util.Map; public class SqlUtils { private String beanName; private String beanShortName; private Map propertyMap; private List conditionList; private List relationList; private Map orderByMap; public SqlUtils(Class instance) { this.setBeanName(instance.getSimpleName()); this.setBeanShortName(Character.toLowerCase(this.getBeanName() .charAt(0)) + ""); init(); } public SqlUtils() { init(); } void init(){ propertyMap = new LinkedHashMap(); conditionList = new LinkedList(); relationList = new LinkedList(); orderByMap = new LinkedHashMap(); } /** * 添加查询条件 * * @param relation * 关联 "and","or"等 * @param property * 查询的对象属性 * @param condition * 查询的条件,关系符 * @param value * 查询的值 */ public SqlUtils setWhereStr(String relation, String property, String condition, Object value) { if(value != null){ relationList.add(relation); propertyMap.put(property, value); conditionList.add(condition); } return this; } private String buildWhereStr() { StringBuffer buffer = new StringBuffer(); if (!propertyMap.isEmpty() && propertyMap.size() > 0) { buffer.append("WHERE 1 = 1 "); int index = 0; for (String property : propertyMap.keySet()) { if (property != null && !property.equals("")) { buffer.append(r

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值