博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JAVA(2)——JDBC
阅读量:6168 次
发布时间:2019-06-21

本文共 3805 字,大约阅读时间需要 12 分钟。

    刚接触JDBC的时候,有时候就在想,为什么java要用JDBC,而不是直接使用之前在VB中就学习过的ODBC,由于ODBC是在JDBC之前出现,所以ODBC肯定由于无法完毕某些操作或者不能非常顺利的完毕某些操作,所以才有了JDBC的出现,那么,在JAVA的使用中,JDBC交ODBC究竟有哪些优势呢?

    那么,先简单的介绍一下ODBC:

    开放数据库互连(Open DatabaseConnectivity,ODBC)是微软公司开放服务结构(WOSA,Windows Open Services Architecture)中有关数据库的一个组成部分,它建立了一组规范,并提供了一组对数据库訪问的标准API(应用程序编程接口)。这些API利用SQL来完毕其大部分任务。ODBC本身也提供了对SQL语言的支持,用户能够直接将SQL语句送给ODBC。到眼下为止,微软的ODBC可能是用得最广泛的訪问关系数据库的API。它提供了连接差点儿不论什么一种平台、不论什么一种数据库的能力。

    那么,为什么不直接从Java中直接使用ODBC呢?

    回答是能够从Java中使用ODBC,但最好在JDBC的协助下,用JDBC-ODBC桥接器实现。那么,为什么须要JDBC呢?要回答这个问题,有这么几个方面:

    1)ODBC并不适合在Java中直接使用。ODBC是一个C语言实现的API,从Java程序调用本地的C程序会带来一系列类似安全性、完整性、健壮性的缺点

    2)其次,全然精确地实现从C代码ODBC到JavaAPI写的ODBC的翻译也并不令人惬意。比方,Java没有指针,而ODBC中大量地使用了指针,包含极易出错的空指针“void*”。因此,对Java程序猿来说,把JDBC设想成将ODBC转换成面向对象的API是非常自然的。

    3)ODBC并不easy学习,它将简单特性和复杂特性混杂在一起,甚至对很easy的查询都有复杂的选项。而JDBC刚好相反,它保持了简单事物的简单性,但又同意复杂的特性

    4)JDBC这种JavaAPI对于纯Java方案来说是必须的。当使用ODBC时,人们必须在每一台客户机上安装ODBC驱动器和驱动管理器。假设JDBC驱动器是全然用Java语言实现的话,那么JDBC的代码就能够自己主动的下载和安装,并保证其安全性,并且,这将适应不论什么Java平台,从网络计算机NC到大型主机Mainframe。

    总而言之,JDBCAPI是能体现SQL最基本抽象概念的、最直接的Java接口。它建构在ODBC的基础上,因此,熟悉ODBC的程序猿将发现学习JDBC很easy。JDBC保持了ODBC的基本设计特征。实际上,这两种接口都是基于X/OPENSQL的调用级接口(CLI)。它们的最大的不同是JDBC是基于Java的风格和长处,并强化了Java的风格和长处。

 

    所以,总结上面JDBC相对于ODBC的长处,我们也能够总结出JAVA安全、完整、健壮、易学习、可移植性的特点,这也正好是在中提到的一些特点,既然JDBC有这么多长处,那么我们如今就系统的介绍一下JDBC.

   JDBC(Java Data Base Connectivity,java数据库连接)是一种用于运行SQL语句的Java API,能够为多种关系数据库提供统一訪问,它由一组用Java语言编写的类和接口组成。JDBC提供了一种基准,据此能够构建更高级的工具和接口,使数据库开发者能够编写数据库应用程序。

JDBC API的工作原理

JDBC的用法:

    1、   装载驱动。

    装载驱动程序仅仅须要很easy的一行代码。比如,你想要使用 JDBC-ODBC 桥驱动程序, 能够用下列代码装载它:

        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

    你的驱动程序文档将告诉你应该使用的类名。比如, 假设类名是 jdbc.DriverXYZ ,你将用代码下面的代码装载驱动程序:

        Class.forName("jdbc.DriverXYZ");

     载入 Driver 类后,它们就可以用来与数据库建立连接。

    2、   建立连接

    第二步就是用适当的驱动程序类与 DBMS 建立一个连接。下列代码是一般的做法:

        Connection con =DriverManager.getConnection(url, "myLogin", "myPassword");

JDBC怎样建立各个数据库的连接

 1Oracle8/8i/9i数据库(thin模式)

Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();   String url="jdbc:oracle:thin:@localhost:1521:orcl";   //orcl为数据库的SID   String user="test";   String password="test";   Connection conn= DriverManager.getConnection(url,user,password);

2DB2数据库

Class.forName("com.ibm.db2.jdbc.app.DB2Driver ").newInstance();   String url="jdbc:db2://localhost:5000/sample";   //sample为你的数据库名   String user="admin";   String password="";   Connection conn= DriverManager.getConnection(url,user,password);

3Sql Server7.0/2000数据库

Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance();   Stringurl="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb";   //mydb为数据库   String user="sa";   String password="";   Connection conn= DriverManager.getConnection(url,user,password);

4Sybase数据库

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);

5Informix数据库

Class.forName("com.informix.jdbc.IfxDriver").newInstance();   String url =   "jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;   user=testuser;password=testpassword";   //myDB为数据库名   Connection conn= DriverManager.getConnection(url);

 6MySQL数据库

Class.forName("org.gjt.mm.mysql.Driver").newInstance();   String url="jdbc:mysql://localhost/myDB?user=soft&password=soft1234&useUnicod   e=true&characterEncoding=8859_1"   //myDB为数据库名   Connection conn= DriverManager.getConnection(url);

7PostgreSQL数据库

Class.forName("org.postgresql.Driver").newInstance();   String url ="jdbc:postgresql://localhost/myDB"   //myDB为数据库名   String user="myuser";   String password="mypassword";   Connection conn= DriverManager.getConnection(url,user,password);

 

到此,已经对JDBC有了一定的了解,想要了解其它javaEE的规范,敬请期待!

你可能感兴趣的文章
HeadFirst设计模式笔记:(六)命令模式 —— 封装调用
查看>>
SQL Server 2008 游标使用实例
查看>>
eclipse 如何忽略js文件报错
查看>>
OpenSSL命令---pkcs12
查看>>
ViewPager,实现真正的无限循环(定时+手动)
查看>>
FineUI(专业版)v2.6.0即将支持的两个新特性!
查看>>
Leetcode: H-Index
查看>>
从国与国到人与人
查看>>
生成freeswitch事件的几种方式
查看>>
不再平庸
查看>>
oracle循环语句
查看>>
嵌入式开发之hi3519---i2c MDIO PHY uboot phy调试总结
查看>>
『参考』.net CF组件编程(1)——基础之后
查看>>
asp.net真的是并行处理request的吗?
查看>>
structured sparsity model
查看>>
AIM(Autodesk Infrastructure Modeler) 的API示例--列出选中对象
查看>>
WMI使用集锦
查看>>
分析代码的利器 - ctags
查看>>
JavaScript数据结构与算法——链表
查看>>
199. Binary Tree Right Side View
查看>>