【java】——JDBC链接数据库

这里以mysql为例

public class mysqldemo {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        Class.forName("com.mysql.cj.jdbc.Driver");
        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "root");
        Statement st = conn.createStatement();
        String sql = "select * from testtable";
        //返回值为获取到结果集
        ResultSet resultSet = st.executeQuery(sql);

    }
}

代码解析

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

作用为:要求jvm查找并加载指定的类(com.mysql.cj.jdbc.Driver),加载类就意味着需要需要执行静态代码块。

查看com.mysql.cj.jdbc.Driver源码

public class Driver extends NonRegisteringDriver implements java.sql.Driver {
    //
    // Register ourselves with the DriverManager
    //
    static {
        try {
            java.sql.DriverManager.registerDriver(new Driver());
        } catch (SQLException E) {
            throw new RuntimeException("Can't register driver!");
        }
    }

    /**
     * Construct a new driver and register it with DriverManager
     * 
     * @throws SQLException
     *             if a database error occurs.
     */
    public Driver() throws SQLException {
        // Required for Class.forName().newInstance()
    }
}

类中有一个静态代码块,在类被加载的时候,会制定该静态代码带块,这个静态代码块的作用是注册该类到驱动管理器中【DriverManager】,为什么这么写这个是JDBC的规范

因此【Class.forName("com.mysql.cj.jdbc.Driver");】这句代码的意思是将mysql的驱动加载类实例化。

 

Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "root");

作用:通过驱动管理器【DriverManager】将上一步注册的myql驱动取出,并调用驱动的【connect】方法,获取一个mysql的链接对象Connection conn,

 

Statement st = conn.createStatement();
        String sql = "select * from testtable";
        //返回值为获取到结果集
        ResultSet resultSet = st.executeQuery(sql);

作用:调用链接对象conn,执行对应sql并返回结果集

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值