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

org.frameworkset.persitent.util.GloableSQLUtil Maven / Gradle / Ivy

/*
 *  Copyright 2008 biaoping.yin
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */
package org.frameworkset.persitent.util;

import com.frameworkset.common.poolman.sql.PoolManResultSetMetaData;
import com.frameworkset.common.poolman.util.JDBCPool;
import com.frameworkset.util.VariableHandler.SQLStruction;
import com.frameworkset.velocity.BBossVelocityUtil;
import org.frameworkset.cache.EdenConcurrentCache;
import org.frameworkset.cache.MissingStaticCache;
import org.frameworkset.spi.BaseApplicationContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class GloableSQLUtil extends SQLUtil {
	private static final Logger logger = LoggerFactory.getLogger(GloableSQLUtil.class);
	protected EdenConcurrentCache tplEdenConcurrentCache;
	protected MissingStaticCache tplMissingStaticCache;
	protected int maxGloableTemplateCacheSize;
	private Lock tplCacheLock = new ReentrantLock();

	GloableSQLUtil(int gloableResultMetaCacheSize,int maxGloableTemplateCacheSize,int globalKeySqlStructionCacheSize,boolean alwaysCache)
	{
		super(gloableResultMetaCacheSize,globalKeySqlStructionCacheSize,alwaysCache);
		this.maxGloableTemplateCacheSize = maxGloableTemplateCacheSize;
		if(alwaysCache) {
			tplEdenConcurrentCache = new EdenConcurrentCache(maxGloableTemplateCacheSize);
		}
		else{
			tplMissingStaticCache = new MissingStaticCache(maxGloableTemplateCacheSize);
		}
	}
	@Override
	public SQLStruction getSQLStruction(SQLInfo sqlinfo, String newsql) {
		// TODO Auto-generated method stub
		return super.getSQLStruction(sqlinfo, newsql);
	}

	@Override
	public SQLStruction getTotalsizeSQLStruction(SQLInfo totalsizesqlinfo,
			String totalsizesql) {
		// TODO Auto-generated method stub
		return super.getTotalsizeSQLStruction(totalsizesqlinfo, totalsizesql);
	}

	@Override
	public SQLInfo getSQLInfo(String dbname, String sql) {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public String getSQL(String dbname, String sql) {
		return sql;
	}

	
	public String getSQL(String dbname, String sql, Map variablevalues) {
		throw new java.lang.UnsupportedOperationException();
	}


	public String getSQL(String sql,boolean istpl,boolean multiparser, Map variablevalues) {
		SQLInfo sqlinfo = getSQLInfo(sql,istpl,multiparser);
		String newsql = null;
		newsql = _getSQL(sqlinfo,variablevalues);
		return newsql;
	}

	@Override
	public String[] getPropertyKeys() {
		throw new java.lang.UnsupportedOperationException();
	}
	public SQLInfo getSQLInfo(String sql)
	{
		return getSQLInfo( sql, false, false);
	}
    public SQLInfo getSQLInfo(String sql,boolean istpl,boolean multiparser,boolean cacheSql) {


        if(!istpl){
            SQLInfo sqlinfo = new SQLInfo(sql, sql, istpl, multiparser,cacheSql);
            sqlinfo.setSqlutil(this);
            return sqlinfo;
        }
        if(alwaysCache){
            return getAwaysCacheSQLInfo(sql,istpl,multiparser);
        }
        else{
            return getMissingCacheSQLInfo(sql,  istpl,  multiparser);
        }
    }
	public SQLInfo getSQLInfo(String sql,boolean istpl,boolean multiparser) {
		
				
			if(!istpl){
				SQLInfo sqlinfo = new SQLInfo(sql, sql, istpl, multiparser,true);
				sqlinfo.setSqlutil(this);
				return sqlinfo;
			}
			if(alwaysCache){
				return getAwaysCacheSQLInfo(sql,istpl,multiparser);
			}
			else{
				return getMissingCacheSQLInfo(sql,  istpl,  multiparser);
			}
	}

    public SQLInfo getPureSQLInfo(String sql) {


        
            SQLInfo sqlinfo = new SQLInfo( sql);
            sqlinfo.setSqlutil(this);
            return sqlinfo;
        
    }


    private SQLInfo getAwaysCacheSQLInfo(String sql,boolean istpl,boolean multiparser){
		boolean outOfSize = false;
		SQLInfo sqlinfo = tplEdenConcurrentCache.get(sql);
		if (sqlinfo == null) {
			tplCacheLock.lock();
			try {

				sqlinfo = tplEdenConcurrentCache.get(sql);
				if (sqlinfo != null)
					return sqlinfo;
				sqlinfo = sqlinfo = buildSQLInfo(  sql,  istpl,  multiparser);
				outOfSize = tplEdenConcurrentCache.put(sql, sqlinfo);

			}
			finally {
				tplCacheLock.unlock();
			}
			if(outOfSize && logger.isWarnEnabled()) {
				logWarn(  sql,  tplEdenConcurrentCache.getMaxSize());
			}

		}
		return sqlinfo;
	}
	private SQLInfo buildSQLInfo(String sql,boolean istpl,boolean multiparser){
		SQLInfo sqlinfo = new SQLInfo(sql, sql, istpl, multiparser,true);
		sqlinfo.setSqlutil(this);

		SQLTemplate sqltpl = new SQLTemplate(sqlinfo);
		sqlinfo.setSqltpl(sqltpl);
		BBossVelocityUtil.initDBTemplate(sqltpl);
		sqltpl.process();
		return sqlinfo;
	}
	private SQLInfo getMissingCacheSQLInfo(String sql,boolean istpl,boolean multiparser){

		if(tplMissingStaticCache.stopCache()){
			logWarn(  sql,  tplMissingStaticCache.getMissesMax());
			return buildSQLInfo(  sql,  istpl,  multiparser);
		}
		SQLInfo sqlinfo = tplMissingStaticCache.get(sql);
		if (sqlinfo == null) {
			tplCacheLock.lock();
			try {

				sqlinfo = tplMissingStaticCache.get(sql);
				if (sqlinfo != null)
					return sqlinfo;
				tplMissingStaticCache.increamentMissing();
				sqlinfo = buildSQLInfo(  sql,  istpl,  multiparser);
				if(!tplMissingStaticCache.stopCache()){
					tplMissingStaticCache.put(sql, sqlinfo);
				}
				else{
					if(logger.isWarnEnabled()){
						logWarn(  sql,  tplMissingStaticCache.getMissesMax());
					}
				}


			}
			finally {
				tplCacheLock.unlock();
			}


		}
		return sqlinfo;
	}
	private void logWarn(String sql,int maxSize){
		StringBuilder info = new StringBuilder();
		info.append("\r\n**********************************************************************\r\n")
				.append("*********************************警告*********************************\r\n")
				.append("**********************************************************************\r\n")
				.append("调用GloableSQLUtil getSQLInfo 方法从tplEdenConcurrentCache获取代码中硬编码的[")
				.append(sql).append("] 模板信息时,检测到缓冲区记录数超出cache允许的最大cache size:")
				.append(maxSize)
				.append(",\r\n导致告警原因分析:\r\n本条sql或者其他sql语句直接硬编码在代码中;")
				.append("\r\n本条sql或者其他sql语句可能存在不断变化的值参数;")
				.append("\r\n本条sql或者其他sql语句可能存在的$var模式的变量并且$var的值不断变化;")
				.append("\r\n优化建议:\r\n将sql中可能存在不断变化的值参数转化为绑定变量或者#[variable]变量,或将sql中可能存在的$var模式的变量转换为#[varibale]模式的变量,并采用配置文件来管理sql语句,以提升系统性能!")
				.append("\n\r**********************************************************************")
				.append("\n\r**********************************************************************");
		logger.warn(info.toString());
	}

	@Override
	public String getSQL(String sql) {
		return sql;
	}

	@Override
	public PoolManResultSetMetaData getPoolManResultSetMetaData(JDBCPool db, String dbname,
																String sqlkey, ResultSetMetaData rsmetadata) throws SQLException {
		// TODO Auto-generated method stub
		return super.getPoolManResultSetMetaData(db,dbname, sqlkey, rsmetadata);
	}

	

	@Override
	public String getSQLFile() {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public String evaluateSQL(String name, String sql, Map variablevalues) {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public String getDBName(String sqlname) {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public Map getMapSQLs(String sqlname) {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public Map getMapSQLs(String dbname, String sqlname) {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public List getListSQLs(String sqlname) {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public List getListSQLs(String dbname, String sqlname) {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public Set getSetSQLs(String sqlname) {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public Set getSetSQLs(String dbname, String sqlname) {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public BaseApplicationContext getSqlcontext() {
		throw new java.lang.UnsupportedOperationException();
	}

	@Override
	public long getRefresh_interval() {
		throw new java.lang.UnsupportedOperationException();
	}
	protected void _destroy(){

		if(this.alwaysCache) {
			this.tplEdenConcurrentCache.clear();
			this.tplEdenConcurrentCache = null;
		}
		else
		{
			this.tplMissingStaticCache.clear();
			tplMissingStaticCache = null;
		}
		this.alwaysCache = false;
		super._destroy();
//		this.edenConcurrentCache.clear();
	}
	protected void reinit(){
//		if(this.alwaysCache) {
//			this.tplEdenConcurrentCache.clear();
//		}
//		else
//		{
//			this.tplMissingStaticCache.clear();
//		}

		super.reinit();
		if(alwaysCache) {
			tplEdenConcurrentCache = new EdenConcurrentCache(maxGloableTemplateCacheSize);
		}
		else{
			tplMissingStaticCache = new MissingStaticCache(maxGloableTemplateCacheSize);
		}
//		this.edenConcurrentCache.clear();
	}

	@Override
	public Map getSQLRefers() {
		return null;
	}

	@Override
	public boolean hasrefs() {
		return false;
	}

	@Override
	public String getPlainSQL(String dbname, String sqlname) {
		return sqlname;
	}

	@Override
	public String getSQL(String sqlname, Map variablevalues) {
		return _getSQL(this.getSQLInfo(sqlname,true,false),variablevalues);
	}

	@Override
	public boolean fromConfig() {
		return false;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy