/* * 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.dbeaver.model.DBConstants; import org.jkiss.dbeaver.model.data.DBDPseudoAttribute; import org.jkiss.dbeaver.model.data.DBDPseudoAttributeType; import org.jkiss.dbeaver.model.struct.DBSEntityConstraintType; import org.jkiss.dbeaver.model.struct.rdb.DBSIndexType; /** * Oracle constants */ public class OracleConstants { public static final String CMD_COMPILE = "org.jkiss.dbeaver.ext.oracle.code.compile"; //$NON-NLS-1$ public static final int DEFAULT_PORT = 1521; public static final String SCHEMA_SYS = "SYS"; public static final String VIEW_ALL_SOURCE = "ALL_SOURCE"; public static final String VIEW_DBA_SOURCE = "DBA_SOURCE"; public static final String[] SYSTEM_SCHEMAS = { "CTXSYS", "DBSNMP", "DMSYS", "EXFSYS", "IX", "MDDATA", "MDSYS", "DMSYS", "MGMT_VIEW", "OLAPSYS", "ORDPLUGINS", "ORDSYS", "ORDDATA", "SI_INFORMTN_SCHEMA", "OWBSYS", "OWBSYS_AUDIT", "OUTLN", "ORACLE_OCM", "SYS", "SYSMAN", "SYSTEM", "TSMSYS", "WMSYS", "XDB", }; public static final String PROP_CONNECTION_TYPE = DBConstants.INTERNAL_PROP_PREFIX + "connection-type@"; public static final String PROP_SID_SERVICE = DBConstants.INTERNAL_PROP_PREFIX + "sid-service@"; public static final String PROP_CONNECTION_TARGET = "connection_target"; public static final String PROP_DRIVER_TYPE = DBConstants.INTERNAL_PROP_PREFIX + "driver-type@"; public static final String PROP_INTERNAL_LOGON = DBConstants.INTERNAL_PROP_PREFIX + "internal-logon@"; public static final String PROP_TNS_PATH = DBConstants.INTERNAL_PROP_PREFIX + "tns-path@"; public static final String PROP_SESSION_LANGUAGE = DBConstants.INTERNAL_PROP_PREFIX + "session-language@"; public static final String PROP_SESSION_TERRITORY = DBConstants.INTERNAL_PROP_PREFIX + "session-territory@"; public static final String PROP_SESSION_NLS_DATE_FORMAT = DBConstants.INTERNAL_PROP_PREFIX + "session-nls-date-format@"; public static final String PROP_CHECK_SCHEMA_CONTENT = DBConstants.INTERNAL_PROP_PREFIX + "check-schema-content@"; public static final String PROP_ALWAYS_SHOW_DBA = DBConstants.INTERNAL_PROP_PREFIX + "always-show-dba@"; public static final String PROP_USE_RULE_HINT = DBConstants.INTERNAL_PROP_PREFIX + "use-rule-hint@"; public static final String OS_AUTH_USER_NAME = "@OS_AUTH@"; public static final String DRIVER_TYPE_THIN = "THIN"; public static final String DRIVER_TYPE_OCI = "OCI"; public static final String USER_PUBLIC = "PUBLIC"; public static final String YES = "YES"; public static final String TYPE_NAME_XML = "XMLTYPE"; public static final String TYPE_FQ_XML = "SYS.XMLTYPE"; public static final String TYPE_NAME_BFILE = "BFILE"; public static final DBSIndexType INDEX_TYPE_NORMAL = new DBSIndexType("NORMAL", "Normal"); public static final DBSIndexType INDEX_TYPE_BITMAP = new DBSIndexType("BITMAP", "Bitmap"); public static final DBSIndexType INDEX_TYPE_FUNCTION_BASED_NORMAL = new DBSIndexType("FUNCTION-BASED NORMAL", "Function-based Normal"); public static final DBSIndexType INDEX_TYPE_FUNCTION_BASED_BITMAP = new DBSIndexType("FUNCTION-BASED BITMAP", "Function-based Bitmap"); public static final DBSIndexType INDEX_TYPE_DOMAIN = new DBSIndexType("DOMAIN", "Domain"); public static final String PROP_OBJECT_DEFINITION = "objectDefinitionText"; public static final String PROP_OBJECT_BODY_DEFINITION = "extendedDefinitionText"; public static final String COL_OWNER = "OWNER"; public static final String COL_TABLE_NAME = "TABLE_NAME"; public static final String COL_CONSTRAINT_NAME = "CONSTRAINT_NAME"; public static final String COL_CONSTRAINT_TYPE = "CONSTRAINT_TYPE"; public static final String XML_COLUMN_NAME = "XML"; public static final String OBJECT_VALUE_COLUMN_NAME = "OBJECT_VALUE"; public static final DBDPseudoAttribute PSEUDO_ATTR_ROWID = new DBDPseudoAttribute( DBDPseudoAttributeType.ROWID, "ROWID", "$alias.ROWID", null, "Unique row identifier", true); public static final String PREF_EXPLAIN_TABLE_NAME = "oracle.explain.table"; public static final String PREF_SUPPORT_ROWID = "oracle.support.rowid"; public static final String PREF_DBMS_OUTPUT = "oracle.dbms.output"; public static final String NLS_DEFAULT_VALUE = "Default"; public static final String PREF_KEY_DDL_FORMAT = "oracle.ddl.format"; public static final int MAXIMUM_DBMS_OUTPUT_SIZE = 1000000; public static final String VAR_ORA_HOME = "ORA_HOME"; public static final String VAR_ORACLE_HOME = "ORACLE_HOME"; public static final String VAR_TNS_ADMIN = "TNS_ADMIN"; public static final String VAR_PATH = "PATH"; public static final String VAR_ORACLE_NET_TNS_ADMIN = "oracle.net.tns_admin"; public static final int DATA_TYPE_TIMESTAMP_WITH_TIMEZONE = 101; public static final int DATA_TYPE_TIMESTAMP_WITH_LOCAL_TIMEZONE = 102; public static final DBSEntityConstraintType CONSTRAINT_WITH_CHECK_OPTION = new DBSEntityConstraintType("V", "With Check Option", null, false, false, false); public static final DBSEntityConstraintType CONSTRAINT_WITH_READ_ONLY = new DBSEntityConstraintType("O", "With Read Only", null, false, false, false); public static final DBSEntityConstraintType CONSTRAINT_HASH_EXPRESSION = new DBSEntityConstraintType("H", "Hash expression", null, false, false, false); public static final DBSEntityConstraintType CONSTRAINT_REF_COLUMN = new DBSEntityConstraintType("F", "Constraint that involves a REF column", null, false, false, false); public static final DBSEntityConstraintType CONSTRAINT_SUPPLEMENTAL_LOGGING = new DBSEntityConstraintType("S", "Supplemental logging", null, false, false, false); /** * Oracle error codes */ public static final int EC_FEATURE_NOT_SUPPORTED = 17023; /** * Connection type */ public enum ConnectionType { BASIC, TNS, CUSTOM } public static final String XMLTYPE_CLASS_NAME = "oracle.xdb.XMLType"; public static final String BFILE_CLASS_NAME = "oracle.sql.BFILE"; public static final String PLAN_TABLE_DEFINITION = "create global temporary table ${TABLE_NAME} (\n" + "statement_id varchar2(30),\n" + "plan_id number,\n" + "timestamp date,\n" + "remarks varchar2(4000),\n" + "operation varchar2(30),\n" + "options varchar2(255),\n" + "object_node varchar2(128),\n" + "object_owner varchar2(30),\n" + "object_name varchar2(30),\n" + "object_alias varchar2(65),\n" + "object_instance numeric,\n" + "object_type varchar2(30),\n" + "optimizer varchar2(255),\n" + "search_columns number,\n" + "id numeric,\n" + "parent_id numeric,\n" + "depth numeric,\n" + "position numeric,\n" + "cost numeric,\n" + "cardinality numeric,\n" + "bytes numeric,\n" + "other_tag varchar2(255),\n" + "partition_start varchar2(255),\n" + "partition_stop varchar2(255),\n" + "partition_id numeric,\n" + "other long,\n" + "distribution varchar2(30),\n" + "cpu_cost numeric,\n" + "io_cost numeric,\n" + "temp_space numeric,\n" + "access_predicates varchar2(4000),\n" + "filter_predicates varchar2(4000),\n" + "projection varchar2(4000),\n" + "time numeric,\n" + "qblock_name varchar2(30),\n" + "other_xml clob\n" + ") on commit preserve rows"; }