概述

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 获取数据库连接的更多相关文章

  1. <一>获取数据库连接

    一.JDBC_通过Driver接口获取数据库连接 1. Driver是一个接口:数据库厂商必须提供实现的接口,可以从其中 获取数据库连接. 2.JDBC URL由三部分组成,各部分用冒号隔开,格式:j ...

  2. JAVA jdbc获取数据库连接

    JDBC获取数据库连接的帮助类 import java.io.InputStream; import java.sql.Connection; import java.sql.DriverManage ...

  3. 使用DriverManager获取数据库连接的一个小改进

    由于使用DriverManager获取数据库连接时,由于DriverManager实现类中有一段静态代码块,可以直接注册驱动,且可以同时管理多个驱动程序 所以当换数据库连接时需要指定不同的数据库,那么 ...

  4. 使用DriverManager获取数据库连接

    DriverManager 是驱动的管理类 * 1).可以通过重载的getConnection() 方法获取数据库连接,较为方便 * 2).可以同时管理多个驱动程序,若注册了多个数据库连接,则调用ge ...

  5. 通过Driver获取数据库连接

    先看一下文件,在当前包下有一个properties配置文件,在根目录下有一个lib文件夹,里面放的是mySql的驱动jar包 Driver :是一个接口,数据库厂商必须提供实现的接口,能从其中获取数据 ...

  6. JDBC_获取数据库连接

    <span style="font-size:24px;">package src.com.jdbc.java; import java.io.IOException; ...

  7. 获取数据库连接对象Connection

    2018-11-04  19:50:52 开始写 public Connection getConn() {//返回类型为Connection try { Class.forName("co ...

  8. JDBC编程:获取数据库连接

    JDBC(Java Database Connectivity),即Java数据库连接.通过JDBC编程,可以使Java应用程序和数据库进行交互. JDBC驱动的方式有很多种,我们常用的驱动方式为:本 ...

  9. JDBC 学习笔记(四)—— JDBC 加载数据库驱动,获取数据库连接

    1. 加载数据库驱动 通常来说,JDBC 使用 Class 类的 forName() 静态方法来加载驱动,需要输入数据库驱动代表的字符串. 例如: 加载 MySQL 驱动: Class.forName ...

随机推荐

  1. OSI参考模型(应用层、表示层、会话层、传输层、网络层、数据链路层、物理层)

    文章转自:https://blog.csdn.net/weixin_43914604/article/details/104589085 学习课程:<2019王道考研计算机网络> 学习目的 ...

  2. 数组中重复的数字 牛客网 剑指Offer

    数组中重复的数字 牛客网 剑指Offer 题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中 ...

  3. clnt_create: RPC: Port mapper failure - Unable to receive: errno 111 (Connection refused)

    clnt_create: RPC: Port mapper failure - Unable to receive: errno 111 (Connection refused) 关闭防火墙,可以连, ...

  4. Kubernetes(k8s)部署redis-cluster集群

    Redis Cluster 提供了一种运行 Redis 安装的方法,其中数据 在多个 Redis 节点之间自动分片. Redis Cluster 还在分区期间提供了一定程度的可用性,这实际上是在某些节 ...

  5. 变量命名网站 Codelf

    程序员最头疼的事情除了头发以外就是给变量或函数命名,一开始学编程语言的时候还可以 abc.a1.x2 等方式命名,等到工作过程中开始真正的项目开发时,如果还是这样随意的命名,即使同事可以忍受你的 ab ...

  6. 模块化开发 | es6模块暴露与引入

    CommonJS模块开发 CommonJS定义 每个文件就一个模块,有自己的作用域.在一个文件里面定义的变量.函数.类,都是私有的,对其他文件不可见. 私有作用域不会污染全局作用域. 模块可加载多次, ...

  7. 问题 G: 心急的C小加

    题目描述 C小加有一些木棒,它们的长度和质量都已经知道,需要一个机器处理这些木棒,机器开启的时候需要耗费一个单位的时间,如果第i+1个木棒的重量和长度都大于等于第i个处理的木棒,那么将不会耗费时间,否 ...

  8. C# 获取PDF中的数字签名证书

    PDF中的加数字签名是对文档权威性的有效证明.我们在向PDF文档添加签名时,需要准备可信任的签名证书.同时,对已有的签名,可验证签名是否有效,也可以获取文档中的签名证书信息.下面,以C#代码示例展示如 ...

  9. Chrome handless无界面浏览器的脚本操作

    1.什么是Phantomjs (已经停止更新) 是一个无界面的浏览器 支持页面元素查找,js的执行等 由于不进行css和gui渲染,运行效率要比真实的浏览器要快很多 2.如何使用Phantomjs? ...

  10. vue + cesium开发(5) 搭建 vue + cesium开发环境(2)

    上vue+cesium开发(1)中,没有进行配置webpack,而是使用了插件进行代替,在使用过程中出现了一些未知BUG,影响体验,因此参考了官方文档对项目进行重新配置,使用了 copy-webpac ...