Jfinal+SQLite处理 sqlite数据库执行FIND_IN_SET报错

方法一

原代码

复制代码
sql +=" and FIND_IN_SET(s.M_ID,'" + ids + "')";
修改为 sql += " where s.M_ID"+getInSql(ids);
复制代码
public static String getInSql(String ids) {
    String[] idArray = ids.split(",");
    StringBuilder sql = new StringBuilder(" IN (");
    for (int i = 0; i < idArray.length; i++) {
        // 直接将参数值添加到 SQL 片段中
        sql.append("'").append(idArray[i].trim()).append("'");
        if (i < idArray.length - 1) {
            sql.append(",");
        }
    }
    sql.append(")");
    return sql.toString();
}

缺点,FIND_IN_SET量大,需要改动多

方案二观察到Jfinal所有需要执行的sql语句会经过Sqlite3Dialect,我们在Sqlite3Dialect类中重写sql语句,判断是sqlite数据库,且是否含FIND_IN_SET,继而进行修改替换FIND_IN_SET

复制代码
@Override
public List<Record> dbFindForRecord(String sql, Object... paras) {
   /*System.out.println(sql);
   List<Record> list = Db.find(sql,paras);
   return list;*/
   String jdbcUrl = null;
   try {
      jdbcUrl = DbKit.getConfig().getDataSource().getConnection().getMetaData().getURL();
   } catch (SQLException e) {
      e.printStackTrace();
   }
   System.out.println("改动之前sql"+sql);
   if (jdbcUrl != null && jdbcUrl.contains("sqlite") && sql.contains("FIND_IN_SET")) {
      // 正则:FIND_IN_SET(\w+,\?(\d+)?\))  ->  INSTR(','||$2||',' , ','||$1||',')>0
      sql = sql.replaceAll("(?i)FIND_IN_SET\\s*\\(\\s*(\\w+)\\s*,\\s*\\?\\s*\\)",
            "INSTR(','||?||',' , ','||$1||',')>0");
   }
   System.out.println("改动之后sql"+sql);
   return Db.find(sql, paras);

},其他调用可按如上例子修改,看自己需求
相关推荐
科技小花11 分钟前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
X56611 小时前
如何在 Laravel 中正确保存嵌套动态表单数据(主服务与子服务)
jvm·数据库·python
虹科网络安全2 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_771717213 小时前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
axng pmje3 小时前
Java语法进阶
java·开发语言·jvm
小江的记录本3 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
dvjr cloi3 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
dFObBIMmai4 小时前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw04 小时前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
czlczl200209254 小时前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql