标签: jdbc-odbc

在java 8中删除JDBC ODBC桥

从Java 8开始,JDK将不再包含JDBC-ODBC Bridge.

Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); // classNotFoundException is thrown
Run Code Online (Sandbox Code Playgroud)

有没有其他解决方案连接JDBC-ODBC Bridge?

java jdbc-odbc java-8

34
推荐指数
4
解决办法
6万
查看次数

java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常.为什么?

我创建了一个MS Access数据库并为其分配了一个DSN.我想通过我的Java应用程序访问它.

这就是我在做的事情:

public class AccessDbConnection {

    public static void main(String[] args) {
        System.out.println("**ACCESS DB CONNECTION**");

        try {
            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); // for MS Access ... MS access driver loading

            String     conURL    = "jdbc:odbc:sampleDNS";
            Connection con       = DriverManager.getConnection(conURL);
            Statement  statement = con.createStatement();
            String     qry       = "SELECT * FROM Table1";
            ResultSet  rs        = statement.executeQuery(qry);

            while(rs.next()) {
                String id    = rs.getString("ID") ;
                String fname = rs.getString("First_Name");
                String lname = rs.getString("Last_Name");
                System.out.println(id + fname + lname);
            }
        } catch (ClassNotFoundException ex) {
            System.out.println("Classforname Exception!!");
            Logger.getLogger(AccessDbConnection.class.getName()).log(Level.SEVERE, …
Run Code Online (Sandbox Code Playgroud)

java ms-access jdbc jdbc-odbc

31
推荐指数
2
解决办法
18万
查看次数

java的最佳开源dbf驱动程序是什么?

任何人都可以提一下最好的开源odbc:jdbc驱动程序来读/写dbf.我有一个dbf文件,我想通过Web应用程序(Tomcat应用程序)查询(选择/更新).

任何帮助/提示都会很有意义.

谢谢.

java dbf jdbc-odbc

16
推荐指数
2
解决办法
3万
查看次数

ResultSet:异常:set type是TYPE_FORWARD_ONLY - 为什么?

我有非常简单的代码:

pstat=con.prepareStatement("select typeid from users where username=? and password=?");             
pstat.setString(1, username);
pstat.setString(2, password);
rs=pstat.executeQuery();
int rowCount=0;
while(rs.next())
{       
    rowCount++;         
}
rs.beforeFirst();
if(rowCount>=1)
{
while(rs.next())
{
    typeID=rs.getInt(1);
}
Run Code Online (Sandbox Code Playgroud)

但是当执行这段代码时我得到了......

java.sql.SQLException: Result set type is TYPE_FORWARD_ONLY
at sun.jdbc.odbc.JdbcOdbcResultSet.beforeFirst(Unknown Source)
at server.ClientImpl.login(ClientImpl.java:57)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at sun.rmi.server.UnicastServerRef.dispatch(Unknown Source)
at sun.rmi.transport.Transport$1.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at sun.rmi.transport.Transport.serviceCall(Unknown Source)
at sun.rmi.transport.tcp.TCPTransport.handleMessages(Unknown Source)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(Unknown Source)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown …
Run Code Online (Sandbox Code Playgroud)

java sql resultset jdbc-odbc

13
推荐指数
5
解决办法
6万
查看次数

JDBC ODBC驱动程序连接

我目前正在为我的大学的一个班级做一个项目.我正在学习连接和操作数据库,我们正在使用Microsoft .accdb文件.

这是我到目前为止所拥有的.

/* Perform database operations */
    try {
        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
        System.out.println("Driver loaded");

        connection = DriverManager.getConnection("jdbc:odbc:Lab3.accdb");
        System.out.println("Database connected");

        statement = connection.createStatement();

        ResultSet resultSet = statement.executeQuery("");

        while (resultSet.next()) {
            output.write("<p>" + resultSet.getString(1) + "\t" +
                resultSet.getString(2) + "\t" + resultSet.getString(3) + "</p>");
        }

        connection.close();
    } catch (ClassNotFoundException|SQLException e) {
        System.out.println("Database Access Error.");
        e.printStackTrace();
    }
Run Code Online (Sandbox Code Playgroud)

在寻找"sun.jdbc.odbc.JdbcOdbcDriver"时,我得到以下输出.

SEVERE:   java.lang.ClassNotFoundException: sun.jdbc.odbc.JdbcOdbcDriver
at org.glassfish.web.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1761)
at org.glassfish.web.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1611)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:190)
at changepass.ChangePasswordServlet.processRequest(ChangePasswordServlet.java:47)
at changepass.ChangePasswordServlet.doGet(ChangePasswordServlet.java:83)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:687)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1682)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:318)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:160) …
Run Code Online (Sandbox Code Playgroud)

java macos ms-access jdbc jdbc-odbc

11
推荐指数
1
解决办法
10万
查看次数

使用Java 8操作旧版MDB(Access 2.0)

Java 8不再支持JDBC-ODBC桥.有没有办法在Java 8中没有桥接器的情况下访问旧版MDB文件?遗产,我的意思是Access 2.0.UCanAccess不支持这样的旧版本,这是在这里提出的.

java ms-access jdbc-odbc java-8

10
推荐指数
1
解决办法
979
查看次数

如何使用C++使用ODBC Driver API将数据绑定到SQLBindCol

我正在尝试使用C++为Windows环境(如PostgreSQL,Simba,Firebird等)创建自定义ODBC驱动程序,因为ODBC API 默认具有多个ODBC API方法.

我使用DSN建立了连接,并且我能够使用SQLExecuteDirect方法执行SQL查询.

但是,在将Excel与我们的ODBC驱动程序连接时,我无法将表列表绑定到Microsoft查询向导. 在此输入图像描述

SQLTABLES() ,SQLBindColumn() ,并且调用SQLFetch()方法用于检索这里的表名列表.使用SQLBindColumn方法绑定数据.

但我对如何检索表名并将它们绑定到Excel感到困惑?

c++ excel odbc jdbc-odbc

10
推荐指数
1
解决办法
639
查看次数

Java程序连接到Sql Server并运行示例查询来自Eclipse

package sqlselection;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class Sqlselection 
    {
        public static void main(String[] args)
        {
            try
            {
                Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");

                String userName = "sa";
                String password = "password";
                String url = "jdbc:microsoft:sqlserver://localhost:1433"+";databaseName=AdventureWorks2008R2";
                Connection con = DriverManager.getConnection(url, userName, password);
                Statement s1 = con.createStatement();
                ResultSet rs = s1.executeQuery("SELECT TOP 1 * FROM HumanResources.Employee");
                String[] result = new String[20];
                if(rs!=null){
                    while (rs.next()){
                        for(int i = 0; i <result.length ;i++)
                        {
                            for(int j = 0; j <result.length;j++)
                            {
                                result[j]=rs.getString(i);
                            System.out.println(result[j]);
                        } …
Run Code Online (Sandbox Code Playgroud)

java eclipse jdbc jdbc-odbc

8
推荐指数
2
解决办法
12万
查看次数

"常规错误无法从Access ODBC打开注册表项临时(volatile)..."

我尝试了以下方法:

private String password = "";
private String dbName = "dataHC.accdb";
private String bd = dbName + ";PWD=" + password;
String  url   = "jdbc:odbc:Driver={Microsoft Access Driver (*.mdb, *.accdb)};DBQ="+bd+";";

private Connection conn = null;

//Connect
public void connect() {
    try{
        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
        conn = DriverManager.getConnection(url);
        if (conn != null)
            System.out.println("Conexión a base de datos "+dbName+". listo");
    }catch(SQLException e){
        System.out.println(e);
    }catch(ClassNotFoundException e){
        System.out.println(e);
    }
}
Run Code Online (Sandbox Code Playgroud)

字体:http://www.jc-mouse.net/base-de-datos/consultas-con-parametros-en-access-y-java

我得到了这个错误:

[Microsoft] [ODBC Microsoft Access驱动程序]常规错误无法打开注册表项临时(易失性)Ace DSN进程0x7f8线程0x1174 DBC

特别

java.sql.SQLException: [Microsoft][ODBC Microsoft Access Driver]General error …
Run Code Online (Sandbox Code Playgroud)

ms-access odbc pyodbc jdbc-odbc

8
推荐指数
1
解决办法
3万
查看次数

org.hibernate.exception.GenericJDBCException的出现:无法为长时间运行的进程打开连接

在我的应用程序中,我使用20个线程来完成工作.每个线程调用远程Web服务并更新Oracle DB.Jboss重启后,作业无法更新数据库,但我在日志中找到的例外情况如下:

2017-11-08 23:36:20,706 ERROR [org.hibernate.engine.jdbc.spi.SqlExceptionHelper] (EJB default - 21) javax.resource.ResourceException: IJ000460: Error checking for a transaction
2017-11-08 23:36:20,706 ERROR [org.jboss.as.ejb3] (EJB default - 16) javax.ejb.EJBTransactionRolledbackException: org.hibernate.exception.GenericJDBCException: Could not open connection
2017-11-08 23:36:20,707 ERROR [org.jboss.as.ejb3] (EJB default - 20) javax.ejb.EJBTransactionRolledbackException: org.hibernate.exception.GenericJDBCException: Could not open connection
2017-11-08 23:36:20,707 ERROR [org.jboss.as.ejb3] (EJB default - 19) javax.ejb.EJBTransactionRolledbackException: org.hibernate.exception.GenericJDBCException: Could not open connection
2017-11-08 23:36:20,710 ERROR [org.jboss.as.ejb3] (EJB default - 21) javax.ejb.EJBTransactionRolledbackException: org.hibernate.exception.GenericJDBCException: Could not open connection
2017-11-08 23:36:20,711 ERROR [org.jboss.as.ejb3.invocation] (EJB default - …
Run Code Online (Sandbox Code Playgroud)

java multithreading ejb jpa jdbc-odbc

8
推荐指数
1
解决办法
5262
查看次数

标签 统计

jdbc-odbc ×10

java ×8

ms-access ×4

jdbc ×3

java-8 ×2

odbc ×2

c++ ×1

dbf ×1

eclipse ×1

ejb ×1

excel ×1

jpa ×1

macos ×1

multithreading ×1

pyodbc ×1

resultset ×1

sql ×1