我想连接远程Oracle数据库,但我有异常。请帮帮我。 我该怎么办?
我尝试了这个,但它不起作用:
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection con = DriverManager.getConnection(
"jdbc:oracle:thin:@*****:1521/******", "*********",
"********");
Statement st = con.createStatement();
con.close();
} catch (SQLException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
获取错误:
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: -1
at oracle.sql.converter.CharacterSetMetaData$JdbcCharacterSetMetaData.isFixedWidth(CharacterSetMetaData.java:1292)
at oracle.sql.converter.CharacterSetMetaData.getRatio(CharacterSetMetaData.java:1230)
at oracle.jdbc.driver.DBConversion.init(DBConversion.java:159)
at oracle.jdbc.driver.DBConversion.<init>(DBConversion.java:112)
at oracle.jdbc.driver.T4CConnection.connect(T4CConnection.java:1075)
at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:301)
at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:531)
at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:221)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:32)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:503)
at java.sql.DriverManager.getConnection(DriverManager.java:664)
at java.sql.DriverManager.getConnection(DriverManager.java:247)
答案 0 :(得分:0)
您的连接网址格式错误。您正在混合使用SID
和service
格式。
无论
DriverManager.getConnection(
"jdbc:oracle:thin:<user>/<password>@<host>:<port>:<sid>");
或
DriverManager.getConnection(
"jdbc:oracle:thin:@<host>:<port>:<sid>", "<user>", "<password>");
或者如果您连接到服务而不是SID
DriverManager.getConnection(
"jdbc:oracle:thin:<user>/<password>@//<host>:<port>/<service");
有关使用Properties
对象的示例,请查看javadoc of oracle.jdbc.OracleDriver
修改在此处找到Thin-style Service Name Syntax
的链接编辑2 启用驱动程序日志记录以查看是否存在一些有用的消息。
OracleLog.setTrace(true);
DriverManager.setLogWriter(new PrintWriter(System.out));
编辑3 这是一种通过反射查找服务器和驱动程序报告的字符集的方法。
出于许可原因,包裹声明很重要。
package oracle.jdbc.driver;
import java.lang.reflect.Field;
import java.sql.Connection;
import java.sql.DriverManager;
import oracle.sql.CharacterSet;
import sun.reflect.ReflectionFactory;
public class OJdbcInfo {
public static void main(String[] args) throws Exception {
OracleLog.setTrace(true);
DriverManager.setLogWriter(new PrintWriter(System.out));
System.out.printf("defaultCharset: %s%n", Charset.defaultCharset());
System.out.printf("file.encoding : %s%n",
System.getProperty("file.encoding"));
String connectUrl =
"jdbc:oracle:thin:<user>/<password>@<host>:<port>:<sid>";
try (Connection con = DriverManager.getConnection(connectUrl)) {
T4CConnection t4Conn = (T4CConnection) con;
T4C8TTIpro pro = t4Conn.pro;
short oVersion = pro.oVersion;
short svrCharSet = pro.svrCharSet;
short driverCharSet;
try {
driverCharSet = DBConversion.findDriverCharSet(
svrCharSet, oVersion);
} catch (ArrayIndexOutOfBoundsException e) {
System.err.printf("failed to get driver charset: %s%n",
e.getMessage());
driverCharSet = -1;
}
System.out.println("server charset: " + svrCharSet);
System.out.println("driver charset: " + driverCharSet);
Object instance = ReflectionFactory.getReflectionFactory()
.newConstructorForSerialization(
Class.forName("oracle.sql.CharacterSetFactoryThin"),
Object.class.getConstructor())
.newInstance();
for (Field fs : CharacterSet.class.getDeclaredFields()) {
if (fs.getType() == short.class) {
if (fs.getShort(instance) == driverCharSet) {
System.out.printf("charset name : %s%n", fs.getName());
}
}
}
}
}
}
编译
mkdir bin
javac -cp ojdbc6_g.jar -d bin/ OJdbcInfo.java
运行
java -cp ojdbc6_g.jar:bin/ oracle.jdbc.driver.OJdbcInfo
可能的输出
defaultCharset: UTF-8
file.encoding : UTF-8
server charset: 873
driver charset: 873
charset name : AL32UTF8_CHARSET
在你的情况下,驱动程序字符集很可能是-1
。
检查您是否使用了最新的驱动程序版本。
java -jar ojdbc6.jar
可能的输出
Oracle 11.2.0.4.0 JDBC 4.0 compiled with JDK6 on Thu_Jul_03_18:17:32_PDT_2014
检查Linux机器上的locale
设置
locale
可能的输出(取决于您的语言设置,但所有值通常应该相同)
LANG=en_US.UTF-8
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
答案 1 :(得分:0)
我测试了您正在使用的代码
DriverManager.getConnection(
"jdbc:oracle:thin:@<host>:<port>:<sid>", "<user>", "<password>");
所以在/
之间移除<port>/<sid>
并将:
放在<port>:<sid>
之间
您的更新代码将是
Connection con = DriverManager.getConnection( "jdbc:oracle:thin:@*****:1521:******", "*********", "********");
有关详细信息,请参阅此链接http://docs.oracle.com/cd/E11882_01/appdev.112/e12137/getconn.htm#TDPJD136
我希望,它会对你有帮助。