python jdbc连接sybase_sybase的jdbc连接

本文介绍了作者在使用Python通过JDBC连接Sybase数据库时遇到的问题及解决过程。通过下载jConnect驱动并尝试不同版本,最终发现需要设置JDBC_HOME,并调整驱动类路径。文中给出了成功的Java代码示例,展示了如何建立连接并执行SQL查询。
摘要由CSDN通过智能技术生成

在sybase网站上下载了两个jdbc的驱动

jConnect-5_5.zip

jConnect-6_05.zip

在网上搜罗了一下如何使用jdbc连接sybase。

很明显 那些大全里写的那些文字根本不正确。

这是一个典型的例子,(当然 我没有调试成功)

--

Class.forName("com.sybase.jdbc.SybDriver").newInstance();

String url =" jdbc:sybase:Tds:localhost:5007/myDB";//myDB为你的数据库名

Properties sysProps = System.getProperties();

SysProps.put("user","userid");

SysProps.put("password","user_password");

Connection conn= DriverManager.getConnection(url, SysProps);

--

解压jConnect-5_5.zip后看到驱动jconn2.jar,使用winrar打开浏览一下

com.sybase.jdbc.SybDriver的路径不正确 好像是com.sybase.jdbcx.SybDriver

改后仍旧不成功。

不过,设置JDBC_HOME后,带的一个工具jisql是运行成功的。这给了我很大的鼓舞。

毕竟,人家能连接,我也要试试。

忍住头皮,看docs。

翻阅了一小会儿,就有了眉目。

这个文档叫docs\en\progref\prjdbcp6.htm ,很短,正是我想要的。试试去

我虽然java不精通,调试小程序还是很容易的,加上eclipse很智能,程序很快就调试过去了。

下面是程序

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

import java.util.Properties;

import com.sybase.jdbcx.SybDriver;

public class T1 {

/**

*T1.java

* @param args

*/

public static void main(String[] args) {

try {

SybDriver  sybDriver = (SybDriver)

Class.forName   ("com.sybase.jdbc2.jdbc.SybDriver").newInstance();

sybDriver.setVersion

(com.sybase.jdbcx.SybDriver.VERSION_5);

DriverManager.registerDriver(sybDriver);

//Class.forName("com.sybase.jdbcx.SybDriver").newInstance();

} catch (InstantiationException e) {

// TODO 自动生成 catch 块

e.printStackTrace();

} catch (IllegalAccessException e) {

// TODO 自动生成 catch 块

e.printStackTrace();

} catch (ClassNotFoundException e) {

// TODO 自动生成 catch 块

e.printStackTrace();

} catch (SQLException e) {

// TODO 自动生成 catch 块

e.printStackTrace();

}

String url =" jdbc:sybase:Tds:192.168.0.43:5000";

Properties sysProps = System.getProperties();

sysProps.put("user","sa");

sysProps.put("password","");

try {

Connection conn= DriverManager.getConnection(url, sysProps);

Statement stmt = null;

stmt = conn.createStatement();

ResultSet rs = stmt.executeQuery("select * from spt_datatype_info");

System.out.println("

while (rs.next())

System.out.println(rs.getString(1)+"-"+rs.getString(2));

System.out.println("->");

} catch (SQLException e) {

e.printStackTrace();

}

}

}

好像可以写得通用一点 哦

阅读(10212) | 评论(1) | 转发(0) |

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值