天天看点

Java学习笔记(JDBC数据库编程常用接口)

path配置

通常问题有两方面,一方面是路径不对,另一方面是路径前后标点符号不对(英文半角):

classpath   .;%java_home%\lib;                 (注意:前面点号,分号,后面分号)

java_home   c:\program files\java\jdk1.6.0_17   (注意:前后均无符号)

path        %java_home%\bin;              (注意:写在原来变量值的最前面  前无符号,后为分号)

jdbc的全称是java database connectivity,是一套面向对象的应用程序接口(api),制定了统一的访问各种关系数据库的标准接口,为各个数据库厂商提供了标准接口的实现。这东西能够实现软件的扩平台性。

jdbc是一种底层api,在访问数据库是需要在业务逻辑中直接嵌入sql语句。

jdbc不能够直接访问数据库,必须依赖数据库厂商提供的jdbc驱动程序完成以下三步工作1.同数据库建立连接;2.向数据库发送sql语句;3.处理从数据库返回的结果。

*jdbc驱动

1.jdbc-odbc桥连是指通过本地的obdc driver连接到rdbms上。

2.jdbc-native桥连通过调用本地的native程序实现数据库连接,这种类型的驱动程序把客户机api上的jdbc调用转为oracle,sybase,informix,db2或者其它dbms的调用。

3.jdbc网络驱动是一种完全利用java语言编写的jdbc驱动。

4.本地协议驱动是一种完全利用java语言编写的jdbc驱动,这种类型的驱动程序将jdbc调用直接转换为dbms所使用的网络协议。

#jdbc中常用接口

-driver接口

每种数据库的驱动程序都应该提供一个实现java.sql.driver接口的类,简称driver类。

加载jdbc-odbc驱动:

class.forname("sun.jdbc.odbc.jdbcodbcdriver");

-drivermanager类

java.sql.drivermanager类负责管理jdbc驱动程序的基本服务,是jdbc的管理层,作用于用户和驱动程序之间,负责跟踪可用的驱动程序,并在数据和驱动程序之间建立连接。

(静态方法)getconnection(string url,string user,string password)用来建立数据库连接。

setlogintimeout(int seconds)用来设置每次连接数据库的最长时间

println(string message)用来输出指定消息到当前的jdbc日记流

-connection接口

java.sql.connection接口代表与特定数据库的连接,在接连的上下文中可以执行sql语句并返回结果,还可以通过getmetadata()方法获得由数据库提供的相关信息。

createstatement()创建并返回一个statement 实例,通常在执行无参数的sql语句是创建实例。

-statement接口

java.sql.statement接口用来执行静态sql语句,并返回执行结果。

对于insert,ipdate和delete语句,调用executeupdate(string sql)方法;对于select语句,则调用executequery(string sql)方法,并返回一个永远不能为null的resultset实例。

-preparedstatement接口

java.sql.preparedstatement接口继承并扩展了statement接口,用来执行动态的sql语句,即包含参数的sql语句。

通过setxxx()方法为sql语句中的参数赋值时,建议利用与参数类型匹配的方法,也可以利用setobject()为各种类型赋值。

preparedstetement ps=connection.preparedstatement("select * from table_name where id>? and (name=? or name=?)");

ps.setint(1,6);

ps.setstring(2,"马先生");

ps.setobject(3,"李先生");

resultset rs=ps.executequery();

clearparameters()清除当前参数的值。

-callablestatement接口

java.sql.callablestatement接口继承并扩展preparedstatement接口,用来执行sql的存储过程。

-resultset接口

java.sql.resultset接口类似于一个数据表,通过该接口的实例可以获得检索结果集,以及对应数据表的相关信息,resultset实例通过执行查询数据库的语句生成。

next()方法可以将指针移动到下一行,返回bool类型。只能迭代一次!

getxxx()方法均有两个重载方法,分别根据列的索引号和列的名称检索列值。

first(),返回bool值

last(),返回bool值

previous()将指针移动到上一行,返回bool值

beforefirst()

afterlast()

absolute()移动到指定行,int>0向下移动,int<0,向后移动

relative()相对当前位置移动到指定行,int>0向下移动,int<0,向后移动

getrow()当前行索引编号

findcolumn()查看指定列名的索引编号

isbeforefirst()查看指针是否处于实例开头,返回bool

isfirst()查看指针是否处于第一行,返回bool

deleterow()删除当前行,执行该方法后,在执行close()之后才会同步到数据库