Java程序是一个平台无关的程序语言,它能够运行在各种操作系统上。而数据库是程序存储、管理数据的重要方式。因此,Java与数据库的配合是非常重要的。
Java连接SQL数据库可使用多种方式,其中ODBC(Open>服务器名称和数据库名称即可。
2.引入ODBC驱动程序
Java连接SQL数据库需要查询ODBC驱动程序,并把其引入Java程序中。ODBC驱动程序在Windows操作系统中通常是预装的,但为确保ODBC驱动程序已安装,可进入“ODBC数据源管理器”,查看驱动程序的所有数据源。
在Java程序中引入ODBC驱动程序的方式如下:
Class.ForName(“sun.jdbc.odbc.JdbcOdbcDriver”);
其中,“sun.jdbc.odbc.JdbcOdbcDriver”为ODBC驱动程序的类名。在调用此语句时,会创建一个ODBC驱动程序的实例。
3.连接数据库
Java连接SQL数据库还需要连接数据库。连接数据库需要提供ODBC数据源的名称、用户名和密码等信息。在本例中,我们已经创建了一个名为TestDB的数据库,并建立了一个名为TestTable的数据表。
连接数据库的方式如下:
Connection conn = DriverManager.getConnection(“jdbc:odbc:TestDB”, “用户名”, “密码”);
其中,“jdbc:odbc:TestDB”为ODBC数据源的名称,“用户名”和“密码”为连接数据库所需的用户名和密码。
4.执行SQL语句
连接到数据库后,就可以执行SQL语句了。在本例中,我们想要查询TestTable数据表中的所有数据。
执行SQL语句的方式如下:
Statement stmt = conn.CREATEStatement();
ResultSet rs = stmt.executeQuery(“select * from TestTable”);
while(rs.next()) {
System.out.println(rs.getString(“column1″) + ” ” + rs.getString(“column2”));
其中,“select * from TestTable”为要执行的SQL语句,executeQuery方法会返回一个ResultSet对象;rs.next()将指针移到ResultSet对象的下一行;rs.getString(“column1”)和rs.getString(“column2”)分别为数据表TestTable中的列名。
5.关闭连接
执行完SQL语句后,应关闭连接。关闭连接的方式如下:
rs.close();
stmt.close();
conn.close();
其中,ResultSet对象、Statement对象和Connection对象依次关闭即可。

是一种简单、易懂的方式。ODBC驱动程序为用户提供了方便快捷的接口,并保证了数据库的兼容性,使其成为连接Java与SQL数据库的首选方式。我们希望本文对有了更深入的了解。
相关问题拓展阅读:
Java中如何实现与后台数据库的连接?
用JAVA连接数据库主要有两种方式,一是用JDBC-ODBC桥来连接,二是用脊旅相关厂商提供的相应驱动程序来连接,首先谈谈之一种连接。 \x0d\x0a\x0d\x0aJDBC-ODBC桥接器是用JdbcOdbc.Class和一个用于访问ODBC驱动程序的本地库实现的。对于WINDOWS平台,该本地库是一个动态连接库DLL(JDBCODBC.DLL)。 \x0d\x0a\x0d\x0a由于JDBC在设计上与ODBC很接近。在内部,这个驱动程序把JDBC的方法映射到ODBC调用上,这样,JDBC就可以和任何可用的ODBC驱动程序进行交互了。这种桥接器的优点是,它使JDBC目前有能力访问几乎所有的数据库。通行方式如图所示: \x0d\x0a\x0d\x0a应用程序—JDBC API—JDBC-ODBC—ODBC API—ODBC层—数据源 \x0d\x0a\x0d\x0a具体操作方法为: \x0d\x0a\x0d\x0a首先打开控制面板的管理工具,打开数据源(ODBC),在用户DSN里面添加数据源(即你要连接的数据库的名字),在这里假定连接SQL SERVER 2023的GoodsSupply数据库。名称填写你要连接的数据库的名称(GoodsSupply),然后逐步设置,如果选用了使用SQL-SERVER密丛贺码认证的话,就要输入相应的用户名及密码连接到数据库。一路下一步设置完成。 \x0d\x0a\x0d\x0a在JAVA里面编写程序进行测试,在这里我的程序是让用户输入任意的表名与与列名,把该列的所有数据输出。源代码如下: \x0d\x0a\x0d\x0aimport java.io.BufferedReader; \x0d\x0aimport java.io.InputStreamReader; \x0d\x0aimport java.sql.*; \x0d\x0a\x0d\x0apublic class ODBCBridge { \x0d\x0a\x0d\x0apublic static void main(String args) { \x0d\x0aString URL=”jdbc:odbc:GoodsSupply”; \x0d\x0aStatement =null; \x0d\x0aString command=null; \x0d\x0aResultSet rs=null; \x0d\x0aString tableName=null; \x0d\x0aString cName=null; \x0d\x0aString result=null; \x0d\x0aBufferedReader input=new BufferedReader(new InputStreamReader(System.in)); \x0d\x0atry { \x0d\x0atry { \x0d\x0aClass.forName(“sun.jdbc.odbc.JdbcOdbcDriver”); //加载驱动 \x0d\x0a}catch(ClassNotFoundException e){ \x0d\x0aSystem.out.println(“Can not load Jdbc-Odbc Bridge Driver”); \x0d\x0aSystem.err.print(“ClassNotFoundException:”); \x0d\x0aSystem.err.println(e.getMessage()); \x0d\x0a} \x0d\x0aConnection con=DriverManager.getConnection(url,”USER”,”PASSWORD”); //使用SQL-SERVER2023认证 \x0d\x0aDatabaseMetaData dmd=con.getMetaData(); //DMD为连接的渗野派相应情况 \x0d\x0aSystem.out.println(“连接的数据库:”+dmd.getURL()); \x0d\x0aSystem.out.println(“驱动程序:”+dmd.getDriverName()); \x0d\x0a=con.createStatement(); \x0d\x0aSystem.out.println(“输入表名”); \x0d\x0atableName=input.readLine(); \x0d\x0awhile(true) { \x0d\x0aSystem.out.println(“输入列名(为空时程序结束):”); \x0d\x0acName=input.readLine(); \x0d\x0aif(cName.equalsIgnoreCase(“”)) \x0d\x0abreak; \x0d\x0acommand=”select “+cName+” from “+tableName; \x0d\x0ars=.executeQuery(command); //执行查询 \x0d\x0aif(!rs.next()) \x0d\x0aSystem.out.println(“表名或列名输入有误”); \x0d\x0aelse { \x0d\x0aSystem.out.println(“查询结果为:”); \x0d\x0ado \x0d\x0a{ \x0d\x0aresult=rs.getString(cName); \x0d\x0a//数据库语言设置为中文,不用转换编码 \x0d\x0a//result=new String(result.getBytes(“ISO”),”GB2312″); \x0d\x0aSystem.out.println(result); \x0d\x0a}while(rs.next()); \x0d\x0a} \x0d\x0a} \x0d\x0a}catch(SQLException ex) { \x0d\x0aSystem.out.println(“SQLException:”); \x0d\x0awhile(ex!=null) { \x0d\x0aSystem.out.println(“Message:”+ex.getMessage()); \x0d\x0aex=ex.getNextException(); \x0d\x0a} \x0d\x0a}catch(Exception e) { \x0d\x0aSystem.out.println(“IOException”); \x0d\x0a} \x0d\x0a} \x0d\x0a}
关于java odbc连接sql数据库的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
香港服务器首选树叶云,2H2G首月10元开通。树叶云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
JAVA如何连接数据库SQL
import ; //都是导入一些下面需要用到的类 String ConnStr=jdbc:microsoft:sqlserver://WINJUE:1433;DatabaseName=library;//jdbc连接数据库url public sqlServer() { try { (DBDriver)(); //加载SQLServer驱动程序,DBDriver是你上面的代码; conn=(ConnStr,sa,sa); //和数据库建立连接,ConnStr里面的://WINJUE:1433;DatabaseName=library 分别是主机地址:端口号;你自己建的数据库(database) } catch(SQLException e) { //捕获SQL异常 (()); //要是出现异常,捕获到后,这句代码会把异常的信息(出错的原因之类的)打印出来。 } catch(Exception e) { //捕获异常,这个是总的,所以不能和上面的顺序颠倒,先小到大,我连ORACLE和MYSQL,这个我通常不要,只须捕获SQL异常就OL (()); } } public Connection getConn(){ //获取连接方法 return conn; } public void insert(String sql) {//增删改 try { Statement stm=(); 调用conn下的方法,创建Statement对象 (sql);//调用Statement下的方法执行SQL语句 (操作成功); } catch(Exception e){ (()); //如上 } } public ResultSet query(String sql){ //查询 try{ Statement stm=(_SCROLL_SENSITIVE,_UPDATABLE); rs=(sql); //如上 } catch(Exception e){ (()); } return rs; } public static void main(String args[]){ sqlServer conn=new sqlServer(); //创建sqlServer,就是你上面的类,以便调用里面的方法 ResultSet rs=(select * from Orders); //调用query方法,执行SQL语句后,把结果保存到结果集里 //(delete from BookInfo where BookName = +\悟空传\); //(insert into BookInfo (BookID,BookName,Author,KeyWord) values (,悟空传,今何在,孙悟空)); try{ while(()){ //循环,判断结果集里的记录,一条条往下走,是否还有下一条记录,若是返回真,继续走 ((OrderID)); //((U_age)); } () ; //关闭结果集 } catch (Exception e){ (()); } } } 注: TYPE_FORWARD_ONLY:缺省类型。 只允许向前访问一次,并且不会受到其他用户对该数据库所作更改的影响。 TYPE_SCROLL_INSENSITIVE:允许在列表中向前或向后移动,甚至能进行特定定位,例如移至列表中的第四个记录或从当前位置向后移动两个记录。 不会受到其他用户对该数据库所作更改的影响。 TYPE_SCROLL_SENSITIVE:象 TYPE_SCROLL_INSENSITIVE 相同,允许在记录中定位。 这种类型受到其他用户所作更改的影响。 如果用户在执行完查询之后删除一个记录,那个记录将从 ResultSet 中消失。 类似的,对数据值的更改也将反映在 ResultSet 中。
怎样快速检测与sql数据库是否能正常连接
1、右键计算机,点击管2113理。 2、如图找到5261SQL Server配置管理器。 3、如图找到SQL Server网络配置下的msSQLSERVER,然4102后把TCP/IP状态1653改为启用。 4、打开SQL server数据库,按照图内进行操作,然后点击连接,那么就可以连接到别人(容或自己)的数据库
如何建立java程序与sql数据库的连接?
jdbc连接各种数据库方式列表:下面罗列了各种数据库使用JDBC连接的方式,可以作为一个手册使用。1、Oracle8/8i/9i数据库(thin模式)()();String url=jdbc:oracle:thin:@localhost:1521:orcl; //orcl为数据库的SIDString user=test;String password=test;Connection conn= (url,user,password);2、DB2数据库(2Driver )();String url=jdbc:db2://localhost:5000/sample; //sample为你的数据库名String user=admin;String password=;Connection conn= (url,user,password);3、Sql Server7.0/2000数据库()();String url=jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb;//mydb为数据库String user=sa;String password=;Connection conn= (url,user,password);4、Sybase数据库()();String url = jdbc:sybase:Tds:localhost:5007/myDB;//myDB为你的数据库名Properties sysProps = ();(user,userid);(password,user_password);Connection conn= (url, SysProps);5、Informix数据库()();String url = jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;user=testuser;password=testpassword; //myDB为数据库名Connection conn= (url);6、MySQL数据库()();//或者();String url =jdbc:mysql://localhost/myDB?user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1//myDB为数据库名Connection conn= (url);7、PostgreSQL数据库()();String url =jdbc:postgresql://localhost/myDB //myDB为数据库名String user=myuser;String password=mypassword;Connection conn= (url,user,password);8、access数据库直连用ODBC的() ;String url=jdbc:odbc:Driver={MicroSoft Access Driver (*)};DBQ=+(/Data/);Connection conn = (url,,);Statement stmtNew=() ;
发表评论