Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 334|回复: 0

[JDBC学习]深入探讨JDBC

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-10-11 04:12:57 | 显示全部楼层 |阅读模式
        JDBCjava Database Connection从字面上看就知道是Java应用与数据库之间的通信。 谈到JDBC不得不考虑的几个重要的问题
    1. Java访问数据库的时候,由于数据库可能由不同的厂商所提供,底层的通信机制可能是不相同的,在这种情况下,Java语言怎样保证与各种数据库通信呢? 2. Java能够连接到各种数据库后,怎样去访问呢? Java连接到数据库可以通过下面三种方法:    1. 通过JDBC-ODBC桥接驱动器:是微软公司提出的一种解决方案,微软公司在Windows系统里面就编写了一个模块,名叫ODBC,开放数据库连接,然后所有安装到Windows系统上的数据库只要支持ODBC(基本所有数据库都支持),通过ODBC就能够连接到数据库,所以只要Java语言与ODBC通信就行了,不需要知道是什么厂商的数据库。
      
       
       
         
       

         
       
      
        2.通过数据库厂商提供的JDBC驱动:通常数据库不但要求在Windows平台上面运行,还要在Unix、Linux等平台上面运行,这中情况就不能使用ODBC,所以数据库厂商自己提供一个数据库驱动,让Java来注册驱动,连接到各种数据库,所以支持跨平台。如果需要修改不同厂商的数据库,这时就需要修改注册驱动和获得连接的代码,这也是这种方法的存在缺点。    3. 通过在服务器上面建立连接池、数据源:通过JNDI技术寻找服务器上的数据源,进而通过连接池连接到数据库。连接池支持所有的数据库,如果需要修改不同厂商数据库,只需要在服务器的控制台上修改相关信息,并不需要修改代码。通常服务器是跨平台的。所以这种方法通常是连接数据库最好的方法。 通过JDBC-ODBC桥接驱动器连接数据库 建立ODBC数据源:在控制面板->管理工具->数据源->系统DSN->添加各种数据库的数据源。 案例:查询员工表里面的全部资料,在控制台上打印。 编写QueryEmployees类,实现ODBC数据源的方式查找所有员工的信息,代码如下

      
       package wang.jdbc;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    public class QueryEmployees {
    public static void main(String[] args) {
    Connection conn = null;
    try {
       // 指定驱动,连接到ODBC
            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
            // 获取连接
            conn = DriverManager.getConnection("jdbc:odbc:XEDS", "hr", "hr");
            // 运行sql语句
            Statement stat = conn.createStatement();
            String sql = "select * from employees";
            // 获得结果
            ResultSet rs = stat.executeQuery(sql);
            // 显示结果
            while(rs.next()) {
             String id = rs.getString("EMPLOYEE_ID");
             String name = rs.getString("FIRST_NAME") + " " + rs.getString("LAST_NAME");
             String email = rs.getString("EMAIL");
             System.out.println(id + " " + name + " " + email);
            }
            } catch (Exception e) {
                    e.printStackTrace();
            } finally {               
             try {
                    if(conn != null) {
                            conn.close();
                            conn = null;
                    }
            } catch (SQLException e) {
                    e.printStackTrace();
            }
            }
            }
    }
                           
       新增、删除、修改等操作略之。 调用存储过程 调用存储过程,分以下三种情况: 1. 调用不带参数的存储过程 2. 调用带参数的存储过程 3. 调用带输出参数的存储过程 编写CallPrc类,实现这三种情况下调用存储过程,代码如下  
      
       package wang.jdbc;
    import java.sql.CallableStatement;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import java.sql.Types;
    public class CallPrc1 {
    public static void main(String[] args) {
      Connection conn = null;
      try {
            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
            conn = DriverManager.getConnection("jdbc:odbc:XEDS", "hr", "hr");
            //调用不带参数的存储过程,prc1是一个不带参数的存储过程
            CallableStatement cs1 = conn.prepareCall("{call prc1 ()}");
            cs1.execute();
            //调用带参数的存储过程,prc2(String, double)是一个带参数的存储过程
            CallableStatement cs2 = conn.prepareCall("{call prc2 (?,?)}");
            cs2.setString(1, "参数1");
            cs2.setDouble(2, 45.0);
            cs2.execute();
            //调用带输出参数的存储过程,prc3(String, String, String(output参数))是一个带输出参数的存储过程
            CallableStatement cs3 = conn.prepareCall("{call prc3 (?,?)}");
            cs3.setString(1, "参数1");
            cs3.setString(2, "参数2");
            cs3.registerOutParameter(3, Types.CHAR);
            cs3.execute();
            String str = cs3.getString(3);//得到输出参数的值
            } catch (Exception e) {
                    e.printStackTrace();
            } finally {               
            try {
                    if(conn != null) {
                            conn.close();
                            conn = null;
                    }
            } catch (SQLException e) {
                    e.printStackTrace();
            }
    }
    }
    }
                      
       事务 案例:转账的时候,我的钱减少了,他的钱增加了,实现时希望这两个过程要么全部运行,要么全部不运行,这种情况就可以把这两个修改操作做成一个事务。 编写Transaction类,实现以上转账功能,代码如下  

    package wang.jdbc;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import java.sql.Statement;
    public class Transaction {
    public static void main(String[] args) {
    Connection conn = null;//默认事务自动提交
      try {
            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
            conn = DriverManager.getConnection("jdbc:odbc:XEDS", "hr", "hr");
            Statement stat = conn.createStatement();
            conn.setAutoCommit(false);//修改为不要自动提交事务
            // sql1和sql2要么全部运行,要么全部不要运行,把以下两句定义成事务
            String sql1 = "update ....";
            String sql2 = "update ....";
            stat.executeUpdate(sql1);
            stat.executeUpdate(sql2);
            conn.commit();//提交以上操作,如果以上两步出现异常就回退
       } catch (Exception e) {
             try {
                    conn.rollback();
            } catch (SQLException e1) {
                    e1.printStackTrace();
            }
    } finally {               
            try {
                    if(conn != null) {
                            conn.close();
                            conn = null;
                    }
    } catch (SQLException e) {
                    e.printStackTrace();
    }
    }
    }
    }
                         
    通过数据库驱动程序连接数据库
    案例:使用oracle驱动连接,查询所有员工信息。
    编写OraDriver类,利用oracle驱动连接,查询所有的员工信息,代码如下
      package wang.jdbc;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    public class OraDriver {
    public static void main(String[] args) {
      Connection conn = null;
      try {
            Class.forName("oracle.jdbc.driver.OracleDriver");//载入驱动
            String url = "jdbc:oracle:thin:@localhost:1521:XE";
            conn = DriverManager.getConnection(url, "hr" ,"hr");
            Statement stat = conn.createStatement();
            String sql = "select * from employees";
            ResultSet rs = stat.executeQuery(sql);
           
            while(rs.next()) {
             String id = rs.getString("EMPLOYEE_ID");
             String name = rs.getString("FIRST_NAME") + " " + rs.getString("LAST_NAME");
             String email = rs.getString("EMAIL");
             System.out.println(id + " " + name + " " + email);
            }
            } catch (Exception e) {
                    e.printStackTrace();
            } finally {
            try {
                    if(conn != null) {
                            conn.close();
                            conn = null;
                    }
            } catch (SQLException e) {
                    e.printStackTrace();
            }
    }
    }
    }
                         
    通过Weblogic建立连接池、数据源连接数据库
    Weblogic有一种能力,能够把很多数据库连接放到连接池里面,然后这些连接以数据源的形式对外发布,供外部访问,实现的具体步骤如下
    1. 建立连接池(具体步骤略之);
    2. 建立数据源(具体步骤略之),通过JNDI对外发布。
    编写Pool类,实现weblogic的连接池和数据源技术来连接数据库,代码如下
      package wang.jdbc;
    import java.sql.*;
    import javax.naming.Context;
    import javax.naming.InitialContext;
    import javax.sql.DataSource;
    import java.util.Hashtable;
    public class Pool {
    public static void main(String[] args) {
      //连接到weblogic,查找数据源获得数据库连接
    Hashtable table = new Hashtable();
    //table里面放置连接基本信息
    table.put(Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory");
    table.put(Context.PROVIDER_URL, "t3://localhost:7001");
    table.put(Context.SECURITY_PRINCIPAL, "weblogic");
    table.put(Context.SECURITY_CREDENTIALS, "weblogic");
    //查询服务器中的数据源
    try {
            Context        context = new InitialContext(table);
            Object obj = context.lookup("DS1");
            DataSource ds = (DataSource)obj;
            Connection conn = ds.getConnection();
            Statement stat = conn.createStatement();
            String sql = "select * from employees";
            ResultSet rs = stat.executeQuery(sql);
            while(rs.next()) {
                    String id = rs.getString("EMPLOYEE_ID");
                    String name = rs.getString("FIRST_NAME") + " " + rs.getString("LAST_NAME");
                    String email = rs.getString("EMAIL");
                    System.out.println(id + " " + name + " " + email);
            }
    } catch (Exception e) {
            e.printStackTrace();
    }
    }
    }
                         
      
      
       
       
         
         

          
         

          
         
       
      
    复制代码
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-26 06:53 , Processed in 0.363755 second(s), 49 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表