java mysql

1.java操作mysql数据库,首先加入lib包,我本地使用的是mysql-connector-java-5.1.18-bin.jar

以下java代码例子:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;


/*
 * mysql数据库操作
 * @@author
 * 创建时间:
 * 更新时间:
 * 
 */
public class DBhandle {
    
    private static String driver = "com.mysql.jdbc.Driver";
    private static String url = "jdbc:mysql://192.168.6.71:3306/";
    private static String db = "test";
    private static String character = "?useUnicode=true&characterEncoding=gbk";
    private static String user = "linchaojiang";
    private static String pass = "qwsSedcRFV";
     
    static Connection conn = null;
    static Statement statement = null;
    static PreparedStatement ps = null;
    static ResultSet rs = null;
    List<Map> list = new ArrayList<Map>();//返回所有记录
    
    /*
     * 连接数据库
     */    
     public static void connDB() {
          try {
           Class.forName(driver).newInstance();
           conn = DriverManager.getConnection(url+db+character, user, pass);
           if (!conn.isClosed()) {
            System.out.println("Succeeded connecting to MySQL!");
           }
           
           statement = conn.createStatement();
          } catch (Exception e) {
           e.printStackTrace();
          }
         }
        
    /*
     * 关闭数据库
     */
     public static void closeDB() {         
          if(rs != null ){              
              try {
                rs.close();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }              
          }          
          if(statement != null){              
              try {
                statement.close();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
          }
          if(conn != null){
           try {
            conn.close();
            System.out.println("Database connection terminated!");
           } catch (SQLException e) {
            e.printStackTrace();
               }
           }
         }             
     
     /*
      * 查询数据表
      */
     public List query(String sql){
        connDB();
        int count;
        try {
            rs = statement.executeQuery(sql);
            ResultSetMetaData rsmd;
            rsmd = rs.getMetaData();
            count = rsmd.getColumnCount();
            while(rs.next()){
                Map  map = new HashMap();
                for(int i=1;i<=count;i++){
                    //获取指定列的表目录名称
                    String label=rsmd.getColumnLabel(i);
                    //以 Java 编程语言中 Object 的形式获取此 ResultSet 对象的当前行中指定列的值
                    Object object= rs.getObject(i);
                    //把数据库中的字段名和值对应为一个map对象中的一个键值对
                    map.put(label.toLowerCase(), object);
                }
                list.add(map);                                         
            }            
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } finally {
            closeDB();
        }      
        return list;         
     }
     
     /*
      * 数据插入
      */
     public void insert(String sql){
            connDB(); 
            try {
                statement.execute(sql);
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }finally {
                closeDB();
            }     
     }
     
     /*
      * 数据更新
      */
     public void update(String sql){         
         connDB();
         try {
             statement.execute(sql);
         } catch (SQLException e) {
             // TODO Auto-generated catch block
             e.printStackTrace();
         }finally {
             closeDB();
         }         
     } 
     
     /*
      * 数据删除
      */
     public void delete(String sql){
         connDB();
         try {
             statement.execute(sql);
         } catch (SQLException e) {
             // TODO Auto-generated catch block
             e.printStackTrace();
         }finally {
             closeDB();
         }     
     }
}

 

posted @ 2016-08-25 08:32  星星故乡  阅读(4177)  评论(0编辑  收藏  举报