Java原生操作JDBC连接以及原理详解

一、简介

JDBC全称又叫做Java DataBase Connectivity,也就是Java数据库连接,说白了就是用Java语言来操作数据 库,提供统一API访问数据库操作。

二、原理

JDBC主要是用于java连接数据库的,能连接什么数据库不固定,其实能连接很多种数据库,而且一般来说可以连接oracle和mysql,通常也是这两种。但是既然JDBC能连接这么多的数据库,开发起来太麻烦了,于是sun公司那些人想出了一个办法,我定义一套规范,大家都按照这个规范来,实现自己公司访问数据库的实现。这套规范就是JDBC,遵循了JDBC规范的,可以访问自己数据库的API被称之为数据库驱动。

三、数据库操作

数据库操作分为6个步骤(增、删、改可跳过第5步,移步看第6步):

1、首先,项目中检查是否已导入mysql连接jar包,如:mysql-connector-java-5.1.6-bin.jar

2、使用反射注册数据库驱动,Class.forName(name);

3、通过DriverManager.getConnection(url, username, password)构造器获取数据库连接

4、通过Connection连接对象获取数据库操作对象PrepareStatement或者Statement

5、通过获取的Statement对象执行executeQuery()操作返回ResultSet结果集,需判断是否为空

6、通过获取的Statement对象执行executeUpdate()操作返回受影响的行数,判断是否成功标识

7、释放连接资源,关闭顺序为:ResultSet -> PrepareStatement / Statement -> Connection

解释说明关键类:

(1)DriverManager:该类管理数据库驱动程序。

(2)Connection:管理数据库建立的连接。

(3)Statement:负责将要执行的sql体提交到数据库。

(4)ResultSet:执行sql查询语句返回的结果集。

(5)PreparedStatement: 可以使用预编译的SQL,防止SQL注入,而Statment只能使用静态的SQL。

PreparedStatement 与 Statment 区别:

语法不同: PreparedStatement可以使用预编译的sql,而Statment只能使用静态的sql。

效率不同: PreparedStatement可以使用sql缓存区,效率比Statment高。

安全性不同: PreparedStatement可以有效防止sql注入,而Statment不能防止sql注入。

四、数据库增、删、改、查示例

工具类(可做相对应灵活替换):

package com.bnd.util;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Objects;

/** 

* @author 作者 mbql: 

* @version 创建时间:2021年1月10日 下午5:14:16 

* 类说明 	JDBC操作数据库工具类

*/
public class JdbcUtils {

	private static final String driverName = "com.mysql.jdbc.Driver";		// 数据库驱动名称

	private static final String url = "jdbc:mysql://39.108.146.20:3307/jsp?useUnicode=true&characterEncoding=utf-8";	// 数据库url

	private static final String userName = "root";			// 用户名

	private static final String password = "123456";	 // 用户密码

	private static Connection conn = null;					// 数据库连接对象

	private static PreparedStatement preparedStatement = null;	// 执行操作对象

	static {

		try {
			Class.forName(driverName);		// 2、注册数据库驱动
			conn = DriverManager.getConnection(url, userName, password);	// 3、获取数据库连接
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

	}

	/**
	 * 查询数据
	 * @return	返回查询到结果
	 */
	public static ResultSet queryData() {
		ResultSet result = null;
		String sql = "select id, name, pwd from user";		// 定义预编译SQL
		try {
			preparedStatement = conn.prepareStatement(sql);			// 4、执行预编译SQL操作
			result = preparedStatement.executeQuery();	// 5、执行查询操作
			while (result.next()) {
				int id = result.getInt(1);
				String name = result.getString(2);
				String pwd = result.getString(3);
				System.out.println("id:" + id + "--> name:" + name + "--> pwd:" + pwd);
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally {
			// 7、释放资源
			close(conn, preparedStatement, result);
		}
		return result;
	}

	/**
	 * 添加数据
	 * @return	返回受影响行数
	 */
	public static int addData() {
		String sql = "insert into user(name,pwd) values(?, ?)";
		try {
			preparedStatement = conn.prepareStatement(sql);		// 4、执行预编译SQL操作
			preparedStatement.setString(1, "tom");
			preparedStatement.setString(2, "abc123");
			int count = preparedStatement.executeUpdate();			// 6、执行添加操作
			if (count > 0) {
				return count;
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally {
			// 7、释放资源
			close(conn, preparedStatement, null);
		}
		return -1;
	}

	/**
	 * 更新数据
	 * @return	返回受影响行数
	 */
	public static int updateData() {
		String sql = "update user set name = ?, pwd = ? where id = ?";
		try {
			preparedStatement = conn.prepareStatement(sql);		// 4、执行预编译SQL操作
			preparedStatement.setString(1, "sueno");
			preparedStatement.setString(2, "qwe123");
			preparedStatement.setInt(3, 10);
			int count = preparedStatement.executeUpdate();			// 6、执行添加操作
			if (count > 0) {
				return count;
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally {
			// 7、释放资源
			close(conn, preparedStatement, null);
		}
		return -1;
	}

	/**
	 * 删除数据
	 * @return	返回受影响行数
	 */
	public static int deleteData() {
		String sql = "delete from user where id = ?";
		try {
			preparedStatement = conn.prepareStatement(sql);		// 4、执行预编译SQL操作
			preparedStatement.setInt(1, 11);
			int count = preparedStatement.executeUpdate();			// 6、执行添加操作
			if (count > 0) {
				return count;
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally {
			// 7、释放资源
			close(conn, preparedStatement, null);
		}
		return -1;
	}

	/**
	 * 释放资源
	 * @param conn	关闭数据库连接
	 * @param statement	关闭数据库操作对象
	 * @param rs	关闭结果集操作对象
	 */
	public static void close(Connection conn, Statement statement, ResultSet rs) {
		if (Objects.nonNull(rs)) {
			try {
				rs.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
		if (Objects.nonNull(statement)) {
			try {
				statement.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
		if (Objects.nonNull(conn)) {
			try {
				conn.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
	}
}

测试类:

package com.bnd.util;

import java.sql.ResultSet;

/** 

* @author 作者 mbql: 

* @version 创建时间:2021年1月10日 下午6:00:30 

* 类说明 

*/
public class TestJdbc {

	public static void main(String[] args) {
		// 获取用户数据
//		ResultSet rs = JdbcUtils.queryData();
//		System.out.println(rs);

		// 添加用户数据
//		int count = JdbcUtils.addData();
//		if (count > 0) {
//			System.out.println("添加成功!");
//		}

		// 更新用户数据
//		int count = JdbcUtils.updateData();
//		if (count > 0) {
//			System.out.println("更新成功!");
//		}

		// 删除用户数据
//		int count = JdbcUtils.deleteData();
//		if (count > 0) {
//			System.out.println("删除成功!");
//		}
	}
}

五、总结

1、通过简单Jdbc连接数据库,巧妙的实现了CRUD;其实实现并不难,记一下数据库连接步骤就行。

2、数据库操作本身就是一套数据库规范,根据不同驱动能够达到连接不同的数据库,实现可实行操作。

3、剧上述连接可知,数据库连接是非常耗性能的,频繁的数据库操作,不及时释放资源,会导致IO阻塞。

到此这篇关于Java原生操作JDBC连接以及原理的文章就介绍到这了,更多相关Java原生操作JDBC连接及原理内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Java加载JDBC驱动程序实例详解

    本文实例说明了Java加载JDBC驱动程序的方法,运行本文实例代码后,如果连接成功就会显示如下一条语句:sun.jdbc.odbc.JdbcOdbcDriver@6ec12,如果连接不成功,则显示加载数据库驱动程序出现异常. Java加载JDBC的实现方法: 通过调用Class.forName()方法可以显式地加载一个驱动程序.该方法的入口参数为要加载的驱动程序.例如:Class.forName("sun.jdbc.odbc.JdbcOdbcDriver")语句加载了SUN 公司开发的

  • java jdbc连接mysql数据库实现增删改查操作

    jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打交道非常基础的一个知识,也是比较接近底层的,在实际的工作中大家用得更多的其实还是比较成熟的框架,例如Hibernate.Mybatis. 但是作为这些成熟框架的底层的jdbc却也是我们应该去掌握的,只有了解了jdbc的增删改查,这样在以后如果有兴趣去研究Hibernate或者Mybatis的源代码的时候才能更好的去理解这些成熟的框架是如何去实现增删改查

  • java使用JDBC动态创建数据表及SQL预处理的方法

    本文实例讲述了java使用JDBC动态创建数据表及SQL预处理的方法.分享给大家供大家参考,具体如下: 这两天由于公司的需求,客户需要自定义数据表的字段,导致每张表的字段都不是固定的而且很难有一个通用的模板去维护,所以就使用JDBC动态去创建数据表,然后通过表的字段动态添加数据,数据的来源主要是用户提供的Excel直接导入到数据库中. 如果考虑到字段的类型,可以通过反射的机制去获取,现在主要用户需求就是将数据导入到数据库提供查询功能,不能修改,所以就直接都使用String类型来处理数据更加便捷.

  • JAVA使用JDBC技术操作SqlServer数据库实例代码

    JDBC(Java Data Base Connectivity,Java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成.JDBC提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序. JDBC并不能直接访问数据库,需要借助于数据库厂商提供的JDBC驱动程序. 数据库连接 如果要在Java访问数据库,首先要加载一个数据库驱动,数据库驱动只需要在第一次访问时加载一次.然后再每次访问

  • 完整java开发中JDBC连接数据库代码和步骤

    JDBC连接数据库 •创建一个以JDBC连接数据库的程序,包含7个步骤: 1.加载JDBC驱动程序: 在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机), 这通过java.lang.Class类的静态方法forName(String className)实现. 例如: try{ //加载MySql的驱动类 Class.forName("com.mysql.jdbc.Driver") ; }catch(ClassNotFoundException e){ Sys

  • java的jdbc简单封装方法

    学习了jdbc一段时间后感觉自己写一个简单的封装来试试,于是参考的一些资料就写了一下不是多好,毕竟刚学也不太久 首先写配置文件:直接在src下建立一个db.properties文件然后写上内容 <span style="font-size:18px;">MysqlDriver=com.mysql.jdbc.Driver MysqlURL=jdbc\:mysql\://localhost\:3306/one User=root Pwd=123456 </span>

  • Java使用JDBC连接数据库的实现方法

    本文实例讲述了Java使用JDBC连接数据库的实现方法,是Java数据库程序设计里非常实用的重要技巧.分享给大家供大家参考.具体如下: JDBC(Java Data Base Connectivity)数据库连接,通常我们在编写web应用或java应用程序要连接数据库时就要使用JDBC.使用JDBC连接数据库一般步骤有: 1.加载驱动程序 Class.forName(driver); 2.创建连接对象 Connection con = DriverManager.getConnection(ur

  • Java开发Oracle数据库连接JDBC Thin Driver 的三种方法

    Oracle的jdbc驱动三种主要分类: 1.JDBC OCI: oci是oracle call interface的缩写,此驱动类似于传统的ODBC 驱动.因为它需要Oracle Call Interface and Net8,所以它需要在运行使用此驱动的JAVA程序的机器上安装客户端软件,其实主要是用到orcale客户端里以dll方式提供的oci和服务器配置. 2.JDBC Thin: thin是for thin client的意思,这种驱动一般用在运行在WEB浏览器中的JAVA程序.它不是

  • java实现jdbc批量插入数据

    首先介绍三种JDBC批量插入编程方法,进行比较,具体内容如下 JDBC批量插入主要用于数据导入和日志记录因为日志一般都是先写在文件下的等. 我用Mysql 5.1.5的JDBC driver 分别对三种比较常用的方法做了测试 方法一:使用PreparedStatement加批量的方法 try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(o_url, userName, pass

  • 基于Java回顾之JDBC的使用详解

    尽管在实际开发过程中,我们一般使用ORM框架来代替传统的JDBC,例如Hibernate或者iBatis,但JDBC是Java用来实现数据访问的基础,掌握它对于我们理解Java的数据操作流程很有帮助. JDBC的全称是Java Database Connectivity. JDBC对数据库进行操作的流程:•连接数据库•发送数据请求,即传统的CRUD指令•返回操作结果集JDBC中常用的对象包括:•ConnectionManager•Connection•Statement•CallableStat

随机推荐