我不想要odbc数据源配置,想要直接读取access文件 这是java程序
为什么会在哪个位置报错?(红色点的那一行)代码如下:packagezhishiwenda;importjava.sql.Connection;importjava.sql...
为什么会在哪个位置报错?(红色点的那一行)
代码如下:
package zhishiwenda;
import java.sql.Connection;import java.sql.Statement;import java.sql.ResultSet;import java.sql.DriverManager;
public class ART5 { public static void main(String[] args) throws Exception { String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};" + "DBQ=./timu/qs.mdb"; Connection conn = null; Statement stmt = null; ResultSet rs = null; try { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); conn = DriverManager.getConnection(url,"",""); stmt = conn.createStatement(); String command = "select * from qs1"; rs = stmt.executeQuery(command);
while (rs.next()) { String x1 = rs.getString(1); String x2 = rs.getString(2); String x3 = rs.getString(3); String x4 = rs.getString(4); float x5 = rs.getFloat(5); String x6 = rs.getString(6); System.out.print(" " + x1 + " "); System.out.print(" " + x2 + " "); System.out.print(" " + x3 + " "); System.out.print(" " + x4 + " "); System.out.print(" " + x5 + " "); System.out.print(" " + x6 + " "); } } catch (Exception e) { e.printStackTrace(); } finally { if (rs != null && !rs.isClosed()) { rs.close(); } if (stmt != null && !stmt.isClosed()) { stmt.close(); } if (conn != null && !conn.isClosed()) { conn.close(); } } }
} 展开
代码如下:
package zhishiwenda;
import java.sql.Connection;import java.sql.Statement;import java.sql.ResultSet;import java.sql.DriverManager;
public class ART5 { public static void main(String[] args) throws Exception { String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};" + "DBQ=./timu/qs.mdb"; Connection conn = null; Statement stmt = null; ResultSet rs = null; try { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); conn = DriverManager.getConnection(url,"",""); stmt = conn.createStatement(); String command = "select * from qs1"; rs = stmt.executeQuery(command);
while (rs.next()) { String x1 = rs.getString(1); String x2 = rs.getString(2); String x3 = rs.getString(3); String x4 = rs.getString(4); float x5 = rs.getFloat(5); String x6 = rs.getString(6); System.out.print(" " + x1 + " "); System.out.print(" " + x2 + " "); System.out.print(" " + x3 + " "); System.out.print(" " + x4 + " "); System.out.print(" " + x5 + " "); System.out.print(" " + x6 + " "); } } catch (Exception e) { e.printStackTrace(); } finally { if (rs != null && !rs.isClosed()) { rs.close(); } if (stmt != null && !stmt.isClosed()) { stmt.close(); } if (conn != null && !conn.isClosed()) { conn.close(); } } }
} 展开
2个回答
展开全部
数据库文件是二进制文件,不能像操作文本文件那样同过java程序直接读取,Access数据库是依赖于操作系统的,并且只能在WINDOWS的操作系统上读取。一般就用ODBC来读取。
oracle, sqlserver,db2等数据库用JDBC来操作数据库(实际上是SUN公式定义了接口,各数据库厂商实现JDBC接口来操作数据库的,各数据库实现方式不一样)。
所以,ACCESS就只能用odbc来读取, 这是java提供的操作ACCESS的标准方法.
在使用JDBC读取SQLSERVER的时候要用配置文件配置4个参数 url driver username password
这样才能便于程序的移植。
oracle, sqlserver,db2等数据库用JDBC来操作数据库(实际上是SUN公式定义了接口,各数据库厂商实现JDBC接口来操作数据库的,各数据库实现方式不一样)。
所以,ACCESS就只能用odbc来读取, 这是java提供的操作ACCESS的标准方法.
在使用JDBC读取SQLSERVER的时候要用配置文件配置4个参数 url driver username password
这样才能便于程序的移植。
更多追问追答
追问
就是用jdbc的话
移植到其他电脑的话,也必须装有sql才能正常使用软件?是这样么?
追答
不一定,如果mysql装到其他电脑上的也能连接,方法是配置url
"jdbc:mysql://127.0.0.1:3306/wend" 其中127.0.0.1 表示IP地址, 3306是默认端口号, wend是数据库名称。 前台是服务器能访问配置的IP地址。
2014-05-17
展开全部
如果64位的平台,使用32位的ODBC,就不能使用,会爆错
更多追问追答
追问
我不进行配置odbc
就读取access的方法。
通过配置odbc的方法读取access的方法我会了!
现在问的是,不通过配置odbc进行读取access
追答
上面的代码,就是直接访问.mdb文件。
先排除64位的平台、使用32位的ODBC的情况。。。。。。
再说说你现在碰到的具体的错误信息。因为上面图片中的红字不是具体的错误信息,只是出错信息的一部分。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询