JDBC连接数据库的经典案例

  1. package com.execlExport.util;  
  2.   
  3. import java.sql.Connection;  
  4. import java.sql.DriverManager;  
  5. import java.sql.PreparedStatement;  
  6. import java.sql.ResultSet;  
  7. import java.sql.SQLException;  
  8. /** 
  9.  * DatabaseUtil  
  10.  * 创建人: TanLiu 
  11.  * 时间: 2015-1-19 下午9:08:23 
  12.  * 作用:  
  13.  */  
  14. public class DatabaseUtil {  
  15.   
  16.     private final String Driver = "com.mysql.jdbc.Driver";  
  17.     private final String URL = "jdbc:mysql://localhost:3306/tmdest";  
  18.     private final String User = "root";  
  19.     private final String pwd ="123456";  
  20.   
  21.     private Connection con = null;  
  22.   
  23.     private PreparedStatement ps = null;  
  24.     public ResultSet rs=null;      
  25.     /** 
  26.      *作用:获取对数据库的连接 
  27.      */  
  28.     public void getConnection(){  
  29.         try {  
  30.             Class.forName(Driver);  
  31.             con=DriverManager.getConnection(URL,User,pwd);  
  32.         } catch (ClassNotFoundException e) {  
  33.             e.printStackTrace();  
  34.         } catch (SQLException e) {  
  35.             e.printStackTrace();  
  36.         }         
  37.     }  
  38.     /** 
  39.      *作用:对数据的查询操作 
  40.      * @param sql 
  41.      * @param arr 
  42.      * @return 返回一个数据集rs 
  43.      */  
  44.     public ResultSet getQuery(String sql,String[] arr){  
  45.         getConnection();  
  46.         try {  
  47.             ps=con.prepareStatement(sql);  
  48.             if(arr!=null&&arr.length>0){  
  49.                 for(int i=0;i<arr.length;i++){  
  50.                     ps.setString(i+1, arr[i]);  
  51.                 }  
  52.             }  
  53.             rs=ps.executeQuery();  
  54.         } catch (SQLException e) {  
  55.               
  56.             e.printStackTrace();  
  57.         }  
  58.   
  59.         return rs;  
  60.     }  
  61.       
  62.     /** 
  63.      *作用:用于对数据库的更新操作 
  64.      * @param sql 
  65.      * @param arr 
  66.      * @return row 
  67.      */  
  68.     public int getUpdate(String sql,String[] arr){  
  69.         int row=0;  
  70.         getConnection();  
  71.         try {  
  72.             ps=con.prepareStatement(sql);  
  73.             if(arr!=null&&arr.length>0){  
  74.                 for(int i=0;i<arr.length;i++){  
  75.                     ps.setString(i+1, arr[i]);  
  76.                 }  
  77.             }  
  78.             row=ps.executeUpdate();  
  79.         } catch (SQLException e) {  
  80.               
  81.             e.printStackTrace();  
  82.         }finally{  
  83.             this.closeAll();  
  84.         }  
  85.         return row;  
  86.     }  
  87.       
  88.     /** 
  89.      *作用:对数库操作的关闭 
  90.      */  
  91.     public void closeAll(){  
  92.           
  93.             try {  
  94.                 if(rs!=null){  
  95.                 rs.close();  
  96.                 }  
  97.                 if(ps!=null){  
  98.                     ps.close();  
  99.                 }  
  100.                 if(con!=null){  
  101.                     con.close();  
  102.                 }  
  103.             } catch (SQLException e) {                
  104.                 e.printStackTrace();  
  105.             }  
  106.     }  
  107. }  
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值