`
wind_bell
  • 浏览: 291271 次
  • 性别: Icon_minigender_2
  • 来自: 广州
社区版块
存档分类
最新评论

JDBC初级应用(一)注:转

    博客分类:
  • JDBC
阅读更多
JDBC初级应用实例(一)
    在了解JDBC基础知识以后,我们先来写一个数据库操作的类(Bean)以后我们会
在这个类的基础上,随着介绍的深入不断提供优化的方案.
    要把一个数据库操作独立到一个类(Bean)中,至少要考虑以下几个方面:
    1.对于不同层次的应用,应该有不同的得到连结的方法,如果得到连结的方法要随
着应用层次的不同而改变,我们就应该把他独立成一个专门的类中,而把在任何应用层次
中都通用的处理方法封装到一个(类)Bean中.
    2.既然考虑到既作为javaBean使用又可以用为一个普通类调用,要考虑到javaBean
的规范和普通类的灵活性.
    3.对于特定的数据库操作不应封装到共性的(类)Bean中,而应该成为它的扩展类.

    以上几点是充分考虑JAVA的面象对象的思想,经过深入的抽象形成的层次,下面我
们就按这个思想来设计:
    一:定义一个用于连结的Bean,以后如果要在不同的应用中,如可以在J2EE中从
DataSource中得到连结,或从普通的连结池中得到连结,以及直接从DriverManager中得到
连结,只需修改本类中的得到连结的实现方法.
    package com.imnamg.axman.beans;
    import java.sql.*;
    import ..................
    public class ConnectionFactory{
        protected Connection conn;
        ConnectionFactory() throws SQLException 
        {    //构造方法中生成连结
            //无论是从DataSource还是直接从DriverManager中取得连结.
            //先初始化环境,然后取得连结,本例作为初级应用,从
            //DriverManager中取得连结,因为是封装类,所以要把异常抛
            //给调用它的程序处理而不要用try{}catch(){}块自选处理了.
            //因为要给业务方法的类继承,而又不能给调用都访问,所以
            //conn声明为protected
            conn =     DriverManager.getConnection(url,user,passwd);
        }
        
        /**
            在多线程编程中,很多时候有可能在多个线程体中得到同一连
            结的引用,但如果在一个线程中关闭了连结,则另一个得到相同
            引用的线程就无法操作了,所以我们应该加一个重新建立连结
            的辅助方法,有人问为什么既然有这个辅助方法不直接调用这个
            辅助而要在构造方法中生成连结?因为这样可以增加效率,如果
            在构造时不能生成连结则就不能生成这个对象了,没有必要在
            对象生成后再测试能不能生成连结.
        */
        public void makeConnection(){
            //此处的代码同构造方法,无论以后如果实现连结,都将构造方
            //法的代码复制到此处.
            conn =     DriverManager.getConnection(url,user,passwd);
        }
    }

    这个类就封装到这里,当然你可以在这儿增加业务方法,但如果要修改连结的实现,
整个类都要重新编译,因为业务方法和应用层次无关,代码一经生成不易变动,所以独立封装.
以下我们实现业务方法:

    package com.imnamg.axman.beans;
    import java.sql.*;
    import ..................
    public class DBOperater extends ConnectionFactory{
        //private Statement stmt;
        //private ResultSet rs;
        //为什么要注释成员变量stmt和rs,基础部分已经说过,如果声明为成员变量,
        //在关闭conn时可以显示地先关闭rs和stmt,别的没有任何好处,而显示关
        //闭只是说明你编程风格好,但综合考虑,我们要生成多个stmt或不是类型的
        //stmt就不能声明为成员方法,否则引用同一对象,所以我们要业务方法中生
        //成stmt对象.不仅可以同时处理多个结果集,还可以提高性能和灵活性.

        public ResultSet executeQuery(String sql) throws SQLException{
            if(conn==null || conn.isClosed())
                makeConnection();
            Statement stmt = con.createStatement(
                    ResultSet.TYPE_SCROLL_INSENSITIVE,
                                         ResultSet.CONCUR_READ_ONLY);
            //对于一般的查询操作,我们只要生成一个可流动的结果集就行了.
            //而对于在查询时要更新记录,我们用另一个业务方法来处理,这样,
            //这样可以在普通查询时节省回滚空间.
            ResultSet rs = stmt.executeQuery(sql);
            return rs;
        }
        

        public ResultSet executeUpdatabledQuery(String sql) throws SQLException{
            if (con == null || con.isClosed())
                makeConnection();
            Statement stmt = con.createStatement(
                    ResultSet.TYPE_SCROLL_INSENSITIVE,
                    ResultSet.CONCUR_UPDATABLED);
            //可更新的结果结要更大的回滚空间,普通查询时不要调用这个方法
            ResultSet rs = stmt.executeQuery(sql);
            return rs;
        }

        /**
            基于同上的原因,在执行更新操作是我们根本不要任何回滚空间,所以建立
            一个基本类型的stmt,实现如下
        */



        public int executeUpdate(String sql) throws SQLException{
            if (con == null || con.isClosed()) 
                makeConnection();
            Statement stmt = con.createStatement();
            //这个stmt在执行更新操作时更加节省内存,永远记住,能节省的时候要节省
            //每一个字节的内存,虽然硬件设备可能会有很大的物理内存,但内存是给用
            //户用的而不是给程序员用的(!!!!!!!!!!!!!!!!!!)
            int s = stmt.executeUpdate(sql);
            return s;
        }

        //以上实现了常用功能,还有两个通用的功能也是"共性"的,我们一起在这个封装类
        //中实现:
        public PreparedStatement getPreparedStmt(String sql) throws SQLException{
            if (con == null || con.isClosed()) 
                makeConnection();
            PreparedStatement ps = con.prepareStatement(sql);
            return ps;
        }
        public CallableStatement getCallableStmt(String sql) throws SQLException{
            if (con == null || con.isClosed()) 
                makeConnection();
            PreparedStatement ps = con.prepareCall(sql);
            return ps;
        }

        //记住:对于封装类而言预编译语句和存储过程调用应该从连结中返PreparedStatement
        //和CallableStatement供调用者处理而不是返回它们的处理结果.也就是说封装类只封
        //装了它们的连结过程.最后再次声明,一定要有一个close()方法供调用者调用,而且告
        //诉调用者无论如果要调用这个方法:

        public void close() throws SQLException{
            if(conn != null && !conn.isClosed())
                conn.close();
        }
        //这个方法最好放在ConnectionFactory中,这样可以直接调用来只测试连结.而不用再
        调用子类来关闭
    }

    OK,我们已经实现了数据库常用操作的封装,注意这些业务方法都是把异常抛给调用者而没有用
try...catch来处理,你如果在这里处理了那么调用者则无法调试了.对于特定的数据库的特殊操作,不要封
装到此类中,可以再从这个类继承,或直接从ConnectionFactory类继承,当然最好是从这个业务类中继承,
这样不仅可以调用特殊方法也可以调用共性的业务方法,兴一个例子,我在应用Oracle时要把XML文件直接
存到数据数和把数据直接读取为XML文件,那么这两个方法只对Oracle才用到,所以:

    package com.inmsg.axman.beans;

    import java.sql.*;
    import oracle.xml.sql.query.OracleXMLQuery;
    import oracle.xml.sql.dml.OracleXMLSave;
    
    public class OracleDBOperater extends DBOperater{
         public OracleXMLQuery getOXQuery(String sql,String table) throws Exception
                 {
                         OracleXMLQuery qry = new OracleXMLQuery(con,sql);
                         qry.setRowsetTag(table);
                         qry.setRowTag("RECORD");
                         return qry;
                 }
                 public int insertXML(String path,String table) throws Exception
                 {
                         OracleXMLSave sav = new OracleXMLSave(con,table);
                         URL url = sav.createURL(path);
                         sav.setRowTag("RECORD");
                         int x = sav.insertXML(url);
                         sav.close();
                         return x;
                 }
    }

    现在,有了这样的几个"东西"在手里,你还有什么觉得不方便的呢?
    虽然本处作为初级应用,但设计思想已经是JAVA高手的套路了,是不是有些自吹自擂了啊?
好的,休息一下吧.
分享到:
评论

相关推荐

    com.microsoft.sqlserver.jdbc.SQLServerException: 只进结果集不支持请求的操作 解决方案

    本文将深入探讨标题和描述中提到的“com.microsoft.sqlserver.jdbc.SQLServerException: 只进结果集不支持请求的操作”这一异常,以及如何在使用Hibernate、Struts进行分页时避免这一问题。我们将从异常的根本原因...

    Java连接达梦数据库驱动dm_jdbc

    Java连接达梦数据库驱动dm_jdbc: dm_jdbc\com.dameng.floader.jar dm_jdbc\com.dameng.impexp.jar dm_jdbc\Dm7Dictionary.jar dm_jdbc\Dm7JdbcDriver14.jar dm_jdbc\Dm7JdbcDriver15.jar dm_jdbc\Dm7JdbcDriver16....

    JDBC driver

    Sybase官方的JDBC驱动程序——jConnect 驱动类名:com.sybase.jdbc3.jdbc.SybDriver 连接URL:jdbc:sybase:Tds:host:port/database?property_name=value

    JDBC and ODBC

    JDBC API是一个抽象的Java接口集合,它定义了一系列用于打开数据库连接、执行SQL语句及处理结果的标准方法。这些API允许开发者以一致的方式与不同的数据库进行交互。 #### JDBC驱动程序 JDBC驱动程序是连接Java...

    JDBC Driver 驱动包

    MySQL是一款开源、免费的关系型数据库管理系统,广泛应用于Web应用中。MySQL JDBC驱动(也称为Connector/J)是MySQL官方提供的Java数据库连接器,它实现了Java的JDBC API,使得Java应用程序可以连接到MySQL服务器。...

    kingbaseV8 jdbc 驱动

    String url = "jdbc:kingbase://hostname:port/databasename"; String username = "your_username"; String password = "your_password"; try { Class.forName("com.kingbase.jdbc.Driver"); Connection conn = ...

    常用的数据库JDBC URL格式

    - **JDBC URL**:`jdbc:microsoft:sqlserver://<server_name>:<port>` - 默认端口:1433 - 如果服务器使用默认端口,则 `<port>` 可以省略。 ##### 2. Microsoft SQL Server 2005 及以上版本 - **驱动程序包名**...

    ha-jdbc.rar

    在Java应用程序中,JDBC是访问和操作数据库的标准接口,而ha-jdbc则是对这一接口的扩展,它为开发者提供了更高级的功能,以应对分布式环境中的数据访问需求。 ha-jdbc的核心功能主要包括: 1. **故障切换**:当主...

    JDBC连接字符串.doc

    每个数据库驱动都有其特定的URL格式,例如,`jdbc:mysql:`前缀表示连接到MySQL,而`jdbc:sqlserver:`表示连接到SQL Server。`jdbc:oracle:thin:`是Oracle数据库的“瘦”驱动,它不依赖本地Oracle客户端库。 在实际...

    是对之前讲的jdbc初级应用实例

    是对之前讲的jdbc初级应用,讲解一些实例

    jdbc-oracle-thinjdbc-oracle-thin

    在提供的部分内容中,“`jdbc:oracle:thin:@SFMWLHRTRLFQJQA:1521:orclsid`” 是一个典型的 JDBC-Oracle-Thin 连接字符串。下面我们将逐个部分进行解析: - **jdbc:**:表示使用 JDBC 协议。 - **oracle:**:指定...

    GBase JDBC 8.3.81.53.zip

    GBase JDBC 8.3.81.53 是一款专为GBase数据库设计的Java数据库连接器(Java Database Connectivity,简称JDBC),它允许Java应用程序通过标准的JDBC接口与GBase数据库进行通信和数据操作。GBase是南大通用数据系统...

    SQLite JDBC Driver

    当Java程序通过JDBC URL(如`jdbc:sqlite:/path/to/database`)建立连接时,驱动会加载必要的类和资源,创建与SQLite数据库的通信通道。 2. **使用步骤** - 添加依赖:将`sqlitejdbc.jar`文件添加到项目类路径中,...

    常用 JDBC 驱动名字和 URL 列表

    jdbc:odbc:name 用 COM.ibm.db2.jdbc.net.DB2Driver 连接到 DB2 数据库 一个 DB2 URL 的示例: jdbc:db2://aServer.myCompany.com:50002/name 用 com.sybase.jdbc.SybDriver连接到 Sybase 数据库 一个 Sybase URL...

    jdbc8.jar-oracle12

    "jdbc:oracle:thin:@//hostname:port/service_name", "username", "password"); ``` 其中,`hostname`是Oracle服务器地址,`port`是监听的TCP端口,`service_name`是Oracle服务名。 3. 执行SQL操作: 可以...

    oracle所有版本jdbc的jar包

    JDBC(Java Database Connectivity)是Java平台中的一个标准API,用于在Java应用程序中连接和操作关系型数据库。它由一组接口和类组成,允许开发者编写数据库无关性的代码。 2. **Oracle JDBC驱动类型**: - ** ...

    jconn4 jdbc连接sybase驱动

    String url = "jdbc:sybase:TDS:hostname:port/databaseName"; String user = "yourUsername"; String password = "yourPassword"; Connection conn = DriverManager.getConnection(url, user, password); ``` ...

    jdbc应用详解

    Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@192.168.0.39:1521:TARENADB", "username", "password"); ``` 3. **创建Statement对象**:用于执行SQL语句。 - 示例代码: ```java ...

    log4jdbc监控sql及执行时间

    1、在应用中jdbc url最前面添加jdbc:log4;比如oracle的url就变成了jdbc:log4jdbc:oracle:thin:@x.x.x.x:1521:dbname; 2、在日志系统中设置jdbc.sqlonly、jdbc.sqltiming等日志级别,可直接将log4jdbc doc中的日志...

Global site tag (gtag.js) - Google Analytics