一、JDBC的概念:
JDBC 是 Java DataBase Connectivity (Java 数据连接)技术的简称,是一种可用于执行 SQL 语句的 Java API。它由一些 java 语言编写的类和接口组成;程序员通过使用 jdbc 可以方便地将 SQL 语句传送给几乎任何一种数据库。
二、JDBC的功能:
(1)与数据库建立连接。
(2)向数据库发送sql语句,并执行这些语句。
(3)处理数据返回的结果。
JDBC下载链接:
- https://dev.mysql.com/downloads/connector/j/
下载之后解压,然后点开解压后的文件,一直到下图然后复制
之后再新建一个项目,在项目里新建一个目录lib,把刚才复制的粘贴到lib里面,然后再把lib添加到库,最后就可以执行下面的代码了。
1.加载驱动:
Class.forName("com.mysql.cj.jdbc.Driver");
2.用户信息和url:
String url = "jdbc:mysql://localhost:3306/jdbcStudy?useUnicode=true&characterEncoding=utf8&useSSL=true&serverTimezone=GMT%2B8";String username = "root";String password = "111111";//如果报错显示时区问题在url后面加&serverTimezone=GMT%2B8
3.连接成功,数据库对象 Connection 代表数据库
Connection connection = DriverManager.getConnection(url, username, password);
4.执行sql对象:
Statement statement = connection.createStatement();
5.获得执行sql的对象 Statement,查看返回结果
String sql = "SELECT * FROM users";ResultSet resultSet = statement.executeQuery(sql);//返回结果集
6.释放连接:
resultSet.close();statement.close();connection.close();
整体代码:
import java.sql.*;public class jdbc {public static void main(String[] args) throws ClassNotFoundException, SQLException {//1.加载驱动Class.forName("com.mysql.cj.jdbc.Driver");//固定写法,加载驱动//2.用户信息和urlString url = "jdbc:mysql://localhost:3306/jdbcStudy?useUnicode=true&characterEncoding=utf8&useSSL=true&serverTimezone=GMT%2B8";String username = "root";String password = "111111";//如果报错显示时区问题在url后面加&serverTimezone=GMT%2B8//3.连接成功,数据库对象 Connection 代表数据库Connection connection = DriverManager.getConnection(url, username, password);//4.执行SQL的对象Statement statement = connection.createStatement();//5.执行SQL的对象 去 执行SQL,可能存在结果,查看返回结果String sql = "SELECT * FROM users";ResultSet resultSet = statement.executeQuery(sql);//返回结果集while(resultSet.next()){System.out.println("id=" + resultSet.getObject("id"));System.out.println("name=" + resultSet.getObject("NAME"));System.out.println("pwd=" + resultSet.getObject("PASSWORD"));System.out.println("email=" + resultSet.getObject("email"));System.out.println("birth=" + resultSet.getObject("birthday"));System.out.println("========================");}//释放连接resultSet.close();statement.close();connection.close();}
}