设为首页 收藏本站
查看: 1257|回复: 0

[经验分享] java JDBC访问Oracle数据库

[复制链接]
YunVN网友  发表于 2018-9-22 12:05:19 |阅读模式
  Java数据库访问——  1、加载JDBC驱动:
  


  •   加载JDBC驱动,并将其注册到DriverManager中,下面是一些主流数据库的JDBC驱动加裁注册的代码:
  •   //Oracle8/8i/9iO数据库(thin模式)
  •   Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
  •   //Sql Server7.0/2000数据库
  •   Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance();
  •   //DB2数据库
  •   Class.froName("com.ibm.db2.jdbc.app.DB2Driver").newInstance();
  •   //Informix数据库
  •   Class.forName("com.informix.jdbc.IfxDriver").newInstance();
  •   //Sybase数据库
  •   Class.forName("com.sybase.jdbc.SybDriver").newInstance();
  •   //MySQL数据库
  •   Class.forName("com.mysql.jdbc.Driver").newInstance();
  •   //PostgreSQL数据库
  •   Class.forNaem("org.postgresql.Driver").newInstance();
  
2、建立数据库连接:
  


  •   //Oracle8/8i/9i数据库(thin模式)
  •   String url="jdbc:oracle:thin:@localhost:1521:orcl";
  •   String user="scott";
  •   String password="tiger";
  •   Connection conn=DriverManager.getConnection(url,user,password);

  •   //Sql Server7.0/2000数据库
  •   String url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs";
  •   String user="sa";
  •   String password="";
  •   Connection conn=DriverManager.getConnection(url,user,password);

  •   //DB2数据库
  •   String url="jdbc:db2://localhost:5000/sample";
  •   String user="amdin"
  •   String password=-"";
  •   Connection conn=DriverManager.getConnection(url,user,password);

  •   //Informix数据库
  •   String url="jdbc:informix-sqli://localhost:1533/testDB:INFORMIXSERVER=myserver;user=testuser;password=testpassword";
  •   Connection conn=DriverManager.getConnection(url);

  •   //Sybase数据库
  •   String url="jdbc:sybase:Tds:localhost:5007/tsdata";
  •   Properties sysProps=System.getProperties();
  •   SysProps.put("user","userid");
  •   SysProps.put("password","user_password");
  •   Connection conn=DriverManager.getConnection(url,SysProps);

  •   //MySQL数据库
  •   String url="jdbc:mysql://localhost:3306/testDB?user=root&password=root&useUnicode=true&characterEncoding=gb2312";
  •   Connection conn=DriverManager.getConnection(url);

  •   //PostgreSQL数据库
  •   String url="jdbc:postgresql://localhost/testDB";
  •   String user="myuser";
  •   String password="mypassword";
  •   Connection conn=DriverManager.getConnection(url,user,password);
  

  3、建立Statement对象或PreparedStatement对象:
  


  • //建立Statement对象
  •   Statement stmt=conn.createStatement();
  •   //建立ProparedStatement对象
  •   String sql="select * from user where userName=? and password=?";
  •   PreparedStatement pstmt=Conn.prepareStatement(sql);
  •   pstmt.setString(1,"admin");
  •   pstmt.setString(2,"liubin");
  

  4、执行sql语句:
  


  • String sql="select * from users";
  •   ResultSet rs=stmt.executeQuery(sql);
  •   //执行动态SQL查询
  •   ResultSet rs=pstmt.executeQuery();
  •   //执行insert update delete等语句,先定义sql
  •   stmt.executeUpdate(sql);
  

  5、访问结果记录集ResultSet对象。
  


  • while(rs.next)
  •   {
  •   out.println("你的第一个字段内容为:"+rs.getString());
  •   out.println("你的第二个字段内容为:"+rs.getString(2));
  •   }
  

  6、依次将ResultSet、Statement、PreparedStatement、Connection对象关闭,释放所占用的资源:
  


  • rs.close();
  •   stmt.clost();
  •   pstmt.close();
  •   con.close();
  

  7、其他数据库连接:
  


  • MySQL:
  •     String Driver="com.mysql.jdbc.Driver";    //驱动程序
  •     String URL="jdbc:mysql://localhost:3306/db_name";    //连接的URL,db_name为数据库名
  •     String Username="username";    //用户名
  •     String Password="password";    //密码
  •     Class.forName(Driver).new Instance();
  •     Connection con=DriverManager.getConnection(URL,Username,Password);
  • Microsoft SQL Server 2.0驱动(3个jar的那个):
  •     String Driver="com.microsoft.jdbc.sqlserver.SQLServerDriver";    //连接SQL数据库的方法
  •     String URL="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=db_name";    //db_name为数据库名
  •     String Username="username";    //用户名
  •     String Password="password";    //密码
  •     Class.forName(Driver).new Instance();    //加载数据可驱动
  •     Connection con=DriverManager.getConnection(URL,UserName,Password);    //
  • Microsoft SQL Server 3.0驱动(1个jar的那个): // 老紫竹完善
  •     String Driver="com.microsoft.sqlserver.jdbc.SQLServerDriver";    //连接SQL数据库的方法
  •     String URL="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=db_name";    //db_name为数据库名
  •     String Username="username";    //用户名
  •     String Password="password";    //密码
  •     Class.forName(Driver).new Instance();    //加载数据可驱动
  •     Connection con=DriverManager.getConnection(URL,UserName,Password);    //
  • Sysbase:
  •     String Driver="com.sybase.jdbc.SybDriver";    //驱动程序
  •     String URL="jdbc:Sysbase://localhost:5007/db_name";    //db_name为数据可名
  •     String Username="username";    //用户名
  •     String Password="password";    //密码
  •     Class.forName(Driver).newInstance();
  •     Connection con=DriverManager.getConnection(URL,Username,Password);
  • Oracle(用thin模式):
  •     String Driver="oracle.jdbc.driver.OracleDriver";    //连接数据库的方法
  •     String URL="jdbc:oracle:thin:@loaclhost:1521:orcl";    //orcl为数据库的SID
  •     String Username="username";    //用户名
  •     String Password="password";    //密码
  •     Class.forName(Driver).newInstance();    //加载数据库驱动
  •     Connection con=DriverManager.getConnection(URL,Username,Password);
  • PostgreSQL:
  •     String Driver="org.postgresql.Driver";    //连接数据库的方法
  •     String URL="jdbc:postgresql://localhost/db_name";    //db_name为数据可名
  •     String Username="username";    //用户名
  •     String Password="password";    //密码
  •     Class.forName(Driver).newInstance();
  •     Connection con=DriverManager.getConnection(URL,Username,Password);
  • DB2:
  •     String Driver="com.ibm.db2.jdbc.app.DB2.Driver";    //连接具有DB2客户端的Provider实例
  •     //String Driver="com.ibm.db2.jdbc.net.DB2.Driver";    //连接不具有DB2客户端的Provider实例
  •     String URL="jdbc:db2://localhost:5000/db_name";    //db_name为数据可名
  •     String Username="username";    //用户名
  •     String Password="password";    //密码
  •     Class.forName(Driver).newInstance();
  •     Connection con=DriverManager.getConnection(URL,Username,Password);
  • Informix:
  •     String Driver="com.informix.jdbc.IfxDriver";
  •     String URL="jdbc:Informix-sqli://localhost:1533/db_name:INFORMIXSER=myserver";    //db_name为数据可名
  •     String Username="username";    //用户名
  •     String Password="password";    //密码
  •     Class.forName(Driver).newInstance();
  •     Connection con=DriverManager.getConnection(URL,Username,Password);
  • JDBC-ODBC:
  •     String Driver="sun.jdbc.odbc.JdbcOdbcDriver";
  •     String URL="jdbc:odbc:dbsource";    //dbsource为数据源名
  •     String Username="username";    //用户名
  •     String Password="password";    //密码
  •     Class.forName(Driver).newInstance();
  •     Connection con=DriverManager.getConnection(URL,Username,Password);
  

  下面是我自己做的一个例子:
  


  • package dao;

  • import java.sql.SQLException;
  • import java.sql.Statement;
  • import java.sql.Connection;
  • import java.sql.DriverManager;
  • import java.sql.ResultSet;
  • import java.util.ArrayList;
  • import java.util.List;

  • import bean.Tbmeet;

  • public class OracleDao {


  •     private Statement stmt = null;

  •     private  ResultSet rs = null;

  •     private Connection conn = null;

  •     public OracleDao(){
  •         this.getConnection();
  •     }

  •     public void getConnection(){
  •         try{
  •             Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
  •             String url="jdbc:oracle:thin:@10.11.0.31:1521:orcl"; //orcl为数据库的SID
  •             String user="meeting";
  •             String password="meeting";
  •             conn= DriverManager.getConnection(url,user,password);
  •         }catch (Exception e) {
  •             System.out.println(e);
  •         }
  •     }

  •     public List getRes(){
  •         List list = new ArrayList();
  •         try {
  •             stmt = conn.createStatement();
  •             rs = stmt.executeQuery("select * from tbmeetroomequipment");
  •             while (rs.next()) {
  •                 Tbmeet t = new Tbmeet();
  •                 t.setId(rs.getLong(1));
  •                 t.setName(rs.getString(2));
  •                 t.setEcid(rs.getLong(3));
  •                 list.add(t);
  •             }
  •         } catch (SQLException e) {
  •             list = null ;
  •             e.printStackTrace();
  •         }finally{
  •             this.close(conn, stmt, rs);
  •         }
  •         return list;
  •     }

  •     public int delete(String sql) throws SQLException{
  •         int number = 0 ;
  •         try{
  •             stmt = conn.createStatement();

  •             number = stmt.executeUpdate(sql);

  •             conn.commit();
  •         }catch(Exception e){
  •             System.out.println(e);
  •             conn.rollback();
  •             number = 0 ;
  •         }finally{
  •             this.close(conn, stmt, rs);
  •         }
  •         return number;
  •     }

  •     public void close(Connection conn , Statement stmt, ResultSet rs){
  •         try{
  •             if(rs != null){
  •                 rs.close();
  •                 rs = null ;
  •             }
  •             if(stmt != null){
  •                 stmt.close();
  •                 stmt = null ;
  •             }
  •             if(conn != null){
  •                 conn.close();
  •                 conn = null;
  •             }

  •         }catch(Exception e){
  •             System.out.println(e);
  •         }
  •     }

  • }



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-599892-1-1.html 上篇帖子: oracle控制文件损坏恢复 下篇帖子: 过大的Oracle监听日志文件处理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

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