• Java开发中JDBC连接数据库代码和步骤


      JDBC连接数据库:创建一个以JDBC连接数据库的程序,包含7个步骤:   

    1、加载JDBC驱动程序:

      在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),这通过java.lang.Class类的静态方法forName(String  className)实现。 例如:   

    try{   
        //加载MySql的驱动类   
        Class.forName("com.mysql.jdbc.Driver");   
    }catch(ClassNotFoundException e){   
        System.out.println("找不到驱动程序类 ,加载驱动失败!");   
        e.printStackTrace();
    }

      成功加载后,会将Driver类的实例注册到DriverManager类中。   

    2、提供JDBC连接的URL:

      连接URL定义了连接数据库时的协议、子协议、数据源标识。

      书写形式:协议:子协议:数据源标识

      协议:在JDBC中总是以jdbc开始

      子协议:是桥连接的驱动程序或是数据库管理系统名称。

      数据源标识:标记找到数据库来源的地址与连接端口。

      例如:(MySql的连接URL)

    jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=gbk;   
    //useUnicode=true:表示使用Unicode字符集。如果characterEncoding设置为   
     gb2312或GBK,本参数必须设置为true
    //characterEncoding=gbk:字符编码方式。  

    3、创建数据库的连接:

      要连接数据库,需要向java.sql.DriverManager请求并获得Connection对象,该对象就代表一个数据库的连接。   

      使用  DriverManager  的  getConnectin(String url,  String username,  String password )方法传入指定的欲连接的数据库的路径、数据库的用户名和密码来获得。例如:

    //连接MySql数据库,用户名和密码都是root   
    String url = "jdbc:mysql://localhost:3306/test" ;    
    String username = "root" ;   
    String password = "root" ;   
    try{   
        Connection con = DriverManager.getConnection(url , username , password ) ;   
    }catch(SQLException se){   
        System.out.println("数据库连接失败!");   
        se.printStackTrace() ;   
    }

    4、创建一个Statement:

      要执行SQL语句,必须获得java.sql.Statement实例,Statement实例分为以下3种类型:

      (1)执行静态SQL语句。通常通过Statement实例实现。  

      (2)执行动态SQL语句。通常通过PreparedStatement实例实现。  

      (3)执行数据库存储过程。通常通过CallableStatement实例实现。

      具体的实现方式:

    Statement stmt = con.createStatement() ;   
    PreparedStatement pstmt = con.prepareStatement(sql) ;   
    CallableStatement cstmt = con.prepareCall("{CALL demoSp(? , ?)}") ;

    5、执行SQL语句:

      Statement接口提供了三种执行SQL语句的方法:executeQuery 、executeUpdate 和 execute  

      (1)ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句 ,返回一个结果集(ResultSet)对象。   

      (2)int executeUpdate(String sqlString):

        1、用于执行INSERT、UPDATE或DELETE语句,返回执行处理的数据条数目;

        2、以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等,返回0,并会抛出异常,所以需要放在异常代码段里面捕获异常信息。

      (3)execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的语句。

      具体实现的代码:

    ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ;   
    int rows = stmt.executeUpdate("INSERT INTO ...") ;   
    boolean flag = stmt.execute(String sql) ;   

    6、处理结果:

      两种情况:

      (1)执行更新返回的是本次操作影响到的记录数。

      (2)执行查询返回的结果是一个ResultSet对象。   

      ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些行中数据的访问。

      使用结果集(ResultSet)对象的访问方法获取数据:   

    while(rs.next()){   
        String name = rs.getString("name") ;   
        String pass = rs.getString(1) ; // 此方法比较高效   
    }   
    //(列是从左到右编号的,并且从列1开始)   

    7、关闭JDBC对象    

      操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声明顺序相反:

      先关闭记录集,再关闭声明,再关闭连接对象。

    if(rs != null){   // 关闭记录集   
        try{   
            rs.close() ;   
        }catch(SQLException e){   
            e.printStackTrace() ;   
        }   
    }   
    if(stmt != null){   // 关闭声明   
        try{   
            stmt.close() ;   
        }catch(SQLException e){   
            e.printStackTrace() ;   
        }   
    }   
    if(conn != null){  // 关闭连接对象   
        try{   
            conn.close() ;   
        }catch(SQLException e){   
            e.printStackTrace() ;   
        }   
    }  

    8、代码实例:

    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    
    public class MySQLConnection {
        public static void main(String[] args) {
            Connection conn = null;
            Statement stmt = null;
            ResultSet rs = null;
            String url = null;
            String user = null;
            String password = null;
            String sql = null;
            try {
                Class.forName("com.mysql.jdbc.Driver"); //加载mysq驱动
            } catch (ClassNotFoundException e) {
                System.out.println("驱动加载错误");
                e.printStackTrace();//打印出错详细信息
            }
            try {
                url = "jdbc:mysql://localhost/test?user=root&password=2602555&useUnicode=true&&characterEncoding=gb2312&autoReconnect = true";
                //简单写法:url = "jdbc:myqsl://localhost/test(数据库名)? user=root(用户)&password=2602555(密码)";
                user = "root";
                password = "2602555";
                conn = DriverManager.getConnection(url,user,password);
            } catch (SQLException e) {
                System.out.println("数据库链接错误");
                e.printStackTrace();
            }
            try {
                stmt = conn.createStatement();
                sql = "select * from dept";//dept这张表有deptno,deptname和age这三个字段
                rs = stmt.executeQuery(sql);//执行sql语句
                while(rs.next()) {
                    System.out.print(rs.getInt("deptno") + "   ");
                    System.out.print(rs.getString("deptname") + "   ");
                    System.out.println(rs.getInt("age") + "   ");
                }
            } catch (SQLException e) {
                System.out.println("数据操作错误");
                e.printStackTrace();
            }
            //关闭数据库
            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.printStackTrace();
            }
        }
    }
  • 相关阅读:
    poj2976 Dropping tests (01分数规划)
    bzoj5281/luogu4377 Talent Show (01分数规划+背包dp)
    bzoj5280/luogu4376 MilkingOrder (二分答案+拓扑序)
    bzoj1492/luogu4027 货币兑换 (斜率优化+cdq分治)
    [模板]树状数组
    匿名函数 python
    yield解析你要知道的源自IBM
    stackoverflow yield 帖子
    pandas 生成器,生成大数据
    pd.contact,dataframe 拼接
  • 原文地址:https://www.cnblogs.com/goloving/p/7398136.html
Copyright © 2020-2023  润新知