JAVA通过Map拼接SQL语句(Insert Update语句)
package com.lynch.erp.core.util;
import java.util.Map;
import org.apache.commons.collections.MapUtils;
import org.apache.commons.lang3.StringUtils;
public class SQLUtils {
/**
* 通过Map拼接Insert SQL语句
*
* @param tableName
* @param dataMap
* @return
*/
public static String genSqlInsert(String tableName, Map<String, String> dataMap) {
if(MapUtils.isEmpty(dataMap)) {
return null;
}
//生成INSERT INTO table(field1,field2) 部分
StringBuffer sbField = new StringBuffer();
//生成VALUES('value1','value2') 部分
StringBuffer sbValue = new StringBuffer();
sbField.append("INSERT INTO " + tableName.toLowerCase() + "(");
for(Map.Entry<String, String> entry : dataMap.entrySet()){
String mapKey = entry.getKey();
String mapValue = entry.getValue();
if(StringUtils.equals(mapKey, CamelUnderlineUtil.PK)) {
continue;
}
sbField.append("`" + mapKey + "`,");
sbValue.append("'" + mapValue + "',");
}
sbField = Util.deleteLastChar(sbField);
sbValue = Util.deleteLastChar(sbValue);
return sbField.toString() + ") VALUES(" + sbValue.toString() + ")";
}
/**
* 通过Map拼接Update SQL语句
*
* @param tableName
* @param operation
* @param dataMap
* @return
*/
public static String genSqlUpdate(String tableName, Map<String, String> dataMap) {
if(MapUtils.isEmpty(dataMap)) {
return null;
}
String idColumn = dataMap.get(CamelUnderlineUtil.PK);
String idValue = dataMap.get(idColumn);
StringBuffer sb = new StringBuffer();
sb.append("UPDATE "+ tableName.toLowerCase() +" SET ");
for(Map.Entry<String, String> entry : dataMap.entrySet()){
String mapKey = entry.getKey();
String mapValue = entry.getValue();
if(StringUtils.equals(mapKey, CamelUnderlineUtil.PK)) {
continue;
}
if(StringUtils.equals(mapKey.toLowerCase(), idColumn)) {
continue;
}
sb.append("`" + mapKey + "`='" + mapValue + "',");
}
sb = Util.deleteLastChar(sb);
return String.format("%s where %s='%s'", sb.toString(), idColumn, idValue);
}
}
分类:
Java后端架构
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
2017-08-24 Mysql 查看连接数,状态 最大并发数