JDBC¶
JDBC(Java DataBase Connectivity - Java数据库连接),是SUN公司定义的一套接口(规范)。
用于数据库连接的JDBC驱动库。

JDBC访问数据库编码步骤¶
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class Test {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
// 1、加载Driver驱动
Class.forName("com.mysql.cj.jdbc.Driver");
// 2、获取数据库连接(Connection)
String url = "jdbc:mysql://127.0.0.1:3306/msb?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true";
String username = "root";
String password = "asdf123456";
Connection conn = DriverManager.getConnection(url, username, password);
// 3、创建会话-SQL命令发送器(Statement)
Statement sta = conn.createStatement();
// 4、通过Statement发送SQL命令并得到结果
//插入数据
//发送SQL:
int i = sta.executeUpdate("insert into t_book (id,name,author,price) values (3,'红高粱','莫言',49)");
// 5、处理结果:
if(i > 0){//证明对数据库的数据条数有影响
System.out.println("插入成功!");
}else{
System.out.println("插入失败!");
}
//查询数据
//发送SQL:ResultSet结果集合 - 结果集
ResultSet rs = sta.executeQuery("select * from t_book where price < 40");
//处理结果:
while(rs.next()){//判断是否有记录存在
System.out.println(rs.getInt("id") + "---" + rs.getString("name") + "--" + rs.getString("author") + "--" + rs.getDouble("price"));
}
// 6、关闭数据库资源(ResultSet、Statement、Connection)
sta.close();
conn.close();
}
}
getConnection方法url参数
String url="jdbc:mysql://127.0.0.1:3306/数据库名称?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true";
jdbc:mysql:mysql协议127.0.0.1:3306ip和端口号useSSL:是否使用SSL认证机制-不使用 falseuseUnicode:是否unicode字符集-使用characterEncoding=UTF-8:使用unicode 的utf-8策略serverTimezone=Asia/Shanghai:时区参数-东八区allowPublicKeyRetrieval=true:允许客户端从服务器获取公钥