gpt4 book ai didi

jakarta-ee - JDBC-Teradata 连接错误

转载 作者:行者123 更新时间:2023-12-03 12:29:14 24 4
gpt4 key购买 nike

我曾尝试通过 JDBC 连接到 teredata DB。我正在使用 jars 'terajdbc4.jar' 和 'tdgssconfig.jar',但我得到一个 ClassNotFoundExceptionNoClassDefFoundError对于某种东西 com.ncr.teradata.jtdgss.TdgssManager没有找到。

请帮我找到解决办法。我提供了我的代码片段,然后是错误日志。
用户名和密码正确,因为使用该 ID 通过 UNIX 连接到 teradata DB。

public class HelloTeradataJDBC {


public static void main(String[] args) throws Exception {

String url="jdbc:teradata://10.10.***.**/DBS_PORT= 1025/DATABASE= ******/TMODE=ANSI,CHARSET=UTF8";

try{
Class.forName("com.ncr.teradata.TeraDriver");
Connection conn=DriverManager.getConnection(url, "*****", "******");
//Connection conn=DriverManager.getConnection(connurl, "javauser1", "password1");

String query="select * from xi.san_emp";


PreparedStatement stmt=conn.prepareStatement(query);
ResultSet rs=stmt.executeQuery();
while(rs.next()) {
String col1=rs.getString(1);
System.out.println("col1="+col1);
}
}catch(ClassNotFoundException e){
e.printStackTrace();
}
}
}

错误:
Exception in thread "main" java.lang.NoClassDefFoundError: com/ncr/teradata/jtdgss/TdgssManager
at com.ncr.teradata.TeraEncrypt.getTDgssVersion(TeraEncrypt.java:548)
at com.ncr.teradata.jdbc_4.parcel.ConfigFeatureTdgss.<init>(ConfigFeatureTdgss.java:44)
at com.ncr.teradata.jdbc_4.statemachine.InitDBConfigState.action(InitDBConfigState.java:68)
at com.ncr.teradata.jdbc_4.statemachine.LogonController.run(LogonController.java:50)
at com.ncr.teradata.jdbc_4.TDSession.<init>(TDSession.java:150)
at com.ncr.teradata.jdbc_3.ifjdbc_4.TeraLocalConnection.<init>(TeraLocalConnection.java:89)
at com.ncr.teradata.jdbc.ConnectionFactory.createConnection(ConnectionFactory.java:50)
at com.ncr.teradata.TeraDriver.connect(TeraDriver.java:214)
at java.sql.DriverManager.getConnection(DriverManager.java:582)
at java.sql.DriverManager.getConnection(DriverManager.java:185)
at HelloTeradataJDBC.main(HelloTeradataJDBC.java:15)
Caused by: java.lang.ClassNotFoundException: com.ncr.teradata.jtdgss.TdgssManager
at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
... 11 more

最佳答案

这将起作用。驱动程序名称是 com.teradata.jdbc.TeraDriver 而不是 com.ncr.teradata.TeraDriver ,我认为它已经过时了。

Class.forName("com.teradata.jdbc.TeraDriver");
conn = DriverManager.getConnection("jdbc:teradata://"+servername+"/databasename="+this.username+",user="+this.username+",password="+this.password);

关于jakarta-ee - JDBC-Teradata 连接错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22219912/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com