mirror of
https://github.com/MariaDB/server.git
synced 2025-08-08 11:22:35 +03:00
All changes made on 10.1 for last 11 commits
This commit is contained in:
183
storage/connect/Client.java
Normal file
183
storage/connect/Client.java
Normal file
@@ -0,0 +1,183 @@
|
||||
package wrappers;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.Console;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStreamReader;
|
||||
|
||||
public class Client {
|
||||
static boolean DEBUG = true;
|
||||
static final Console c = System.console();
|
||||
static JdbcInterface jdi = null;
|
||||
|
||||
public static void main(String[] args) {
|
||||
int rc, n, ncol, i = 0, fsize = 0;
|
||||
boolean scrollable = false;
|
||||
String s;
|
||||
String[] parms = new String[4];
|
||||
|
||||
if (args.length > 0)
|
||||
try {
|
||||
i = Integer.parseInt(args[i]);
|
||||
} catch (NumberFormatException e) {
|
||||
i = 0;
|
||||
} // end try/catch
|
||||
|
||||
switch (i) {
|
||||
case 1:
|
||||
jdi = new ApacheInterface(DEBUG);
|
||||
break;
|
||||
case 2:
|
||||
jdi = new MysqlInterface(DEBUG);
|
||||
break;
|
||||
case 3:
|
||||
jdi = new MariadbInterface(DEBUG);
|
||||
break;
|
||||
case 4:
|
||||
jdi = new OracleInterface(DEBUG);
|
||||
break;
|
||||
case 5:
|
||||
jdi = new PostgresqlInterface(DEBUG);
|
||||
break;
|
||||
default:
|
||||
jdi = new JdbcInterface(DEBUG);
|
||||
} // endswitch i
|
||||
|
||||
parms[0] = getLine("Driver: ", false);
|
||||
parms[1] = getLine("URL: ", false);
|
||||
parms[2] = getLine("User: ", false);
|
||||
parms[3] = getLine("Password: ", true);
|
||||
s = getLine("Fsize: ", false);
|
||||
fsize = (s != null) ? Integer.parseInt(s) : 0;
|
||||
s = getLine("Scrollable: ", false);
|
||||
scrollable = (s != null) ? s.toLowerCase().charAt(0) != 'n' : false;
|
||||
|
||||
rc = jdi.JdbcConnect(parms, fsize, scrollable);
|
||||
|
||||
if (rc == 0) {
|
||||
String query;
|
||||
System.out.println("Successfully connected to " + parms[1]);
|
||||
|
||||
while ((query = getLine("Query: ", false)) != null) {
|
||||
n = jdi.Execute(query);
|
||||
System.out.println("Returned n = " + n);
|
||||
|
||||
if ((ncol = jdi.GetResult()) > 0)
|
||||
PrintResult(ncol);
|
||||
else
|
||||
System.out.println("Affected rows = " + n);
|
||||
|
||||
} // endwhile
|
||||
|
||||
rc = jdi.JdbcDisconnect();
|
||||
System.out.println("Disconnect returned " + rc);
|
||||
} else
|
||||
System.out.println(jdi.GetErrmsg() + " rc=" + rc);
|
||||
|
||||
} // end of main
|
||||
|
||||
private static void PrintResult(int ncol) {
|
||||
// Get result set meta data
|
||||
int i;
|
||||
String columnName;
|
||||
|
||||
// Get the column names; column indices start from 1
|
||||
for (i = 1; i <= ncol; i++) {
|
||||
columnName = jdi.ColumnName(i);
|
||||
|
||||
if (columnName == null)
|
||||
return;
|
||||
|
||||
// Get the name of the column's table name
|
||||
//String tableName = rsmd.getTableName(i);
|
||||
|
||||
if (i > 1)
|
||||
System.out.print("\t");
|
||||
|
||||
System.out.print(columnName);
|
||||
} // endfor i
|
||||
|
||||
System.out.println();
|
||||
|
||||
// Loop through the result set
|
||||
while (jdi.ReadNext() > 0) {
|
||||
for (i = 1; i <= ncol; i++) {
|
||||
if (i > 1)
|
||||
System.out.print("\t");
|
||||
|
||||
if (DEBUG)
|
||||
System.out.print("(" + jdi.ColumnType(i, null) + ")");
|
||||
|
||||
switch (jdi.ColumnType(i, null)) {
|
||||
case java.sql.Types.VARCHAR:
|
||||
case java.sql.Types.LONGVARCHAR:
|
||||
case java.sql.Types.CHAR:
|
||||
System.out.print(jdi.StringField(i, null));
|
||||
break;
|
||||
case java.sql.Types.INTEGER:
|
||||
System.out.print(jdi.IntField(i, null));
|
||||
break;
|
||||
case java.sql.Types.BIGINT:
|
||||
System.out.print(jdi.BigintField(i, null));
|
||||
break;
|
||||
case java.sql.Types.TIMESTAMP:
|
||||
System.out.print(jdi.TimestampField(i, null));
|
||||
break;
|
||||
case java.sql.Types.TIME:
|
||||
System.out.print(jdi.TimeField(i, null));
|
||||
break;
|
||||
case java.sql.Types.DATE:
|
||||
System.out.print(jdi.DateField(i, null));
|
||||
break;
|
||||
case java.sql.Types.SMALLINT:
|
||||
System.out.print(jdi.IntField(i, null));
|
||||
break;
|
||||
case java.sql.Types.DOUBLE:
|
||||
case java.sql.Types.REAL:
|
||||
case java.sql.Types.FLOAT:
|
||||
case java.sql.Types.DECIMAL:
|
||||
System.out.print(jdi.DoubleField(i, null));
|
||||
break;
|
||||
case java.sql.Types.BOOLEAN:
|
||||
System.out.print(jdi.BooleanField(i, null));
|
||||
default:
|
||||
break;
|
||||
} // endswitch Type
|
||||
|
||||
} // endfor i
|
||||
|
||||
System.out.println();
|
||||
} // end while rs
|
||||
|
||||
} // end of PrintResult
|
||||
|
||||
// ==================================================================
|
||||
private static String getLine(String p, boolean b) {
|
||||
String response;
|
||||
|
||||
if (c != null) {
|
||||
// Standard console mode
|
||||
if (b) {
|
||||
response = new String(c.readPassword(p));
|
||||
} else
|
||||
response = c.readLine(p);
|
||||
|
||||
} else {
|
||||
// For instance when testing from Eclipse
|
||||
BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
|
||||
|
||||
System.out.print(p);
|
||||
|
||||
try {
|
||||
// Cannot suppress echo for password entry
|
||||
response = in.readLine();
|
||||
} catch (IOException e) {
|
||||
response = "";
|
||||
} // end of try/catch
|
||||
|
||||
} // endif c
|
||||
|
||||
return (response.isEmpty()) ? null : response;
|
||||
} // end of getLine
|
||||
|
||||
} // end of class Client
|
Reference in New Issue
Block a user