jdbc(2)——之Class.forName(com.mysql.cj.jdbc.Driver)理解
发布日期:2021-05-07 02:53:26 浏览次数:23 分类:精选文章

本文共 2046 字,大约阅读时间需要 6 分钟。

理解Class.forName(Com.mysql.cj.jdbc.Driver)

Class.forName("com.mysql.cj.jdbc.Driver");

在使用jdbc的时候这行代码必不可少,我们来仔细理解一下这行代码的意义和原理;

1.理解com.mysql.cj.jdbc.Driver

com.mysql.cj.jdbc.Driver是Driver驱动所在的位置,这个大家应该没问题;

在这里插入图片描述

2.理解Class.forName()

Class.forName()是一个反射,但是他没有返回一个Class对象,因为我们不需要;

这是Driver的代码:

public class Driver extends NonRegisteringDriver implements java.sql.Driver {       public Driver() throws SQLException {       }    static {           try {               DriverManager.registerDriver(new Driver());        } catch (SQLException var1) {               throw new RuntimeException("Can't register driver!");        }    }}

它除了构造方法,就只有一个静态代码块,当我们反射进行的时候,这个类就开始初始化,他的静态代码块内容就已经被执行了,详细可以参考类的初始化

我们真正需要的是DriverManager.registerDriver(new Driver());这一行代码

因此这样写,同样可以获取数据库中数据

public class jdbcFirstDemo {       public static void main(String[] args) throws ClassNotFoundException, SQLException {           //1.加载驱动        DriverManager.registerDriver(new com.mysql.cj.jdbc.Driver());        //Class.forName("com.mysql.cj.jdbc.Driver");        //2.用户信息和URL        String url = "jdbc:mysql://localhost:3306/dbhomework?useUnicode=true&characterEncoding=UTF8&useSSL=true&serverTimezone=UTC";        String username = "root";        String password = "lixv298618";        //3.连接成功数据库对象 Connection代表数据库        Connection connection = DriverManager.getConnection(url, username, password);        //4.执行SQL的对象        Statement statement = connection.createStatement();        //5.执行SQL的对象去执行SQL,可能存在结果,查看返回结果        String sql = "SELECT * FROM STUDENT";        ResultSet resultSet = statement.executeQuery(sql);//返回的结果集        while (resultSet.next()){               System.out.print(resultSet.getString(1)+" ");            System.out.print(resultSet.getString("Sname")+" ");            System.out.print(resultSet.getString(3)+" ");            System.out.print(resultSet.getInt("Age")+" ");            System.out.println(resultSet.getString(5)+" ");        }        //6.释放连接        resultSet.close();        statement.close();        connection.close();    }}

运行结果:

在这里插入图片描述

上一篇:jdbc(3)——url内容理解
下一篇:jdbc(1)——第一次使用idea连接数据库,在控制台输出数据库表中内容

发表评论

最新留言

留言是一种美德,欢迎回访!
[***.207.175.100]2025年03月26日 08时18分22秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章