【问题标题】:Call Java SOURCE using function使用函数调用 Java SOURCE
【发布时间】:2020-01-17 01:17:41
【问题描述】:

我需要使用 SQL、PL/SQL 或 Java 找出 Windows 用户名。到目前为止,我已经找到了一些可以返回 Windows 用户名的 java 代码。我将 Java 代码放在我的模式数据库中,但无法创建将调用此 Java 代码的函数。

所以,我的问题是:

如何编写一个 SQL 函数来调用下面的 Java 代码?

CREATE OR REPLACE AND RESOLVE JAVA SOURCE NAMED TED."`GetWindowUsername`" as import java.`lang`.*;
import java.`util`.*;
import java.`io`.*;

public class `GetWindowUsername` {
    public static final void main( String `args`[] ) {
        String `userName` = System.get Property("user.name");
        System.out.`println`("Window's Username: "+user Name);
    }
}

我在互联网上找到此代码作为获取 Windows 用户名的示例。

我使用 Oracle Toad 作为 SQL 编码工具。

【问题讨论】:

  • 您的数据库与任何客户端用户的windows用户名无关。如果您需要数据库中的 Windows 用户名,请从您的客户端传递它。数据库无法做到这一点。
  • 当你有提供用户名的java文件时,为什么你需要创建一个过程。无论如何,您可以在 oracle 中使用这样的过程调用 java 源代码。 docs.oracle.com/cd/B14117_01/java.101/b12021/invokeapp.htm
  • @mallikarjun 但随后您将获得 sql 进程的用户名。假设 sql server 甚至在 windows 上运行。
  • @f1sh 好的,但是,我该怎么做呢?
  • @mallikarjun 我会试试这个,只需要将类加载到数据库中。谢谢你的建议。

标签: java windows oracle java-stored-procedures


【解决方案1】:

如何编写一个 SQL 函数来调用下面的 JAVA 代码?

您需要一个包含将返回值的静态方法的类 (another example of this):

CREATE AND COMPILE JAVA SOURCE NAMED GetWindowUsername AS
public class GetWindowUsername {
  public static String getUsername()
  {
    return java.lang.System.getProperty("user.name");
  }
}

那么你需要创建一个PL/SQL函数来调用Java类的函数:

CREATE FUNCTION getUsername( in_value IN VARCHAR2 ) RETURN VARCHAR2
AS LANGUAGE JAVA NAME 'GetWindowUsername.getUsername() return java.lang.String';
/

【讨论】:

  • 这个例子运行良好,到目前为止编译时没有出现错误。你能写信告诉我如何使用sql 调用这个函数吗?因为当我尝试调用该函数时,我得到了一个错误:ORA-00932:不一致datatypes:期望在参数位置 2 处有一个 Java 类型,可以将一些 Oracle 值转换为其他类型。
猜你喜欢
  • 2018-10-27
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-12-27
  • 1970-01-01
  • 2019-07-21
  • 2011-04-07
  • 2015-03-15
相关资源
最近更新 更多