JDBC01 获取数据库连接
概述
Java Database Connectivity(JDBC)直接访问数据库,通用的SQL数据库存取和操作的公共接口,定义访问数据库的标准java类库(java.sql,javax.sql)

JDBC程序编写步骤

说明:
1.创建Connection对象相当于与数据库建立了链接
2.查询与增删改的差别是是否需要结果集,所以查询需要ResultSet对象
获取数据连接
目的:创建Connection对象
buid path
说明:如果只是将jar包复制到Java工程里面去,是无法使用jar包里面的类,因为无法找到jar包,所以build path其实就是添加jar包的路径
1.先导入jar包

File -> Project Structure -> Modules -> 选中要添加build path的项目 -> Dependencies -> 点击右边的小加号 -> 选择JARs or directories -> 选中jar包的目录

Driver注册
获取Driver实现类对象
//注册 JDBC 驱动
Class.forName("com.mysql.cj.jdbc.Driver");
把Driver类加载到内存中,Driver类中有一段静态代码块(随类的加载而加载)
//Driver类中的静态代码块
static{
try{
java.sql.DriverManager.registerDriver(new Driver());
}catch(SQLException E){
throw new RuntimeException("Can't register driver!");
}
}
所以就不需要手动注册驱动了
//获得该类时自动完成了下面的代码
//加载Driver
Class clazz = Class.forName("com.mysql.jdbc.Driver");
// 获得实例
Driver driver =(Driver)clazz.getDeclaredConstructor().newInstance();
DriverManager.registerDriver(driver); //注册驱动
反射知识复习
Class的实例对应一个运行时类
获取Class实例=获取该类=获取运行时类,调用Class的静态方法forName(String classPath) classPath 包名.类名
java.exe命令对某个字节码文件进行解释运行,相当于将某个字节码文件加载到内存中。此过程称为类的加载.加载到内存中的类,就称为运行时类
创建运行时类的对象,要求
1.调用空参构造器,所以该运行时类必须有空参构造器
2.空参构造器的访问权限要足够
Class<Person> clazz = Person.class;
clazz.getDeclaredConstructor().newInstance();
URL
示例:jdbc:mysql://localhost:3306/test
jdbc:mysql 协议
localhost ip地址
3306 默认mysql端口号
test mysql中的test数据库
注意点:
1.MySQL 8.0 以上版本不需要建立 SSL 连接的,需要显示关闭。
2.allowPublicKeyRetrieval=true 允许客户端从服务器获取公钥。
3.最后还需要设置时区Asia/Shanghai
创建Connection对象,使用DriverManager的静态方法
//使用的静态方法
conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=Asia/Shanghai","root","password");
获取数据连接
//Mysql8.0以上 - JDBC驱动名
final String JDBC_DRIVER = "com.mysql.cj.jdbc.Driver";
//数据库url
final String DB_URL = "jdbc:mysql://localhost:3306/test?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC";
final String USER = "root";
final String PASSWORD = "root";
//加载驱动
Class.forName(JDBC_DRIVER); //可以省略
//获取mysql连接
Connection conn = DriverManager.getConnection(DB_URL, USER, PASSWORD);
这里的信息应该都写在配置文件中,不应该写在代码块中。通过读取配置文件的方式,获取连接。
这种方式的好处
1.实现数据与代码的分离,实现了解耦
2.如果需要修改配置文件信息,可以避免程序重新打包

//1.以流的方式获取配置信息,默认路径时src下
InputStream is = ConnectionTest.class.getClassLoader().getResourceAsStream("jdbc.properties");
Properties pros = new Properties();
pros.load(is);
String USER = pros.getProperty("user");
String PASSWORD = pros.getProperty("password");
String DB_URL = pros.getProperty("url");
String JDBC_DRIVER = pros.getProperty("jdbc_driver");
//2.注册驱动
Class.forName(JDBC_DRIVER);
//3.获取mysql连接
Connection conn = DriverManager.getConnection(DB_URL, USER, PASSWORD);
System.out.println(conn);
JDBC01 获取数据库连接的更多相关文章
- <一>获取数据库连接
一.JDBC_通过Driver接口获取数据库连接 1. Driver是一个接口:数据库厂商必须提供实现的接口,可以从其中 获取数据库连接. 2.JDBC URL由三部分组成,各部分用冒号隔开,格式:j ...
- JAVA jdbc获取数据库连接
JDBC获取数据库连接的帮助类 import java.io.InputStream; import java.sql.Connection; import java.sql.DriverManage ...
- 使用DriverManager获取数据库连接的一个小改进
由于使用DriverManager获取数据库连接时,由于DriverManager实现类中有一段静态代码块,可以直接注册驱动,且可以同时管理多个驱动程序 所以当换数据库连接时需要指定不同的数据库,那么 ...
- 使用DriverManager获取数据库连接
DriverManager 是驱动的管理类 * 1).可以通过重载的getConnection() 方法获取数据库连接,较为方便 * 2).可以同时管理多个驱动程序,若注册了多个数据库连接,则调用ge ...
- 通过Driver获取数据库连接
先看一下文件,在当前包下有一个properties配置文件,在根目录下有一个lib文件夹,里面放的是mySql的驱动jar包 Driver :是一个接口,数据库厂商必须提供实现的接口,能从其中获取数据 ...
- JDBC_获取数据库连接
<span style="font-size:24px;">package src.com.jdbc.java; import java.io.IOException; ...
- 获取数据库连接对象Connection
2018-11-04 19:50:52 开始写 public Connection getConn() {//返回类型为Connection try { Class.forName("co ...
- JDBC编程:获取数据库连接
JDBC(Java Database Connectivity),即Java数据库连接.通过JDBC编程,可以使Java应用程序和数据库进行交互. JDBC驱动的方式有很多种,我们常用的驱动方式为:本 ...
- JDBC 学习笔记(四)—— JDBC 加载数据库驱动,获取数据库连接
1. 加载数据库驱动 通常来说,JDBC 使用 Class 类的 forName() 静态方法来加载驱动,需要输入数据库驱动代表的字符串. 例如: 加载 MySQL 驱动: Class.forName ...
随机推荐
- 洛谷 P3209 [HNOI2010] 平面图判定
链接: P3209 题意: 给出 \(T\) 张无向图 \((T\leq100)\),并给出它对应的哈密顿回路,判断每张图是否是平面图. 分析: 平面图判定问题貌似是有线性做法的,这里给出链接,不是本 ...
- Netty:Netty的介绍以及它的核心组件(一)—— Channel
1. Netty 介绍 Netty 是一个无阻塞的输入/输出(NIO)框架,它使开发低级网络服务器和客户端变得相对简单.Netty为需要在套接字级别上工作的开发人员提供了令人难以置信的强大功能,例如, ...
- [WPF] 使用三种方式实现弧形进度条
1. 需求 前天看到有人问弧形进度条怎么做,我模仿了一下,成果如下图所示: 当时我第一反应是可以用 Microsoft.Toolkit.Uwp.UI.Controls 里的 RadialGauge 实 ...
- CLion 2021.2 debug报错 process exited with status -1 (attach failed (Not allowed to attach to process.
Clion 升级 2021.2 版本后 debug 报错: process exited with status -1 (attach failed (Not allowed to attach to ...
- PTA 7-2 畅通工程之局部最小花费问题 (35分)
PTA 7-2 畅通工程之局部最小花费问题 (35分) 某地区经过对城镇交通状况的调查,得到现有城镇间快速道路的统计数据,并提出"畅通工程"的目标:使整个地区任何两个城镇间都可以实 ...
- 事件消息生产消费中间件-OSS.DataFlow
系统重构解耦的过程涉及不同领域服务分拆,或同一服务下实时响应部分和非响应部分分拆,分解后的各部分通过异步消息的流转传递,完成整体的业务逻辑,但是频繁的在业务层面直接调用不同消息队列的SDK,个人感觉不 ...
- python unicode escape
from: https://stackoverflow.com/questions/44742806/how-to-remove-escape-characters-escaping-unicode- ...
- Roslyn 编译器Api妙用:动态生成类并实现接口
在上一篇文章中有讲到使用反射手写IL代码动态生成类并实现接口. 反射的妙用:C#通过反射动态生成类型继承接口并实现 有位网友推荐使用 Roslyn 去脚本化动态生成,今天这篇文章就主要讲怎么使用 Ro ...
- Docker 急速入门
1. 概述 之前聊了很多 SpringCloud 相关的话题,今天我们来聊聊服务容器 Docker. 2. 在 CentOS7 安装 Docker 2.1 卸载旧版本的Docker # yum re ...
- 构建“元宇宙”,有哪些3D建模方式?
"沉浸.3D世界.虚拟社交.虚拟购物",最近"元宇宙"的概念特别火.人们畅想通过AR/VR以及其他互联网技术,把现实世界的楼房街道.天气温度.人际关系等投射到虚 ...