13.8 The ojvmjava Tool
The ojvmjava tool is an interactive interface to the session namespace of a database instance. You specify database connection arguments when you start the ojvmjava tool. It then presents you with a prompt to indicate that it is ready for commands.
                  
The shell can launch an executable, that is, a class with a static main() method. This is done either by using the command-line interface or by calling a database resident class. If you call a database resident class, the executable must be loaded with the loadjava tool.
                  
This section covers the following topics:
13.8.1 ojvmjava Tool Syntax
The syntax of the ojvmjava tool command is:
                     
ojvmjava {-user user[/password@database ] [options]
  [@filename]
  [-batch]
  [-c | -command command args]
  [-debug]
  [-d | -database conn_string]
  [-fileout filename]
  [-o | -oci | -oci8]
  [-oschema schema]
  [-t | -thin]
  [-version | -v]
 -runjava [server_file_system]
 -jdwp port [host]
 -verbose
13.8.2 ojvmjava Tool Argument Summary
Table 13-4 summarizes the ojvmjava tool arguments.
                     
Table 13-4 ojvmjava Argument Summary
| Argument | Description | 
|---|---|
| 
 | Specifies user name for connecting to the database. This name is not case-sensitive. The name will always be converted to uppercase. If you provide the database information, then the default syntax used is OCI. You can also specify the default database. | 
| 
 | Specifies the password for connecting to the database. | 
| 
 | Specifies a script file that contains the  | 
| 
 | Disables all messages displayed to the screen. No help messages or prompts will be displayed. Only responses to commands entered are displayed. | 
| 
 | Runs the desired command. If you do not want to run the  | 
| 
 | Displays debugging information. | 
| 
 | Provides a database connection string. | 
| 
 | Redirects output to the provided file. | 
| 
 | Uses the JDBC OCI driver. The OCI driver is the default. This flag specifies the syntax used in either the  | 
| 
 | Uses this schema for class lookup. | 
| 
 | Specifies that the database syntax used is for the JDBC Thin driver. The database connection string must be of the form  | 
| 
 | Displays the connection information. | 
| 
 | Shows the version. | 
| 
 | Uses  | 
| 
 | Makes the connection listen for a debugger connection on the indicated port and host. The default value of host is  | 
13.8.3 ojvmjava Tool Example
Open a shell on the session namespace of the database orcl on listener port 2481 on the host dbserver, as follows:
                     
ojvmjava -thin -user HR@dbserver:2481:orcl
Password: password
13.8.4 ojvmjava Tool Functionality
The ojvmjava tool commands span several different types of functionality, which are grouped as follows:
                     
13.8.4.1 ojvmjava Tool Command-Line Options
This section describes the following options available with the ojvmjava tool command:
                        
Scripting the ojvmjava Tool Commands in the @filename Option
This @filename option designates a script file that contains one or more ojvmjava tool commands. The specified script file is located on the client. The ojvmjava tool reads the file and runs all commands on the designated server. In addition, because the script file is run on the server, any interaction with the operating system in the script file, such as redirecting output to a file or running another script, occurs on the server. If you direct the ojvmjava tool to run another script file, then this file must exist in $ORACLE_HOME on the server.
                        
You must enter the ojvmjava tool command followed by any options and any expected input arguments. The script file contains the ojvmjava tool command followed by options and input parameters. The input parameters can be passed to the ojvmjava tool on the command line. The ojvmjava tool processes all known options and passes on any other options and arguments to the script file.
                        
The following shows the contents of the script file, execShell:
                        
java myclass a b c
To run this file, use the following command:
ojvmjava -user HR -thin -database dbserver:2481:orcl @commands
Password: password
The ojvmjava tool processes all options that it knows about and passes along any other input parameters to be used by the commands that exist within the script file. In this example, the parameters are passed to the java command in the script file.
                        
You can add any comments in your script file using the hash sign (#). Comments are ignored by the ojvmjava tool. For example:
                        
#this whole line is ignored by ojvmjava
-runjava
 This option controls whether or not the ojvmjava tool shell command Java runs executable classes using the command-line interface or database resident classes.  When the -runjava option is present the command-line interface is used. Otherwise, the executable must be a database resident class that was previously loaded with the loadjava tool. Using the optional argument server_file_system means that the -classpath terms are on the file system of the machine running Oracle server.  Otherwise, they are interpreted as being on the file system of the machine running the ojvmjava tool.
                        
-jdwp
This option specifies a debugger connection to listen for when the shell command java is used to run an executable.  This allows for debugging the executable. The arguments specify the port and host. The default value of the host argument is localhost. These are used to execute a call to DBMS_DEBUG_JDWP.CONNECT_TCP from the RDBMS session, in which the executable is run.
                        
Related Topics
13.8.4.2 ojvmjava Tool Shell Commands
This section describes the following commands available within the ojvmjava shell:
                        
Note:
An error is reported if you enter an unsupported command.
The following table summarizes the commands that share one or more common options:
Table 13-5 ojvmjava Command Common Options
| Option | Description | 
|---|---|
| 
 | Summarizes the operation of the tool. | 
| 
 | Summarizes the syntax of the tool. | 
| 
 | Shows the version. | 
echo
This command displays to stdout exactly what is indicated. This is used mostly in script files.
                        
The syntax is as follows:
echo [echo_string] [args]
echo_string is a string that contains the text you want written to the screen during the shell script invocation and args are input arguments from the user. For example, the following command displays out a notification:
                        
echo "Adding an owner to the schema" &1
If the input argument is HR, then the output would be:
                        
Adding an owner to the schema HR
exit
This command terminates ojvmjava. The syntax is as follows:
                        
exit
For example, to leave a shell, use the following command:
$ exit %
help
This command summarizes the syntax of the shell commands. You can also use the help command to summarize the options for a particular command. The syntax is as follows:
help [command]
java
This command is analogous to the JDK java command. It calls the static main() method of a class. It does this either by using the command-line interface or using a database resident class, depending on the setting of the runjava mode. In the latter case, the class must have been previously loaded with the loadjava tool. The command provides a convenient way to test Java code that runs in the database. In particular, the command catches exceptions and redirects the standard output and standard error of the class to the shell, which displays them as with any other command output. The destination of standard out and standard error for Java classes that run in the database is one or more database server process trace files, which are inconvenient and may require DBA privileges to read.
                        
The syntax of the command with runjava mode off is:
                        
java [-schema schema] class [arg1 ... argn]
The syntax of the command with runjava mode on is:
                        
java [command-line options] class [arg1 ... argn]
where, command-line options can be any of those mentioned in Table 3-1.
The following table summarizes the arguments of this command.
Table 13-6 java Argument Summary
| Argument | Description | 
|---|---|
| 
 | Names the Java class schema object that is to be run. | 
| 
 | Names the schema containing the class to be run. The default is the invoker's schema. The schema name is case-sensitive. | 
| 
 | Arguments to the  | 
Consider the following Java file, World.java:
                        
package hello;
public class World
{
  public World()
  {
    super();
  }
  public static void main(String[] argv)
  {
    System.out.println("Hello from Oracle Database");
    if (argv.length != 0)
      System.out.println("You supplied " + argv.length + " arguments: ");
    for (int i = 0; i < argv.length; i++)
      System.out.println(" arg[" + i + "] : " + argv[i]);
  }
}
You can compile, load, publish, and run the class, as follows:
% javac hello/World.java
% loadjava -r -user HR@localhost:2481:orcl hello/World.class
Password: password
% ojvmjava -user HR -database localhost:2481:orcl
Password: password
$ java hello.World alpha beta
Hello from Oracle Database
You supplied 2 arguments:
arg[0] : alpha
arg[1] : beta
version
This command shows the version of the ojvmjava tool. You can also show the version of a specified command. The syntax of this command is:
                        
version [options] [command]
For example, you can display the version of the shell, as follows:
$ version 1.0
whoami
This command displays the user name of the user who logged in to the current session. The syntax of the command is:
whoami
connect
This command enables the client to drop the current connection and connect to different databases without having to reinvoke the ojvmjava tool with a different connection description.
                        
The syntax of this command is:
connect [-service service] [-user user][-password password]
You can use this command as shown in the following examples:
connect -s thin@locahost:5521:orcl -u HR/<password> connect -s oci@locahost:5521:orcl -u HR -p <password>
The following table summarizes the arguments of this command.
Table 13-7 connect Argument Summary
| Argument | Description | 
|---|---|
| -service | -s | Any valid JDBC driver URLS, namely, oci @<connection descriptor> and thin@<host:port:db> | 
| 
 | User to connect as | 
| -password | -p | Password to connect with | 
runjava
This command queries or modifies the runjava mode. The runjava mode determines whether or not the java command uses the command-line interface to run executables. The java command:
                        
- 
                              Uses the command-like interface when runjavamode ison
- 
                              Uses database resident executables when runjavamode isoff
Using the runjava command with no arguments displays the current setting of runjava mode. 
                        
The following table summarizes the arguments of this command.
Table 13-8 runjava Argument Summary
| Argument | Description | 
|---|---|
| 
 | Turns  | 
| 
 | Turns  | 
| 
 | Turns  | 
jdwp
This command queries or modifies whether and how a debugger connection is listened for when an executable is run by the Java command.
Note:
The RDBMS session, prior to starting the executable, executes a DBMS_DEBUG_JDWP.CONNECT_TCP call with the specified port and host. This is called Listening.
Using this command with no arguments displays the current setting.
The following table summarizes the arguments of this command.
Table 13-9 jdwp Argument Summary
| Argument | Description | 
|---|---|
| off | Stops listening in future executables. | 
| 
 | Enables listening and specifies the port to be used. | 
| host | Enables listening and specifies the host to be used. The default value for this argument is  |