
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(); }}
运行结果:

发表评论
最新留言
留言是一种美德,欢迎回访!
[***.207.175.100]2025年03月26日 08时18分22秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
云小课 | 守护网络安全不是问题,iptables的四表五链为你开启“八卦阵”
2021-05-09
LiteOS内核源码分析:任务栈信息
2021-05-09
23种设计模式之迭代器模式
2021-05-09
23种设计模式之组合模式
2021-05-09
mysql zip安装
2021-05-09
mysql修改密码
2021-05-09
virtualbox中 Kali Linux安装增强功能
2021-05-09
virtualbox中 Ubuntu挂载共享文件夹
2021-05-09
Python 内置函数笔记
2021-05-09
BootStrapTable 错误
2021-05-09
PHP 配置文件
2021-05-09
PHP 脚本不报错
2021-05-09
代码整洁之道小结
2021-05-09
悲观锁与乐观锁
2021-05-09
js new Date 创建时间默认是8点
2021-05-09
Python实现cmd命令连续执行
2021-05-09
罗马数字
2021-05-09
IO多路复用小故事
2021-05-09
纠错码简介
2021-05-09
码云 Pages 搭建
2021-05-09