【发布时间】: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