JDBC和连接池01

1.JDBC概述

  • 基本介绍
  1. JDBC为访问不同的数据库提供了同一的接口,为使用者屏蔽了细节问题
  2. Java程序员使用JDBC,可以连接任何提供了jdbc驱动程序的数据库系统,从而完成对数据库的各种操作
  • jdbc原理图

    JDBC是java提供的一套用于数据库操作的接口API,Java程序员只需要面向这套接口编程即可。不同的数据库厂商需要针对这套接口,提供不同的实现。

jdbc模拟实现

模拟JDBC驱动:

package jdbc.myjdbc;

/**
* 我们规定的jdbc接口(方法)规范
*/
public interface JdbcInterface {
//连接
public Object getConnection();
//crud
public void crud();
//关闭连接
public void close();
}

模拟Mysql驱动:

package jdbc.myjdbc;

/**
* 模拟 mysql数据库实现jdbc接口[由mysql厂商开发]
*/ public class MysqlJdbcImpl implements JdbcInterface{ @Override
public Object getConnection() {
System.out.println("得到 mysql 的连接");
return null;
} @Override
public void crud() {
System.out.println("完成 mysql 的增删改查"); } @Override
public void close() {
System.out.println("关闭 mysql 的连接");
}
}

模拟Oracle驱动:

package jdbc.myjdbc;

/**
* 模拟实现oracle的连接驱动-即实现规范接口
*/
public class OracleJdbcImpl implements JdbcInterface{
@Override
public Object getConnection() {
System.out.println("得到 oracle 的连接");
return null;
} @Override
public void crud() {
System.out.println("完成 oracle 的增删改查");
} @Override
public void close() {
System.out.println("关闭 oracle 的连接");
}
}

模拟java程序使用各种数据库驱动连接数据库:

package jdbc.myjdbc;

public class TestJdbc {
public static void main(String[] args) {
//完成mysql的操作
JdbcInterface jdbcInterface = new MysqlJdbcImpl();
jdbcInterface.getConnection();// 通过接口来调用实现类[动态绑定]
jdbcInterface.crud();
jdbcInterface.close();
System.out.println("==============");
//完成oracle的操作
jdbcInterface = new OracleJdbcImpl();
jdbcInterface.getConnection();// 通过接口来调用实现类[动态绑定]
jdbcInterface.crud();
jdbcInterface.close();
}
}

  • JDBC API

jdbc api是一系列的接口,它统一和规范了应用程序与数据库的连接、执行SQL语句,并得到返回结果等各类操作,相关类和接口在java.sql与javax.sql包中。

2.JDBC快速入门

2.1JDBC程序编写步骤

  1. 注册驱动 -- 加载Driver类

  2. 获取连接 -- 得到Connection

  3. 执行增删改查 -- 发送SQL命令给mysql执行

  4. 释放资源 -- 关闭相关连接

例子--通过jdbc对表actor进行添加,删除和修改操作

  1. 首先在SQL yog使用mysql数据库创建一个演员actor表
-- 创建测试表 演员表
CREATE TABLE actor(
id INT PRIMARY KEY AUTO_INCREMENT,
`name` VARCHAR(32) NOT NULL DEFAULT '',
sex CHAR(1) NOT NULL DEFAULT '女',
borndate DATETIME,
phone VARCHAR(12)
); SELECT * FROM actor;
  1. 下载mysql连接驱动

  1. 在项目中创建libs文件夹,将驱动复制进文件夹中,右键点击驱动,选择ad as library

  2. 在弹出的窗口中点击OK,即可

package li.jdbc;

import com.mysql.jdbc.Driver;

import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties; /**
* 这是第一个jdbc程序,完成简单的操作
*/
public class jdbc01 {
public static void main(String[] args) throws SQLException {
//前置工作:在项目下创建一个文件夹如 libs
//将mysql.jar拷贝到该目录下,点击add to project.. 加入到项目中 //1.注册驱动
Driver driver = new Driver();//创建一个driver对象 //2.得到连接
/**
* jdbc:mysql:// 是规定好的协议,表示通过jdbc的方式来连接mysql
* localhost 表示要连接到的主机ip地址
* 3306 表示mysql监听的端口
* hsp_db02 表示连接到 mysql DBMS的哪个数据库
*/
// mysql的连接本质就是socket的连接
String url = "jdbc:mysql://localhost:3306/hsp_db02"; //将用户名和密码放入到一个Properties对象中
Properties properties = new Properties();
// user 和 password 是规定好的,后面的值根据实际情况写
properties.setProperty("user", "root");//用户
properties.setProperty("password", "123456");//密码 Connection connect = driver.connect(url, properties); //3.执行sql
String sql = "insert into actor values(null,'刘德华','男','1970-11-11','110')";
//String sql = "update actor set name ='周星驰' where id = 1 ";
//String sql = "delete from actor where id = 1 ";
//Statement 用于执行静态SQL语句并返回其生成的结果的对象
Statement statement = connect.createStatement();
int rows = statement.executeUpdate(sql);//如果是dml语句,返回的就是影响的行数
System.out.println(rows > 0 ? "成功" : "失败"); //4.关闭连接资源
statement.close();
connect.close();
}
}

在SQL yog中执行语句查询,发现actor表中成功插入一条数据

2.2数据库连接的5种方式

2.2.1方式1

//获取Driver实现类对象
Driver driver = new com.mysql.jdbc.Driver(); String url = "jdbc:mysql://localhost:3306/jdbc_db"; Properties info = new Properties();
info.setProperty("user", "root");//用户
info.setProperty("password", "123456");//密码
Connection conn = driver.connect(url,info);
System.out.println(conn);

2.2.2方式2

方式1会直接使用com.mysql.jdbc.Driver(),属于静态加载,灵活性差,依赖性强

方式2使用反射机制进行动态加载,而且信息可以放入配置文件中保存,更利于项目的控制

例子

package li.jdbc;

//分析java连接mysql的5种方式

import com.mysql.jdbc.Driver;
import org.junit.Test; import java.sql.Connection;
import java.util.Properties; public class jdbcConn {
//方式2
@Test
public void connect02() throws Exception {
//使用反射加载Driver类,动态加载,更加地灵活,减少依赖性
Class<?> aClass = Class.forName("com.mysql.jdbc.Driver");
Driver driver = (Driver)aClass.newInstance(); String url = "jdbc:mysql://localhost:3306/hsp_db02";
//将 用户名和密码 放入到 Properties对象中
Properties properties = new Properties();
// user 和 password 是规定好的,后面的值根据实际情况写
properties.setProperty("user", "root");//用户
properties.setProperty("password", "123456");//密码
Connection connect = driver.connect(url, properties);
System.out.println("方式2="+connect);
}
}

2.2.3方式3

在方式2的基础上使用DriverManager替换Driver




例子

package li.jdbc;

import com.mysql.jdbc.Driver;
import org.junit.Test; import java.sql.Connection;
import java.sql.DriverManager; public class jdbcConn { //方式3 使用DriverManager替换Driver进行统一管理
@Test
public void connect03() throws Exception {
//使用反射加载Driver类
Class<?> aClass = Class.forName("com.mysql.jdbc.Driver");
Driver driver = (Driver)aClass.newInstance();
//创建 url和 user 和 password
String url = "jdbc:mysql://localhost:3306/hsp_db02";
String user = "root";
String password = "123456"; DriverManager.registerDriver(driver);//注册Driver驱动
Connection connection = DriverManager.getConnection(url, user, password);
System.out.println("方式3="+connection);
}
}

2.2.4方式4

使用Class.forName自动完成注册驱动,简化代码

例子

//方式4 使用Class.forName自动完成注册驱动,简化代码
// 这种方式获取连接是使用得最多的,推荐使用
@Test
public void connect04() throws Exception {
//使用反射加载Driver类
//在加载Driver类时,完成了注册
/**
* 在 Driver类的源码中:
* 1.静态代码块在类加载时会执行一次
* 2.DriverManager.registerDriver(new Driver());
* 3.因此 注册Driver的工作已经在底层完成了
* static {
* try {
* DriverManager.registerDriver(new Driver());
* } catch (SQLException var1) {
* throw new RuntimeException("Can't register driver!");
* }
* }
*/
Class.forName("com.mysql.jdbc.Driver"); //创建 url和 user 和 password
String url = "jdbc:mysql://localhost:3306/hsp_db02";
String user = "root";
String password = "123456"; Connection connection = DriverManager.getConnection(url, user, password);
System.out.println("方式4="+connection);
}

方法4相比于方法3,减少了注册驱动的操作,但是连接数据库的步骤不是需要注册驱动吗?为什么可以这样呢?

在Driver类的源码中,我们可以看到有这样的一个静态代码块:

而静态代码块在类加载时会执行一次,在使用反射加载Driver类时,就执行了DriverManager.registerDriver(new Driver());语句。

即在加载Driver类时,完成了注册。因此,可以在程序中省略注册的步骤。

注意:

  1. mysql驱动5.1.6之后连Class.forName("com.mysql.jdbc.Driver");也不需要写了

  2. 从jdk1.5以后使用了jdbc4,不再需要显式调用Class.forName()注册驱动,而是自动调用驱动jar包下的META-INF\services\java.sql.Driver文本中的类名称去注册

  3. 但是还是建议写上Class.forName("com.mysql.jdbc.Driver");,更加明确

2.2.5方式5

在方式4的基础上使用配置文件,连接数据库更加灵活


例子

首先在src文件夹下面创建一个Properties文件

user=root
password=123456
url=jdbc:mysql://localhost:3306/hsp_db02
driver=com.mysql.jdbc.Driver

方式5:推荐使用

  //方式5 在方式4的基础上使用配置文件,连接数据库更加灵活
@Test
public void connect05() throws Exception {
//通过Properties对象拿到配置文件的信息
Properties properties = new Properties();
properties.load(new FileInputStream("src\\mysql.properties"));
//获取相关的值
String user = properties.getProperty("user");
String password = properties.getProperty("password");
String url = properties.getProperty("url");
String driver = properties.getProperty("driver"); Class.forName(driver);//建议写上
Connection connection = DriverManager.getConnection(url, user, password);
System.out.println("方式5="+connection); }

day45-JDBC和连接池01的更多相关文章

  1. c3p0、dbcp、tomcat jdbc pool 连接池配置简介及常用数据库的driverClass和驱动包

    [-] DBCP连接池配置 dbcp jar包 c3p0连接池配置 c3p0 jar包 jdbc-pool连接池配置 jdbc-pool jar包 常用数据库的driverClass和jdbcUrl ...

  2. jdbc数据连接池dbcp要导入的jar包

    jdbc数据连接池dbcp要导入的jar包 只用导入commons-dbcp-x.y.z.jarcommons-pool-a.b.jar

  3. 关于JDBC和连接池我学到的(转载保存)

    1.JDBC数据库连接池的必要性 在使用开发基于数据库的web程序时,传统的模式基本是按以下步骤: 在主程序(如servlet.beans)中建立数据库连接. 进行sql操作 断开数据库连接. 这种模 ...

  4. JDBC之 连接池

    JDBC之 连接池 有这样的一种现象: 用java代码操作数据库,需要数据库连接对象,一个用户至少要用到一个连接.现在假设有成千上百万个用户,就要创建十分巨大数量的连接对象,这会使数据库承受极大的压力 ...

  5. JDBC数据源连接池(4)---自定义数据源连接池

    [续上文<JDBC数据源连接池(3)---Tomcat集成DBCP>] 我们已经 了解了DBCP,C3P0,以及Tomcat内置的数据源连接池,那么,这些数据源连接池是如何实现的呢?为了究 ...

  6. JDBC数据源连接池(3)---Tomcat集成DBCP

    此文续<JDBC数据源连接池(2)---C3P0>. Apache Tomcat作为一款JavaWeb服务器,内置了DBCP数据源连接池.在使用中,只要进行相应配置即可. 首先,确保Web ...

  7. JDBC数据源连接池(2)---C3P0

    我们接着<JDBC数据源连接池(1)---DBCP>继续介绍数据源连接池. 首先,在Web项目的WebContent--->WEB-INF--->lib文件夹中添加C3P0的j ...

  8. DBCP,C3P0与Tomcat jdbc pool 连接池的比较

    hibernate开发组推荐使用c3p0; spring开发组推荐使用dbcp(dbcp连接池有weblogic连接池同样的问题,就是强行关闭连接或数据库重启后,无法reconnect,告诉连接被重置 ...

  9. JDBC数据源连接池的配置和使用实例

    个人学习参考所用,勿喷! 使用JDBC建立数据库连接的两种方式: 1.在代码中使用DriverManager获得数据库连接.这种方式效率低,并且其性能.可靠性和稳定性随着用户访问量得增加逐渐下降. 2 ...

随机推荐

  1. FHQ-Treap 简介

    FHQ-treap 即非旋Treap,是一种短小精悍,功能丰富的平衡树. 据说它的效率介于 Treap 和 Splay 之间(可能是我的FHQ常数比较小,跑得比我的Treap还快). 它可以实现 Sp ...

  2. Excel 运算符(一):算术运算符

    算术运算符用于最基本的加.减.乘.除运算. 运算符 含义 实例 结果 + 加法运算 =2+3 5 - 减法运算 =5-2 3 * 乘法运算 =5*2 10 / 除法运算 =4/2 2 % 百分数 =5 ...

  3. linux 旁路掉协议栈的处理点

    对于协议栈的发展,目前有三种处理趋势,一种是类似于使用dpdk的方式,然后将协议栈放到用户态来做,做得比较好的一般都是以bsd的协议栈为底子,可以参考的是腾讯开源的的方案,另外一种是,继续放在内核,但 ...

  4. python与pycharm的安装与“试用”

    python与pycharm的安装与"试用" 一.python解释器安装与启动 python解释器的安装 1.打开文件安装包运行页面 #python3.8 2.选择Customiz ...

  5. java数组---稀疏数组与数组之间的相互转化

    public static void main(String[] args) { int[][]array1=new int[11][11]; array1[1][2]=1; array1[2][3] ...

  6. 【java】学习路线5-public和private、构造方法、this关键字、封装对象、static关键字、main方法结构解析

    //一个教务管理系统//知识点清单/*public & private 的区别一个是公开的,一个是私有的,作用域不一样,访问的权限不一样咯如果是用private修饰,则调用者只可以是在当前的作 ...

  7. 第八十九篇:Vue 重学插槽slot

    好家伙, 1.什么是插槽? 插槽是vue为组件的封装者提供的能力.允许开发者在封装组件时, 把不确定的,希望由用户指定的部分定义为插槽   我们依然可以把它理解为一个占位符 1.1.插槽的基本用法 试 ...

  8. SpringMVC 06: 日期类型的变量的注入和显示

    日期处理和日期显示 日期处理 此时SpringMVC的项目配置和SpringMVC博客集中(指SpringMVC 02)配置相同 日期处理分为单个日期处理和类中全局日期处理 单个日期处理: 使用@Da ...

  9. noip2015提高组初赛

    一.单项选择题(共15题,每题1.5分,共计22.5分:每题有且仅有一个正确选项) 线性表若采用链表存储结构,要求内存中可用存储单元地址( ). A. 必须连续 B. 部分地址必须连续 C. 一定不连 ...

  10. Arrays.asList()你真的知道怎么用吗?

    发现问题 前几天在看别人的项目的时候,发现一个问题,简单复现一下这个问题 // 注意这是一个Integer对象的数组哦 Integer[] arr = new Integer[]{9999,88,77 ...