package JDBCDemo; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; public class JDBCTest { public static void main(String[] args) throws ClassNotFoundException, SQLException { // 加载驱动Driver里有一个静态代码块,所以我们把类字节码对象加载到内存中就可以创建driver对象也就是注册驱动了 Class.forName("com.mysql.jdbc.Driver"); // 创建连接 Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "root"); // 创建语句,这个类是用来封装语句的 这里返回值是用的java中的接口来接收的,java提供了各种数据库的接口,运用多态的形式来调用方法 PreparedStatement ps = connection.prepareStatement("select * from base_dict "); // 这个语句类中有执行语句的方法 ResultSet resultSet = ps.executeQuery(); // 处理结果。返回的ResultSet是所有数据的集合,一行一行的数据 while (resultSet.next()) { System.out.println(resultSet.getString("dict_name")); } // 关闭资源。 if (connection != null) { connection.close(); } } }
需要注意的点:
加载驱动的时候因为driver中加载静态代码块的时候就创建了驱动对象
这也反应出了我们加载字节码对象的时候就已经执行了静态的语句