zoukankan      html  css  js  c++  java
  • Java操作Oracle

    public class DBCon {
    	// 数据库驱动对象
    	public static final String DRIVER = "oracle.jdbc.driver.OracleDriver";
    	// 数据库连接地址(数据库名)
    	public static final String URL = "jdbc:oracle:thin:@localhost:1521:orcl";
    	// 登陆名
    	public static final String USER = "scott";
    	// 登陆密码
    	public static final String PWD = "123456";
    	// 创建数据库连接对象
    	private Connection con = null;
    	// 创建数据库预编译对象
    	private PreparedStatement ps = null;
    	// 创建结果集
    	private ResultSet rs = null;
    	// 创建数据源对象
    	public static DataSource source = null;
    
    	public Connection getCon() {
    		try{
    			Class.forName(DRIVER);
    			con = DriverManager.getConnection(URL, USER, PWD);
    			System.out.println("数据库连接成功!");
    		} catch (Exception e) {
    			System.err.println("数据库连接失败!");
    			e.printStackTrace();
    		}
    		return con;
    	}
    
    	public void closeAll() {
    		if (rs != null)
    			try {
    				rs.close();
    			} catch (SQLException e) {
    				e.printStackTrace();
    			}
    		if (ps != null)
    			try {
    				ps.close();
    			} catch (SQLException e) {
    				e.printStackTrace();
    			}
    		if (con != null)
    			try {
    				con.close();
    			} catch (SQLException e) {
    				e.printStackTrace();
    			}
    	}
    	
    	public int update(String sql,String... pras){  
            int resu=0;  
            con=getCon();  
            try {  
                ps=con.prepareStatement(sql);  
                for(int i=0;i<pras.length;i++){  
                    ps.setString(i+1,pras[i]);  
                }  
                resu=ps.executeUpdate();  
            } catch (SQLException e) {  
            }  
            finally{  
                closeAll();  
            }  
            return resu;  
        }  
    	
    	public ResultSet query(String sql,String... pras){  
            con=getCon();  
            try {  
                ps=con.prepareStatement(sql);  
      
                if(pras!=null)  
                    for(int i=0;i<pras.length;i++){  
                        ps.setString(i+1, pras[i]);  
                    }  
                rs=ps.executeQuery();  
            } catch (SQLException e) {  
                // TODO Auto-generated catch block  
                e.printStackTrace();  
            }  
            return rs;  
        } 
    
    	public static void main(String[] args) throws SQLException {
    		DBCon dbCon = new DBCon();
    //		dbCon.getCon();
    		ResultSet resultSet = dbCon.query("select * from emp", null);
    		while (resultSet.next()) {
    			System.out.printf("%-10d",resultSet.getInt(1));    
    		    //输出10列,左对齐(-号表示左对齐)
    //			System.out.print(resultSet.getInt(1) + "		");
    			System.out.printf("%-10s",resultSet.getString(2)); 
    //			System.out.print(resultSet.getString(2) + "		");
    			System.out.printf("%-20s",resultSet.getString(3)); 
    //			System.out.print(resultSet.getString(3) + "				");
    			System.out.printf("%-10d",resultSet.getInt(4)); 
    //			System.out.print(resultSet.getInt(4) + "		");
    			System.out.print(resultSet.getDate(5) + "		");
    			System.out.print(resultSet.getDouble(6) + "		");
    			System.out.print(resultSet.getDouble(7) + "		");
    			System.out.println(resultSet.getInt(8));
    		}
    		dbCon.closeAll();
    	}
    }

    Jar包下载 http://yunpan.cn/QC5IeekKJvixN  提取码 243b


    Java操作Oracle实现事务回滚

    		DBCon dbCon = new DBCon();
    		Connection connection = dbCon.getCon();
    		String sql = "";
    		Statement statement = null;
    		try {
    			connection.setAutoCommit(false);//设置事物不自动提交
    			
    			sql = "update emp set sal = sal - 100 where ename = 'SMITH'";
    			
    			statement = connection.createStatement();
    			statement.executeUpdate(sql);
    			
    			int i = 7/0; //抛异常。
    			
    			sql = "update emp set sal = sal - 100 where ename = 'JAMES'";
    			statement.executeUpdate(sql);
    			
    			connection.commit();
    		} catch (Exception e) {
    		//注意这里如果是SQLException,上面7/0抛出的异常就不会被这里捕获到,下面的rollback自然就不会执行。陷阱
    			try {
    				connection.rollback();//事务回滚
    			} catch (SQLException e1) {
    				e1.printStackTrace();
    			}
    			e.printStackTrace();
    		}finally{
    			dbCon.closeAll();
    			if (statement != null) {
    				try {
    					statement.close();
    				} catch (SQLException e) {
    					e.printStackTrace();
    				}
    			}
    		}

    默认情况下事物自动提交,此时上例中抛出异常后,前面的sql语句可以执行成功,后面的不会被执行。进行事物管理之后,上例中抛出异常后,事物会在下面的catch块中回滚。保证两个sql语句都不执行。

    本文出自 “阿凡达” 博客,请务必保留此出处http://shamrock.blog.51cto.com/2079212/1532489

  • 相关阅读:
    母版中menu控件上传后出现脚本错误
    asp.net中修改网页的编码方式
    DataBinder的应用
    web服务器控件MultiView 应用
    asp:Wizard 应用
    web服务器控件PlaceHolder应用
    Gridivew里的Textbox值取不出来?
    登录控件Login的应用
    NHibernate调用存储过程
    FckEditor网页编辑器的使用总结
  • 原文地址:https://www.cnblogs.com/umgsai/p/3908076.html
Copyright © 2011-2022 走看看