JDBC 获取架构中包内 oracle 过程的元数据

JDBC getmetadata of an oracle procedure inside package in a schema

在 oracle 数据库中有一个模式。在模式内部有一个包含不同方法的包。如何使用 DatabaseMetaDataclass 中的 getProcedureColumn() 函数检索过程的元数据?

我尝试使用 getProcedureColumns(catalog,schemaname,procedurename,columnnamepattern) 获取元数据,当过程位于架构内时它工作正常。当过程位于模式中的包内时,它不会检索。

这将打印出包中特定程序的所有列信息。用实际值更改参数。

DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());

            Connection conn =
              DriverManager.getConnection ("jdbc:oracle:thin:@<server>:<port>:<sid>", "<username>", "<password>");

            DatabaseMetaData metadata = conn.getMetaData();

            String packageName = "<your package name>";
            String schemaName = "<schema name>";
            String procedureName = "<procedure name>";

            ResultSet rs = metadata.getProcedureColumns(
                        packageName,
                        schemaName,
                        procedureName,
                    "%");

                while(rs.next()) {
                // get stored procedure metadata
                String procedureCatalog     = rs.getString(1);
                String procedureSchema      = rs.getString(2);
                procedureName               = rs.getString(3);
                String columnName           = rs.getString(4);
                short  columnReturn         = rs.getShort(5);
                int    columnDataType       = rs.getInt(6);
                String columnReturnTypeName = rs.getString(7);
                int    columnPrecision      = rs.getInt(8);
                int    columnByteLength     = rs.getInt(9);
                short  columnScale          = rs.getShort(10);
                short  columnRadix          = rs.getShort(11);
                short  columnNullable       = rs.getShort(12);
                String columnRemarks        = rs.getString(13);

                System.out.println("stored Procedure name="+procedureName);
                System.out.println("procedureCatalog=" + procedureCatalog);
                System.out.println("procedureSchema=" + procedureSchema);
                System.out.println("procedureName=" + procedureName);
                System.out.println("columnName=" + columnName);
                System.out.println("columnReturn=" + columnReturn);
                System.out.println("columnDataType=" + columnDataType);
                System.out.println("columnReturnTypeName=" + columnReturnTypeName);
                System.out.println("columnPrecision=" + columnPrecision);
                System.out.println("columnByteLength=" + columnByteLength);
                System.out.println("columnScale=" + columnScale);
                System.out.println("columnRadix=" + columnRadix);
                System.out.println("columnNullable=" + columnNullable);
                System.out.println("columnRemarks=" + columnRemarks);
                }