All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.kawanfw.sql.util.parser.SqlCommentsDetector Maven / Gradle / Ivy

Go to download

AceQL HTTP is a framework of REST like http APIs that allow to access to remote SQL databases over http from any device that supports http. AceQL HTTP is provided with four client SDK: - The AceQL C# Client SDK allows to wrap the HTTP APIs using Microsoft SQL Server like calls in their code, just like they would for a local database. - The AceQL Java Client SDK allows to wrap the HTTP APIs using JDBC calls in their code, just like they would for a local database. - The AceQL Python Client SDK allows SQL calls to be encoded with standard unmodified DB-API 2.0 syntax

There is a newer version: 12.2
Show newest version
/*
 * Copyright (c)2022 KawanSoft S.A.S. All rights reserved.
 * 
 * Use of this software is governed by the Business Source License included
 * in the LICENSE.TXT file in the project's root directory.
 *
 * Change Date: 2026-11-01
 *
 * On the date above, in accordance with the Business Source License, use
 * of this software will be governed by version 2.0 of the Apache License.
 */
package org.kawanfw.sql.util.parser;

import java.util.regex.Pattern;

import org.apache.commons.lang3.StringUtils;

/**
 * Detects if sql statement part without values in quotes has comments
 * @author Nicolas de Pomereu
 *
 */
public class SqlCommentsDetector {

    private static Pattern commentPattern = Pattern.compile("/\\*.*?\\*/", Pattern.DOTALL);
    
    private String sql;

    private boolean withComments;

    public SqlCommentsDetector(String sql) {
	this.sql = sql;
    }
    
    /**
     * @return true if the SQL statement part contains comments
     */
    public boolean isWithComments() {
        return withComments;
    }

    /**
     * Remove the comments from the statement part
     * @return statement part without comments
     */
    public String removeComments() {
	// 1) Surrounds /* and */ with spaces
	sql = StringUtils.replace(sql, "/*", " /* ");
	sql = StringUtils.replace(sql, "*/", " */ ");
	
	// 2) Remvoe then 
	final String sqlOut = commentPattern.matcher(sql).replaceAll("");
	
	this.withComments = sql.length() == sqlOut.length() ? false:true;
	
	return sqlOut;
    }
    
   
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy