关于java运行mysql中一小段脚本

本文介绍了一种利用Java ScriptEngine来执行SQL条件判断的方法,通过解析和编译JavaScript脚本来决定SQL语句的走向。这种方法可以灵活地处理动态生成的SQL语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需要执行mysql中的一段脚本,获取具体的值.然后将这段sql拼入到sql中.

//需要执行的脚本 if('aa@sohu.com'='', 1=1, cus.buyer_email like '%aa@sohu.com%')

处理方式.
1. 先将 条件,返回结果1,返回结果2 截取出来.
2. 再将放到javascript中,运行一下.

ScriptEngine engine = new ScriptEngineManager().getEngineByName("javascript");
Compilable compilable = (Compilable) engine;
Bindings bindings = engine.createBindings(); // println(op1);
String script = "function exeSql(op1,res1,res2){ if(eval(op1)){return res1;}else{return res2;}} exeSql(op1,res1,res2);"; //定义函数并调用
CompiledScript JSFunction = compilable.compile(script); //解析编译脚本函数
bindings.put("op1","'aa@sohu.com'=='aa@sohu.com'");
bindings.put("res1", "1=1");
bindings.put("res2", "cus.buyer_email like '%aa@sohu.com%'");
Object result = JSFunction.eval(bindings);
System.out.println(result); //调用缓存着的脚本函数对象,Bindings作为参数容器传入

结果就出来了.

js中的eval作用非常大,将我传入的字符串,转化为需要执行的脚本语言了.很强大.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值