JDBC编程学习笔记整理

连接Oracle数据库的各种oracle JDBC驱动程序的细节。
这些细节包括:
1、导入JDBC包
2、注册oracle JDBC驱动程序
3、打开数据库连接
4、执行SQL DML语句在数据库表中获取、添加、修改和删除行

一、JDBC驱动程序
    共有有4种
1、Thin驱动程序
     Thin驱动程序是所有驱动程序中资源消耗最小的,而且完全用java编写的。
     该驱动程序只使用TCP/IP且要求Oracle Net。被称为第4类驱动程序。
     它使用TTC协议与Oracle数据库进行通信。能够在Applet、Application中使用。
2、OCI驱动程序
     OCI驱动比Thin需要资源要多,但性能通常好一点。OCI驱动适合于部署在
     中间层的软件,如Web服务器。不能在applet中使用OCI驱动。是第2类驱动程序。
     不完全用java写的,还包含了c代码。该驱动有许多附加的性能增强特性,
     包括高级的连接缓冲功能。
     注意:OCI驱动要求在客户计算机上安装它。
3、服务器内部驱动程序
     服务器内部驱动程序提供对数据库的直接访问,Oracle JVM使用它与数据库进行通信。
     Oracle JVM是与数据库集成的Java Virtual Machine,可以使用Oracle JVM将
     Java类装载进数据库,然后公布和运行这个类中包含的方法。
4、服务器Thin驱动程序
     服务器端Thin驱动程序也是由Oracle JVM使用的,它提供对远程数据库的访问。
     也是完全用Java编写的。

二、导入JDBC包

三、注册Oracle JDBC驱动程序
       必须先向java程序注册Oracle JDBC驱动程序,然后才能打开数据库连接。
       有两种注册Oracle JDBC驱动程序的办法。
 1、使用java.lang.Class的forName()方法
       例子:Class.forName("oracle.jdbc.OracleDriver");
 2、使用JDBC DriverManager类的registerDriver()方法。
       例子:DriverManager.registerDriver(new oracle.jdbc.OracleDriver());
       如果使用Oracle8i JDBC驱动程序,那么需要导入oracle.jdbc.driver.OracleDriver类,
       然后注册这个类的实例。
       例子:
       import oracle.jdbc.driver.OracleDriver;
       DriverManager.registerDriver(new oracle.jdbc.OracleDriver());
       注意:从JDBC2.0开始,只用JDBC驱动程序的更标准办法是通过数据源。

四、打开数据库连接
        必须先打开数据库连接,然后才能在Java程序中执行SQL语句。打开数据库连接
        的主要办法。
 1、DriverManager类的getConnection()方法。
          DriverManager.getConnection(URL,USERNAME,PASSWROD);
          URL:程序要连接的数据库,以及要使用的JDBC驱动程序
              URL的结构依赖于JDBC驱动程序的生产商。对于Oracle JDBC驱动程序,数据库URL的结构:
                  driver_name@driver_information
                      driver_name是程序使用的Oracle JDBC驱动程序的名称。如:
                           jdbc:oracle:thin Oracle JDBC Thin驱动程序
                           jdbc:oracle:oci  Oracle JDBC OCI驱动程序
                           jdbc:oracle:oci8 Oracle JDBC OCI驱动程序
                      driver_information是连接数据库所需的驱动程序特有的信息。这依赖于使用的驱动程序。
                          对于Oracle JDBC Thin驱动程序,可以用
                           host_name:port:database_sid 或者 Oracle Net关键字-值对
                           (description=(address=(host=host_name)(protocol=tcp)(port=port()
                           (connect_data=(sid=database_sid)))
                                    host_name: 运行数据库的机器的名称
                                              port: Net数据库监听器等待这个端口上的请求,默认是1521
                                 database_sid: 要连接的数据库实例的Oracle SID。
        USERNAME:   程序连接数据库时使用的数据库用户名
        PASSWROD:   用户名的口令
                        例子:
                              Connection myConnection=DriverManager.getConnection(
                              "jdbc:oracle:thin:@localhost:1521:ORCL",
                              "store_user",
                              "store_password");

                              Connection myConnection=DriverManager.getConnection(
                              "jdbc:oracle:oci:@(description=(address=(host=localhost)"+
                              "(protocol=tcp)(port=1521))(connect_data=(sid=ORCL)))",
                              "store_user",
                              "store_password");
 2、使用Oracle数据源对象,必须先创建这个对象,然后连接它,与DriverManager.getConnection方法
       相比,Oracle数据源使用了一种更标准化的方式提供连接数据库所需的各种参数。
       Oracle数据源对象也可以向JNDI注册(见另外一篇学习笔记http://blog.csdn.net/207/archive/2004/12/15/217518.aspx)。
       要想使用Oracle数据源,有三个步骤:
                A.创建oracle.jdbc.pool.OracleDataSource类的Oracle数据源对象
                     import oracle.jdbc.pool.OracleDataSource;
                     OracleDataSource myDataSource=new OracleDataSource();
                B.设置Oracle数据源对象属性,oracle.jdbc.pool.OracleDataSource类实际上实现了
                    JDBC提供的javax.sql.DataSource接口。

Javax.sql.DataSource接口的属性

属性名

属性说明

属性类型

databaseName

数据库名

String

dataSourceName

底层数据源类的名称

String

description

数据源的说明

String

networkProtocol

用于与数据库通信的网络协议。这只用于Oracle JDBC OCI驱动程序,默认值是TCP

String

password

用户名的口令

String

portNumber

Oracle Net监听器等待着个端口上数据库连接请求。默认值是1521

int

derverName

数据库服务器的机器名

String

user

数据库用户名

String


                        oracle.jdbc.pool.OracleDataSource类还提供了另一组属性

OracleDataSource属性

属性名

属性说明

属性类型

driverType

要使用的JDBC驱动程序。如果要使用服务器内部驱动程序,那么这设置为kprb,而且此属性的其他设置被忽略

String

url

可以用于指定Oracle数据库URL,这可以代替设置数据库位置。

String

tnsEntry Name

可以用于指定Oracle Net TNSNAMES字符串在使用OCI驱动程序时也可以用于指定数据库位置

String

                   属性的get/set方法就像javabean的get/set写法规则一样。
                    注意:没有getPassword()方法。
                   例子:
                             myDataSource.setServerName("localhost");
                            myDataSource.setDatabaseName("localhost");
                            myDataSource.setDriverType("oci");
                            myDataSource.setNetworkProtocol("tcp");
                            myDataSource.setPortNumber(1521);
                            myDataSource.setUser("admin");
                            myDataSource.setPassword("helloworld");
                            String serverName=myDataSource.getServerName();
                            int portNumber=myDataSource.getPortNumber();
                   一旦设置了OracleDatatSource对象的属性,就可以使用它连接数据库了。
            C.通过Oracle数据源对象连接数据库
                             Connection myConnection=myDataSource.getConnection();
                            也可以
                             Connection myConnection=myDataSource.getConnection("newOne","learning");
                            这个写法的用户名和口令将覆盖刚才在myDataSource中设置的用户名和口令。因此将使用
                            用户名newOne,口令learning连接数据库。
                一旦得到Connection对象,就可以使用它创建JDBC Statement对象。

五、创建JDBC Statement对象
        需要创建java.sql.Statement类的JDBC Statement对象,然后才能使用JDBC发出SQL语句。
        Statement对象用于表示一个SQL语句:DML语句(select,insert,update或delete)或DDL语句(create table)
        Statement myStatement=myConnection.createStatement();
        根据SQL语句,就使用Statement类的不同方法执行SQL。
                select-------------------->executeQuery()
                insert,update,delete---->executeUpdate()
        如果预先不知道要执行SQL语句的类型,可以使用execute()方法,execute()方法也可以执行DDL语句。
        当然还有个PrepareStatement类可以用于代表JDBC(详细见另外文章)。
        一旦得到了Statement对象,就可以使用JDBC发出SQL语句了。

六、从数据库获取数据
        使用JDBC执行select语句,要使用Statement对象的executeQuery(select语句)方法,因为select语句可能返回多行,
        所以executeQuery()方法返回一个对象,其中存储了select语句返回的行。它是java.sql.ResultSet类的实例。
        使用ResultSet对象从数据库读取行时,有三个步骤:
                1、创建和填充ResultSet对象(具体ResultSet类型操作资料这里没有讨论:P)。
                            Resultset rs=myStatement.executeQuery("select user,sysdate from dual");
                2、从Resultset对象读取列值
                            这里要理解Oracle和java类型的映射关系

JavaOracle可兼容的类型映射

Oracle类型

Java类型

CHAR

String

VARCHAR2

String

DATE

java.sql.Date                日期

java.sql.Time            时间

java.sql.Timestamp     日期和时间

INTEGER

short

int

long

NUMBER

float

double

java.matn.BigDecimal

                              int和String类型是核心JAVA的一部分,而java.sql.Date属于JDBC,它是核心JAVA的扩展。
                              JDBC提供的类型没有完全覆盖Oracle使用的所有类型,就如rowid类型,就必须使用
                              oracle.sql.ROWID类型存储。
                              例子:
                                     while(rs!=null && rs.next()){
                                        String user=rs.getString("user");
                                        String sysdate=rs.getString(2);
                                        //至于Date类型,就要注意日期和时间的区别,最好使用Timestamp
                                        java.sql.Timestamp hopeDateTemp=rsResult.getTimestamp("sysdate");
                                        java.text.SimpleDateFormat sdf=new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm");
                                        String hopeDate=sdf.format(hopeDateTemp);//(这里主要是JDBC,就不详细讨论了:p)
                                    }
                            JDBC提供的next()方法访问ResultSet对象中的第一行,以后每次对next()方法的调用会前进到
                            下一行。当rs没有更多的行读取时,next()返回false;这里建议的是ResultSet只是个临时数据
                            集合,如果Connection断开了,ResultSet里面的数据也没有了,所以最好使用Java的变量或对象
                            把rs的数据复制过来。

七、关闭ResultSet对象(吃完东西抹嘴)
                            例子:
                                     rs.close();

八、INSERT、UPDATE、DELETE数据库记录
            上面提到过使用SQL INSERT语句向数据库插入、修改、删除记录。JDBC有两种方式:
                    a.使用Statement类中定义的executeUpdate()方法
                    b.使用PrepareStatement类中定义的execute()方法

你可能感兴趣的:(JDBC编程学习笔记整理)