java实现增删改SQL的动态替换

28 篇文章 0 订阅
4 篇文章 0 订阅

一、根据传入的参数动态替换SQL的参数

1、需求:以新增insert语句为例

2、实现类

package test.util;

import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public  class SqlUtils{
	public static String getSavesql(String sql, Map<String, String> map) {
		StringBuffer rsql = new StringBuffer(); //接口对应的sql
		Pattern p = Pattern.compile(rge); //编译对象
		Matcher m = p.matcher(sql); //进行匹配
		int index=0;
		int length=sql.length();
		while(m.find()) {
			int start=m.start();
			String text=m.group();
			System.out.println("参数信息:"+text); //一定要先find(),然后才能group()
			if(index<start) {
				rsql.append(sql.substring(index,start));
			}
			//三元表达式 (expr1)?(expr2):(expr3) 在 expr1 求值为 true 时的值为 expr2,在 expr1 求值为 false 时的值为 expr3
			//当传入的参数等于null时,该参数对应的值为null
			rsql.append(map.get(text.substring(text.indexOf("#{")+2,text.indexOf("}")).trim())==null?null:"'"+map.get(text.substring(text.indexOf("#{")+2,text.indexOf("}")).trim())+"'");
			index=m.end();
		}
		if(index<length) {
			rsql.append(sql.substring(index,length));
		}
		System.out.println("————————————————————————————————————————————————————————————\n最终的SQL语句:"+rsql.toString());
		return rsql.toString();
	}
}

3、实现类

package test.main;

import java.util.HashMap;
import java.util.Map;

import test.util.SqlUtils;

public class TestSqL {
	public static void main(String[] args) {
		String sql="insert into user(id,name,sex,phone,createDate)values(#{id},#{name},#{sex},#{phone},#{createDate})";
		Map<String, String> map = new HashMap<>();
		map.put("id","202011030001");
		map.put("name","来福");
		map.put("sex","男");
		map.put("createDate","2020-11-30");
		String sql1 = SqlUtils.getSavesql(sql,map);
	}
	

4、控制台输出

参数信息:#{id}
参数信息:#{name}
参数信息:#{sex}
参数信息:#{phone}
参数信息:#{createDate}
————————————————————————————————————————————————————————————
最终的SQL语句:insert into user(id,name,sex,phone,createDate)values('202011030001','来福','男',null,'2020-11-30')

二、在修改语句时,如果没有传入某参数,则该参数的值为null,导致数据错误

1、情况如:修改语句中只想修改name参数,于是没有传入其他参数,导致sex、phone等参数被动修改为null

2、方案:修改前先查询该数据,并将查询结果作为参数传入修改语句

3、逻辑:修改语句中id为必传参数,此刻我们可以根据id去查询相关数据,将查询结果作为参数重新传入,根据put的相同key值会被覆盖原则,我们可以实现新值替换原有值

4、实现:需要注意的是,必须先赋值,再put新参数,根据java自上而下的执行顺序,值会被最后添加的覆盖

String sql="update user set name = #{name},sex = #{sex},phone = #{phone} where id = #{id}";
Map<String,String> map =new HashMap(); //参数
Map<String,String> obj =userDao.get(map); //根据传入的参数去查询结果(主要用到id参数)
map=obj;//将查询出来的值,作为参数,赋值给原参数对象
map.put("id","202011030002");
map.put("sex","保密");//map的put方法,遇到相同的key值会被覆盖
String sql1 = SqlUtils.getSavesql(sql,map);

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值