當前位置: 首頁>>代碼示例>>Java>>正文


Java BoundSql.getParameterObject方法代碼示例

本文整理匯總了Java中org.apache.ibatis.mapping.BoundSql.getParameterObject方法的典型用法代碼示例。如果您正苦於以下問題:Java BoundSql.getParameterObject方法的具體用法?Java BoundSql.getParameterObject怎麽用?Java BoundSql.getParameterObject使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.ibatis.mapping.BoundSql的用法示例。


在下文中一共展示了BoundSql.getParameterObject方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: intercept

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
@Override
public Object intercept(Invocation invocation) throws Throwable {
	RoutingStatementHandler handler = (RoutingStatementHandler) invocation.getTarget();
	StatementHandler delegate = (StatementHandler) ReflectUtil.getFieldValue(handler, "delegate");
	BoundSql boundSql = delegate.getBoundSql();
	Object obj = boundSql.getParameterObject();
	Page page = seekPage(obj);
	if (page != null) {
		MappedStatement mappedStatement = (MappedStatement) ReflectUtil.getFieldValue(delegate, "mappedStatement");
		Connection connection = (Connection) invocation.getArgs()[0];
		String sql = boundSql.getSql();
		this.setTotalRecord(page, mappedStatement, connection);
		String pageSql = this.getPageSql(page, sql);
		ReflectUtil.setFieldValue(boundSql, "sql", pageSql);
	}
	return invocation.proceed();
}
 
開發者ID:lemon-china,項目名稱:lemon-mybatis-plus,代碼行數:18,代碼來源:PageInterceptor.java

示例2: findMasterValue

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
private Object findMasterValue(ISqlParser iSqlParser, BoundSql boundSql, TableConfig tableConfig) throws SqlParseException {
    if (iSqlParser.getType() == SqlType.INSERT) {
        /** Insert */
        List<ColumnValue> columnValues = iSqlParser.getColumns();
        for (int i = 0; i < columnValues.size(); i++) {
            if (columnValues.get(i).column.equals(tableConfig.getMasterColumn())) {
                try {
                    return ReflectionUtils.getFieldValue(boundSql.getParameterObject(), boundSql.getParameterMappings().get(i).getProperty());
                } catch (Exception e) {
                    throw new SqlParseException("failed to parse property:" + boundSql.getParameterMappings().get(i).getProperty());
                }
            }
        }
    } else {
        /** Select/Update/Delete -> columns from "where" clause */
        if (boundSql.getParameterObject() instanceof MapperMethod.ParamMap) {
            return getColumnValue(tableConfig.getMasterColumn(), iSqlParser, boundSql);
        }
    }
    return null;
}
 
開發者ID:maniaclee,項目名稱:shardy,代碼行數:22,代碼來源:ShardInterceptor.java

示例3: findColumnValue

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
@Deprecated
private static Object findColumnValue(ISqlParser iSqlParser, BoundSql boundSql, TableConfig tableConfig) {
    /** Select/Update/Delete -> columns from "where" clause */
    if (boundSql.getParameterObject() instanceof MapperMethod.ParamMap) {
        return getColumnValue(tableConfig.getMasterColumn(), iSqlParser, boundSql);
    } else {
        /** parameter is object */
        List<ColumnValue> columnValues = iSqlParser.getColumns();
        for (int i = 0; i < columnValues.size(); i++) {
            if (columnValues.get(i).column.equals(tableConfig.getMasterColumn())) {
                try {
                    return ReflectionUtils.getFieldValue(boundSql.getParameterObject(), boundSql.getParameterMappings().get(i).getProperty());
                } catch (Exception e) {
                    throw new SqlParseException("failed to parse property:" + boundSql.getParameterMappings().get(i).getProperty());
                }
            }
        }
    }
    return null;
}
 
開發者ID:maniaclee,項目名稱:shardy,代碼行數:21,代碼來源:ExtendedSqlSource.java

示例4: getColumnValue

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
public static Object getColumnValue(String columnName, ISqlParser iSqlParser, BoundSql boundSql) {
    MapperMethod.ParamMap paramMap = (MapperMethod.ParamMap) boundSql.getParameterObject();
    List<ColumnValue> cols = iSqlParser.getColumns();
    for (int i = 0; i < cols.size(); i++) {
        if (Objects.equals(cols.get(i).column, columnName)) {
            //                if (cols.get(i).value.equals("?")) //TODO
            List<ParameterMapping> parameterMappings = boundSql.getParameterMappings();
            String property = parameterMappings.get(i).getProperty();
            if (!property.startsWith("_"))
                return paramMap.get("param" + (i + 1)); //index start from 1
            return parameterMappings.stream()
                    .filter(p -> p.getProperty().startsWith("__frch_" + columnName))
                    .map(parameterMapping -> boundSql.getAdditionalParameter(parameterMapping.getProperty()))
                    .collect(Collectors.toList());
        }
    }
    return null;
}
 
開發者ID:maniaclee,項目名稱:shardy,代碼行數:19,代碼來源:ExtendedSqlSource.java

示例5: queryTotal

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
/**
 * 查詢總記錄條數
 *
 * @param sql
 * @param mappedStatement
 * @param boundSql
 * @param page
 */
protected void queryTotal(boolean overflowCurrent, String sql, MappedStatement mappedStatement, BoundSql boundSql, Pagination page, Connection connection) {
    try (PreparedStatement statement = connection.prepareStatement(sql)) {
        DefaultParameterHandler parameterHandler = new MybatisDefaultParameterHandler(mappedStatement, boundSql.getParameterObject(), boundSql);
        parameterHandler.setParameters(statement);
        int total = 0;
        try (ResultSet resultSet = statement.executeQuery()) {
            if (resultSet.next()) {
                total = resultSet.getInt(1);
            }
        }
        page.setTotal(total);
        /*
         * 溢出總頁數,設置第一頁
*/
        int pages = page.getPages();
        if (overflowCurrent && (page.getCurrent() > pages)) {
            // 設置為第一條
            page.setCurrent(1);
        }
    } catch (Exception e) {
        logger.error("Error: Method queryTotal execution error !", e);
    }
}
 
開發者ID:baomidou,項目名稱:mybatis-plus,代碼行數:32,代碼來源:PaginationInterceptor.java

示例6: queryCount

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
private Object queryCount(Invocation invocation, Object[] args, MappedStatement ms, BoundSql boundSql)
		throws InvocationTargetException, IllegalAccessException {
	MappedStatement countRowStatement = COUNT_MAPPED_STATS.get(ms.getId());

	if (countRowStatement == null) {
		String countSql = dialect.getCountSql(boundSql.getSql());
		BoundSql newBoundSql = new BoundSql(ms.getConfiguration(), countSql, boundSql.getParameterMappings(),
				boundSql.getParameterObject());
		MetaObject mo = (MetaObject) ReflectionUtils.getFieldValue(boundSql, "metaParameters");
		ReflectionUtils.setFieldValue(newBoundSql, "metaParameters", mo);
		List<ResultMap> resultMaps = new ArrayList<ResultMap>();
		ResultMap resultMap = new ResultMap.Builder(ms.getConfiguration(), ms.getId(), int.class,
				EMPTY_RESULTMAPPING).build();
		resultMaps.add(resultMap);
		countRowStatement = buildMappedStatement(ms, new SqlSourceWrapper(newBoundSql), ms.getId() + "_COUNT",
				resultMaps);
	}

	args[0] = countRowStatement;
	args[2] = new RowBounds();
	args[3] = null;

	return invocation.proceed();
}
 
開發者ID:dianping,項目名稱:zebra,代碼行數:25,代碼來源:PageInterceptor.java

示例7: intercept

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
@Override
public Object intercept(Invocation ivk) throws Throwable {
	if (ivk.getTarget().getClass()
			.isAssignableFrom(RoutingStatementHandler.class)) {
		final RoutingStatementHandler statementHandler = (RoutingStatementHandler) ivk
				.getTarget();
		final BaseStatementHandler delegate = (BaseStatementHandler) Reflection
				.getFieldValue(statementHandler, DELEGATE);
		final MappedStatement mappedStatement = (MappedStatement) Reflection
				.getFieldValue(delegate, MAPPED_STATEMENT);

		if (mappedStatement.getId().matches(SQL_PATTERN)) {
			// 攔截需要分頁的SQL
			BoundSql boundSql = delegate.getBoundSql();
			// 分頁SQL<select>中parameterType屬性對應的實體參數,即Mapper接口中執行分頁方法的參數,該參數不得為空
			Object parameterObject = boundSql.getParameterObject();
			if (null == parameterObject) {
				throw new NullPointerException("parameterObject尚未實例化!");
			} else {
				final Connection connection = (Connection) ivk.getArgs()[0];
				final String sql = boundSql.getSql();
				// 記錄統計
				final int count = BaseParameter
						.getCount(sql, connection, mappedStatement,
								parameterObject, boundSql, DIALECT);
				Page page = null;
				page = convertParameter(parameterObject, page);
				page.init(count, page.getSize(), page.getLimit());
				String pagingSql = BaseParameter.generatePageSql(sql, page,
						DIALECT);
				// 將分頁sql語句反射回BoundSql.
				Reflection.setFieldValue(boundSql, "sql", pagingSql);
			}
		}
	}
	return ivk.proceed();
}
 
開發者ID:jiangzongyao,項目名稱:kettle_support_kettle8.0,代碼行數:38,代碼來源:PreparePaginationInterceptor.java

示例8: processIntercept

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
void processIntercept(final Object[] queryArgs) {
	MappedStatement ms = (MappedStatement) queryArgs[MAPPED_STATEMENT_INDEX];
	Object parameter = queryArgs[PARAMETER_INDEX];
	final RowBounds rowBounds = (RowBounds) queryArgs[ROWBOUNDS_INDEX];
	int offset = rowBounds.getOffset();
	int limit = rowBounds.getLimit();
	if (dialect.supportsLimit() && (offset != RowBounds.NO_ROW_OFFSET || limit != RowBounds.NO_ROW_LIMIT)) {
		BoundSql boundSql = ms.getBoundSql(parameter);
		String sql = boundSql.getSql().trim();
		if (dialect.supportsLimitOffset()) {
			sql = dialect.getLimitString(sql, offset, limit);
			offset = RowBounds.NO_ROW_OFFSET;
		} else {
			sql = dialect.getLimitString(sql, 0, limit);
		}
		limit = RowBounds.NO_ROW_LIMIT;
		queryArgs[ROWBOUNDS_INDEX] = new RowBounds(offset, limit);
		BoundSql newBoundSql = new BoundSql(ms.getConfiguration(), sql, boundSql.getParameterMappings(),
				boundSql.getParameterObject());
		for (ParameterMapping mapping : boundSql.getParameterMappings()) {
			String prop = mapping.getProperty();
			if (boundSql.hasAdditionalParameter(prop)) {
				newBoundSql.setAdditionalParameter(prop, boundSql.getAdditionalParameter(prop));
			}
		}
		MappedStatement newMs = copyFromMappedStatement(ms, new BoundSqlSqlSource(newBoundSql));
		queryArgs[MAPPED_STATEMENT_INDEX] = newMs;
	}
}
 
開發者ID:yi-jun,項目名稱:aaden-pay,代碼行數:30,代碼來源:PagePluging.java

示例9: copyFromBoundSql

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
private static BoundSql copyFromBoundSql(MappedStatement ms, BoundSql boundSql, String sql) {
    BoundSql newBoundSql = new BoundSql(ms.getConfiguration(), sql, boundSql.getParameterMappings(), boundSql.getParameterObject());
    for (ParameterMapping mapping : boundSql.getParameterMappings()) {
        String prop = mapping.getProperty();
        if (boundSql.hasAdditionalParameter(prop)) {
            newBoundSql.setAdditionalParameter(prop, boundSql.getAdditionalParameter(prop));
        }
    }
    return newBoundSql;
}
 
開發者ID:lodsve,項目名稱:lodsve-framework,代碼行數:11,代碼來源:PaginationHelper.java

示例10: copyFromBoundSql

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
private BoundSql copyFromBoundSql(MappedStatement ms, BoundSql boundSql,
		String sql) {
	BoundSql newBoundSql = new BoundSql(ms.getConfiguration(),sql, boundSql.getParameterMappings(), boundSql.getParameterObject());
	for (ParameterMapping mapping : boundSql.getParameterMappings()) {
	    String prop = mapping.getProperty();
	    if (boundSql.hasAdditionalParameter(prop)) {
	        newBoundSql.setAdditionalParameter(prop, boundSql.getAdditionalParameter(prop));
	    }
	}
	return newBoundSql;
}
 
開發者ID:codeWatching,項目名稱:codePay,代碼行數:12,代碼來源:OffsetLimitInterceptor.java

示例11: getColumnValue

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
private Object getColumnValue(String columnName, ISqlParser iSqlParser, BoundSql boundSql) {
    MapperMethod.ParamMap paramMap = (MapperMethod.ParamMap) boundSql.getParameterObject();
    List<ColumnValue> cols = iSqlParser.getColumns();
    for (int i = 0; i < cols.size(); i++) {
        if (Objects.equals(cols.get(i).column, columnName)) {
            //                if (cols.get(i).value.equals("?")) //TODO
            return paramMap.get(boundSql.getParameterMappings().get(i).getProperty());
        }
    }
    return null;
}
 
開發者ID:maniaclee,項目名稱:shardy,代碼行數:12,代碼來源:ShardInterceptor.java

示例12: interceptQuery

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
public Object interceptQuery(Invocation invocation) throws Throwable {
    /** statement is new Object with different memory address */
    StatementHandler statementHandler = (StatementHandler) invocation.getTarget();
    BoundSql boundSql = statementHandler.getBoundSql();
    String sql = boundSql.getSql();
    System.out.println(statementHandler.getClass());
    System.out.println("sql->" + sql);
    ISqlParser iSqlParser = new DruidSqlParser();
    iSqlParser.init(sql);
    iSqlParser.setTableName("fuck");

    String masterColumn = "id";
    if (boundSql.getParameterObject() instanceof MapperMethod.ParamMap) {
        MapperMethod.ParamMap paramMap = (MapperMethod.ParamMap) boundSql.getParameterObject();
        Object masterValue = paramMap.get(masterColumn);
        System.out.println("param-> " + masterValue);
    }

    String sqlResult = iSqlParser.toSql();
    System.out.println("sqlResult->" + sqlResult);

    Statement statement = (Statement) invocation.getArgs()[0];
    ReflectionUtils.setDeclaredFieldValue(boundSql, "sql", sqlResult);

    Object h = ReflectionUtils.getFieldValue(statement, "h");
    if (h instanceof PreparedStatementLogger) {
        PreparedStatementLogger preparedStatementLogger = (PreparedStatementLogger) h;
        PreparedStatement preparedStatement = preparedStatementLogger.getPreparedStatement();
    }
    System.out.println(statement.getClass().getName());
    System.out.println("sta-> " + statementHandler);
    return invocation.proceed();
}
 
開發者ID:maniaclee,項目名稱:shardy,代碼行數:34,代碼來源:ShardInterceptor.java

示例13: intercept

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
@Override
    public Object intercept(Invocation ivk) throws Throwable {
        if (ivk.getTarget().getClass().isAssignableFrom(RoutingStatementHandler.class)) {
            final RoutingStatementHandler statementHandler = (RoutingStatementHandler) ivk.getTarget();
            final BaseStatementHandler delegate = (BaseStatementHandler) Reflections.getFieldValue(statementHandler, DELEGATE);
            final MappedStatement mappedStatement = (MappedStatement) Reflections.getFieldValue(delegate, MAPPED_STATEMENT);

//            //攔截需要分頁的SQL
////            if (mappedStatement.getId().matches(_SQL_PATTERN)) { 
//            if (StringUtils.indexOfIgnoreCase(mappedStatement.getId(), _SQL_PATTERN) != -1) {
                BoundSql boundSql = delegate.getBoundSql();
                //分頁SQL<select>中parameterType屬性對應的實體參數,即Mapper接口中執行分頁方法的參數,該參數不得為空
                Object parameterObject = boundSql.getParameterObject();
                if (parameterObject == null) {
                    log.error("參數未實例化");
                    throw new NullPointerException("parameterObject尚未實例化!");
                } else {
                    final Connection connection = (Connection) ivk.getArgs()[0];
                    final String sql = boundSql.getSql();
                    //記錄統計
                    final int count = SQLHelper.getCount(sql, connection, mappedStatement, parameterObject, boundSql, log);
                    Page<Object> page = null;
                    page = convertParameter(parameterObject, page);
                    page.setCount(count);
                    String pagingSql = SQLHelper.generatePageSql(sql, page, DIALECT);
                    if (log.isDebugEnabled()) {
                        log.debug("PAGE SQL:" + pagingSql);
                    }
                    //將分頁sql語句反射回BoundSql.
                    Reflections.setFieldValue(boundSql, "sql", pagingSql);
                }
                
                if (boundSql.getSql() == null || "".equals(boundSql.getSql())){
                    return null;
                }
                
            }
//        }
        return ivk.proceed();
    }
 
開發者ID:EleTeam,項目名稱:Shop-for-JavaWeb,代碼行數:41,代碼來源:PreparePaginationInterceptor.java

示例14: onInterceptor

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
@Override
public Object onInterceptor(Invocation invocation) throws Throwable {

	Object[] objects = invocation.getArgs();
	MappedStatement ms = (MappedStatement) objects[0];
	Object parameterObject = objects[1];

	// TypeHandlerRegistry typeHandlerRegistry =
	// ms.getConfiguration().getTypeHandlerRegistry();
	
	if(ignoreMappedStatementIds.contains(ms.getId())){
		return null;
	}
	String namespace = ms.getId().substring(0, ms.getId().lastIndexOf(SPIT_POINT));
	//策略配置忽略
	if(ignoreTablesMapperNameSpace.contains(namespace)){
		return null;
	}

	BoundSql boundSql = ms.getBoundSql(parameterObject);
	
	Object parameterObject2 = boundSql.getParameterObject();
	System.out.println(parameterObject2);

	//是否需要分庫
	boolean requiredShard = isRequiredShard(boundSql.getSql(), ms.getSqlCommandType(), namespace);
	
	if(requiredShard){
		//先檢查是否已經設置
		Object shardFieldValue = getShardFieldValue(ms.getId(),parameterObject);
		if(shardFieldValue == null){
			logger.error("方法{}無法獲取分庫字段{}的值",ms.getId(),shardStrategy.shardEntityField());
		}else{				
			int dbIndex = shardStrategy.assigned(shardFieldValue);
			//指定數據庫分庫序列
			DataSourceContextHolder.get().setDbIndex(dbIndex);
		}
	}
	return null;
}
 
開發者ID:vakinge,項目名稱:jeesuite-libs,代碼行數:41,代碼來源:DatabaseRouteHandler.java

示例15: queryLimit

import org.apache.ibatis.mapping.BoundSql; //導入方法依賴的package包/類
private Object queryLimit(Invocation invocation, Object[] args, MappedStatement ms, BoundSql boundSql, RowBounds rb)
		throws InvocationTargetException, IllegalAccessException {
	String limitSql = dialect.getLimitSql(boundSql.getSql(), rb.getOffset(), rb.getLimit());
	BoundSql newBoundSql = new BoundSql(ms.getConfiguration(), limitSql, boundSql.getParameterMappings(),
			boundSql.getParameterObject());
	MetaObject mo = (MetaObject) ReflectionUtils.getFieldValue(boundSql, "metaParameters");
	ReflectionUtils.setFieldValue(newBoundSql, "metaParameters", mo);

	args[0] = buildMappedStatement(ms, new SqlSourceWrapper(newBoundSql), ms.getId() + "_LIMIT",
			ms.getResultMaps());
	args[2] = new RowBounds();
	args[3] = null;

	return invocation.proceed();
}
 
開發者ID:dianping,項目名稱:zebra,代碼行數:16,代碼來源:PageInterceptor.java


注:本文中的org.apache.ibatis.mapping.BoundSql.getParameterObject方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。