/* * DBeaver - Universal Database Manager * Copyright (C) 2010-2017 Serge Rider (serge@jkiss.org) * * 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.jkiss.dbeaver.ext.oracle.model; import org.jkiss.code.NotNull; import org.jkiss.dbeaver.DBException; import org.jkiss.dbeaver.model.exec.jdbc.JDBCResultSet; import org.jkiss.dbeaver.model.exec.jdbc.JDBCSession; import org.jkiss.dbeaver.model.exec.jdbc.JDBCPreparedStatement; import org.jkiss.dbeaver.model.exec.jdbc.JDBCStatement; import org.jkiss.dbeaver.model.impl.jdbc.JDBCUtils; import org.jkiss.dbeaver.model.impl.jdbc.cache.JDBCObjectCache; import org.jkiss.dbeaver.model.meta.Association; import org.jkiss.dbeaver.model.meta.Property; import org.jkiss.dbeaver.model.runtime.DBRProgressMonitor; import org.jkiss.dbeaver.model.struct.DBSEntityMethod; import org.jkiss.dbeaver.model.struct.DBSParametrizedObject; import org.jkiss.utils.CommonUtils; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Types; import java.util.Collection; /** * Oracle data type attribute */ public class OracleDataTypeMethod extends OracleDataTypeMember implements DBSEntityMethod, DBSParametrizedObject { private String methodType; private boolean flagFinal; private boolean flagInstantiable; private boolean flagOverriding; private OracleDataType resultType; private OracleDataTypeModifier resultTypeMod; private final ParameterCache parameterCache; public OracleDataTypeMethod(OracleDataType dataType) { super(dataType); this.parameterCache = new ParameterCache(); } public OracleDataTypeMethod(DBRProgressMonitor monitor, OracleDataType dataType, ResultSet dbResult) { super(dataType, dbResult); this.name = JDBCUtils.safeGetString(dbResult, "METHOD_NAME"); this.number = JDBCUtils.safeGetInt(dbResult, "METHOD_NO"); this.methodType = JDBCUtils.safeGetString(dbResult, "METHOD_TYPE"); this.flagFinal = JDBCUtils.safeGetBoolean(dbResult, "FINAL", OracleConstants.YES); this.flagInstantiable = JDBCUtils.safeGetBoolean(dbResult, "INSTANTIABLE", OracleConstants.YES); this.flagOverriding = JDBCUtils.safeGetBoolean(dbResult, "OVERRIDING", OracleConstants.YES); boolean hasParameters = JDBCUtils.safeGetInt(dbResult, "PARAMETERS") > 0; this.parameterCache = hasParameters ? new ParameterCache() : null; String resultTypeName = JDBCUtils.safeGetString(dbResult, "RESULT_TYPE_NAME"); if (!CommonUtils.isEmpty(resultTypeName)) { this.resultType = OracleDataType.resolveDataType( monitor, getDataSource(), JDBCUtils.safeGetString(dbResult, "RESULT_TYPE_OWNER"), resultTypeName); this.resultTypeMod = OracleDataTypeModifier.resolveTypeModifier( JDBCUtils.safeGetString(dbResult, "RESULT_TYPE_MOD")); } } @Property(viewable = true, editable = true, order = 5) public String getMethodType() { return methodType; } @Property(id = "dataType", viewable = true, order = 6) public OracleDataType getResultType() { return resultType; } @Property(id = "dataTypeMod", viewable = true, order = 7) public OracleDataTypeModifier getResultTypeMod() { return resultTypeMod; } @Property(viewable = true, order = 8) public boolean isFinal() { return flagFinal; } @Property(viewable = true, order = 9) public boolean isInstantiable() { return flagInstantiable; } @Property(viewable = true, order = 10) public boolean isOverriding() { return flagOverriding; } @Association public Collection<OracleDataTypeMethodParameter> getParameters(DBRProgressMonitor monitor) throws DBException { return parameterCache == null ? null : parameterCache.getAllObjects(monitor, this); } private class ParameterCache extends JDBCObjectCache<OracleDataTypeMethod, OracleDataTypeMethodParameter> { @Override protected JDBCStatement prepareObjectsStatement(@NotNull JDBCSession session, @NotNull OracleDataTypeMethod owner) throws SQLException { final JDBCPreparedStatement dbStat = session.prepareStatement( "SELECT PARAM_NAME,PARAM_NO,PARAM_MODE,PARAM_TYPE_OWNER,PARAM_TYPE_NAME,PARAM_TYPE_MOD " + "FROM ALL_METHOD_PARAMS " + "WHERE OWNER=? AND TYPE_NAME=? AND METHOD_NAME=? AND METHOD_NO=?"); OracleDataType dataType = getOwnerType(); if (dataType.getSchema() == null) { dbStat.setNull(1, Types.VARCHAR); } else { dbStat.setString(1, dataType.getSchema().getName()); } dbStat.setString(2, dataType.getName()); dbStat.setString(3, getName()); dbStat.setInt(4, getNumber()); return dbStat; } @Override protected OracleDataTypeMethodParameter fetchObject(@NotNull JDBCSession session, @NotNull OracleDataTypeMethod owner, @NotNull JDBCResultSet resultSet) throws SQLException, DBException { return new OracleDataTypeMethodParameter( session.getProgressMonitor(), OracleDataTypeMethod.this, resultSet); } } }