JAVA JDBC连接数据库的步骤

JDBC连接数据库具体包含7个步骤:   

  1.  1、加载JDBC驱动程序:   
  2.     在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),   
  3.     这通过java.lang.Class类的静态方法forName(String  className)实现。   
  4.     try{    // 1.加载驱动
    Class.forName("oracle.jdbc.driver.OracleDriver");
  5.     }catch(ClassNotFoundException e){   
  6.     System.out.println("找不到驱动程序类 ,加载驱动失败!");   
  7.     e.printStackTrace() ;   
  8.     }   
  9.    成功加载后,会将Driver类的实例注册到DriverManager类中。   
  10.  2、提供JDBC连接的URL   
  11.        jdbc:oracle 
  12.      Connection con  = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:XXX","scott","xxx");
  13.    说明:jdbc:oracle:thin:@localhost(IP地址)
  14.              1521(端口号):
  15.              XXX(数据实例) ;
  16.              scott用户名; 
  17.              xxx密码
  18.  3、创建数据库的连接   
  19.     •要连接数据库,需要向java.sql.DriverManager请求并获得Connection对象, 该对象就代表一个数据库的连接。   
  20.     •使用DriverManager的getConnectin(String url , String username ,String password )方法传入指定的欲连接的数据库的路径、数据库的用户名和   
  21.      密码来获得。   
  22.      例如:   
  23.      String url = "jdbc:oracle:thin:@localhost:1521:XXX" ;    
  24.      String username = "scott" ;   
  25.      String password = "xxx" ;   
  26.      try{   
  27.     Connection con =    
  28.              DriverManager.getConnection(url , username , password ) ;   
  29.      }catch(SQLException se){   
  30.     System.out.println("数据库连接失败!");   
  31.     se.printStackTrace() ;   
  32.      }   
  33.  4、创建一个Statement   
  34.     •要执行SQL语句,必须获得java.sql.Statement实例,Statement实例分为以下3种类型:   
  35.       1、执行静态SQL语句。通常通过Statement实例实现。   
  36.       2、执行动态SQL语句。通常通过PreparedStatement实例实现。   
  37.       3、执行数据库存储过程。通常通过CallableStatement实例实现。   
  38.     具体的实现方式:   
  39.         Statement stmt = con.createStatement() ;   
  40.         PreparedStatement pstmt = con.prepareStatement(sql) ;   
  41.         CallableStatement cstmt =  con.prepareCall("{CALL addEmp(? , ?)}") ;   
  42.  5、执行SQL语句   
  43.     Statement接口提供了三种执行SQL语句的方法:executeQuery 、executeUpdate 和execute   
  44.      1、ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句,返回一个结果集(ResultSet)对象。   
  45.      2int executeUpdate(String sqlString):用于执行INSERT、UPDATE或DELETE语句以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等   
  46.      3、execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的语句。   
  47.    具体实现的代码:   
  48.             ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ;   
  49.             int rows = stmt.executeUpdate("INSERT INTO ...") ;   
  50.              boolean flag = stmt.execute(String sql) ;   
  51.  6、处理结果   
  52.     两种情况:   
  53.      1、执行更新返回的是本次操作影响到的记录数。   
  54.      2、执行查询返回的结果是一个ResultSet对象。   
  55.     • ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些   
  56.       行中数据的访问。   
  57.     • 使用结果集(ResultSet)对象的访问方法获取数据:   
  58.      while(rs.next()){   
  59.          String uname = rs.getString("username") ;   
  60.          String upass = rs.getString(1) ; // 此方法比较高效   
  61.      }   
  62.     (列是从左到右编号的,并且从列1开始)   
  63.  7、关闭JDBC对象    
  64.      操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序由里到外。   
  65.      1、关闭结果集对象    
  66.      2、关闭语句对象 
  67.      3、关闭连接对象   
  68.           if(rs != null){   // 关闭记录集   
  69.         try{   
  70.             rs.close() ;   
  71.         }catch(SQLException e){   
  72.             e.printStackTrace() ;   
  73.         }   
  74.           }   
  75.           if(st != null){   // 关闭声明   
  76.         try{   
  77.             st.close() ;   
  78.         }catch(SQLException e){   
  79.             e.printStackTrace() ;   
  80.         }   
  81.           }   
  82.           if(con != null){  // 关闭连接对象   
  83.          try{   
  84.             con.close() ;   
  85.          }catch(SQLException e){   
  86.             e.printStackTrace() ;   
  87.          }   
  88.       }  

1、资源项目源码均已通过严格测试验证,保证能够正常运行;、 2项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行;、 2项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 、 1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READmE.文件(md如有),本项目仅用作交流学习参考,请切勿用于商业用途。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值