JDBC的学习笔记-手动实现
JDBC是SUN公司提供的一套用于数据库操作的接口,Java程序员只需要面向这套接口编程即可。不同的数据库厂商,需要针对这套接口,提供不同实现。
使用JDBC的好处:1、程序员不需要关注不同数据库的细节。2、编写的代码具有更好的移植性。
下面是JDBC技术的两种实现方式,这篇文章先只介绍JDBC的手动实现,下一篇文章将介绍使用数据库连接池技术,也就是右边的路线。
零:首先要将对应的数据库的驱动导入到项目中。

一、获取连接
获取连接需要四个信息,分别是:对应数据库的驱动(这里以MySQL数据库为例)、url、用户名、密码。
但是我们一般不直接使用Driver,而是用DriverManager替换Driver来进行驱动的注册、加载、获取连接。
我们将获取连接所需要的四个信息放在properties文件中。
这是properties文件的代码,driverClass是对应的数据库的驱动;url的写法:jdbc:mysql:是协议,localhost:这里是ip地址,3306是对应的端口号,test是要操作的数据库的库名称。
driverClass=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/test
user=root
password=1234
接下来就是获取连接的的代码:(这里我将关闭资源、关闭连接的代码写在了一起,作为工具类使用,况且后面也会使用到)
package jdbc_1; import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.Driver;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties; public class JDBCUtils {
/*
* 获取数据库的连接
*/
public static Connection getConnection() throws Exception {
//1.读取配置文件
Properties pros = new Properties();
InputStream is = ClassLoader.getSystemClassLoader().getResourceAsStream("jdbc.properties");
pros.load(is); String driverClass = pros.getProperty("driverClass");
String url = pros.getProperty("url");
String user = pros.getProperty("user");
String password = pros.getProperty("password"); //2.使用反射获取Driver的实现类对象
Class clazz = Class.forName(driverClass);
Driver driver = (Driver) clazz.newInstance(); //3.利用DriverManager注册驱动
DriverManager.registerDriver(driver); //4.利用DriverManager获取连接
Connection conn = DriverManager.getConnection(url, user, password); return conn;
} /*
* 关闭资源操作
* conn是关闭的连接
* ps是要关闭的PreparedStatement,增删改查都用得到
* rs是要关闭的ResultSet,查询的操作才用得到
*/
public static void closeResource(Connection conn,Statement ps,ResultSet rs) {
try {
if(ps != null) {
ps.close();
}
}catch(SQLException e) {
e.printStackTrace();
} try {
if(conn != null) {
conn.close();
}
}catch(SQLException e) {
e.printStackTrace();
}
try {
if(rs != null) {
rs.close();
}
}catch (SQLException e) {
e.printStackTrace();
}
}
}
二、使用PreparedStatement实现增删改、查操作
注:这里我将增删改放在一起,查单独放在一边,因为查需要返回值,而增删改可以不需要返回值。
使用PreparedStatement的好处:解决了Statement的拼接、sql注入、无法操作Blob型数据的问题,还进行更高效的批量操作。
注意:以下的增删改查操作我都是放在JDBCUtils类里面的,作为工具使用
/*
*通用的增删改操作
*sql中的占位符的个数应该与可变形参的长度相同!
*/
public static void update(String sql,Object...args) {
//1.获取数据库连接
Connection conn = null;
//2.预编译sql语句,返回PreparedStatement的实例
PreparedStatement ps = null;
try {
conn = JDBCUtils.getConnection(); ps = conn.prepareStatement(sql); //3.填充占位符
for(int i = 0; i < args.length; i++) {
ps.setObject(i+1, args[i]);
//MySQL数据库中是从1开始计数的
} //4.执行
ps.execute();
} catch (Exception e) {
e.printStackTrace();
}finally {
//5.关闭资源,关闭连接
JDBCUtils.closeResource(conn, ps, null);
} }
接下来是通用的查询操作:
/*
* 针对于不同的表的通用的查询操作,查询一条或多条记录
* 第一个参数为需要从数据库表中得到的一条数据所创建的类
* 第二个参数为查询操作的sql语句
* 第三个参数用来填充占位符
*/
public static <T> List<T> getForList(Class<T> clazz,String sql,Object...args) {
Connection conn = null ;
PreparedStatement ps = null;
ResultSet rs = null;
try {
//1.获取连接
conn = JDBCUtils.getConnection();
//2.预编译的sql语句,获取PreparedStatement对象
ps = conn.prepareStatement(sql);
//3.填充占位符
for(int i = 0; i < args.length; i++) {
ps.setObject(i+1, args[i]);
}
//4.获取结果集
rs = ps.executeQuery();
//5.获取结果集元数据
ResultSetMetaData rsmd = rs.getMetaData();
//6.获取列数
int columnCount = rsmd.getColumnCount();
//7.创建集合对象
ArrayList<T> list = new ArrayList<T>();
while(rs.next()) {
//8.通过获取类的实例
T t = clazz.newInstance();
for(int i = 0 ; i < columnCount; i++) {
//9.获取列值
Object columnValue = rs.getObject(i+1); //10.获取列的别名
String columnLabel = rsmd.getColumnLabel(i+1); //11.给每个列的别名赋予对应的列值,使用反射
Field field = clazz.getDeclaredField(columnLabel);
field.setAccessible(true);
field.set(t, columnValue);
}
//12.将得到的对象添加进list中
list.add(t);
}
return list;
} catch (Exception e) {
e.printStackTrace();
}finally {
//13.关闭资源
JDBCUtils.closeResource(conn, ps, rs);
} return null;
}
三、关闭资源和关闭连接
代码在获取连接的代码中
以上就是本期的全部代码了,第二次写,在尽力美化排版。
欢迎大家阅后和我交流,当然学渣能力有限,代码和知识点可能有错误,也欢迎大家告诉我!
JDBC的学习笔记-手动实现的更多相关文章
- ArcGIS案例学习笔记-手动编辑擦除挖空挖除相减
ArcGIS案例学习笔记-手动编辑擦除挖空挖除相减 联系方式:谢老师,135-4855-4328,xiexiaokui#qq.com 目的:手动编辑擦除.挖空.挖除.相减 1. 选中内部要素 2. c ...
- JDBC MYSQL 学习笔记(一) JDBC 基本使用
1.JDBC简单介绍 SUN公司为了简化.统一对数据库的操作,定义了一套Java操作数据库的规范.称之为JDBC. JDBC全称为:Java Data Base Connectivity(java数据 ...
- JDBC编程学习笔记之数据库连接池的实现
在JDBC编程的时候,获取到一个数据库连接资源是很宝贵的,倘若数据库访问量超大,而数据库连接资源又没能得到及时的释放,就会导致系统的崩溃甚至宕机.造成的损失将会是巨大的.再看有了数据库连接池的JDBC ...
- jdbc 接口学习笔记
一.JDBC概念 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系型数据库提供统一访问,它由一组用Jav ...
- MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- JDBC 学习笔记(十一)—— JDBC 的事务支持
1. 事务 在关系型数据库中,有一个很重要的概念,叫做事务(Transaction).它具有 ACID 四个特性: A(Atomicity):原子性,一个事务是一个不可分割的工作单位,事务中包括的诸操 ...
- JDBC学习笔记二
JDBC学习笔记二 4.execute()方法执行SQL语句 execute几乎可以执行任何SQL语句,当execute执行过SQL语句之后会返回一个布尔类型的值,代表是否返回了ResultSet对象 ...
- JDBC学习笔记一
JDBC学习笔记一 JDBC全称 Java Database Connectivity,即数据库连接,它是一种可以执行SQL语句的Java API. ODBC全称 Open Database Conn ...
- [原创]java WEB学习笔记109:Spring学习---spring对JDBC的支持:使用 JdbcTemplate 查询数据库,简化 JDBC 模板查询,在 JDBC 模板中使用具名参数两种实现
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
随机推荐
- 《提升能力,涨薪可待》-Java并发之AQS全面详解
欢迎关注公众号[Ccww笔记],原创技术文章第一时间推出 一.AQS是什么?有什么用? AQS全称AbstractQueuedSynchronizer,即抽象的队列同步器,是一种用来构建锁和同步器的框 ...
- Hive性能优化(全面)
1.介绍 首先,我们来看看Hadoop的计算框架特性,在此特性下会衍生哪些问题? 数据量大不是问题,数据倾斜是个问题. jobs数比较多的作业运行效率相对比较低,比如即使有几百行的表,如果多次关联多次 ...
- 快速部署 Spring PetClinic 到函数计算平台
简介 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute):函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传.函数计算准 ...
- 转载:通过监控Nginx日志来实时屏蔽高频恶意访问的IP
通过监控Nginx日志来实时屏蔽高频恶意访问的IP 目前在我的VPS上主要通过两种方式来限制ip的访问次数. 通过Nginx的limit_req配置来限制同一ip在一分钟内的访问次数 通过Ngin ...
- tomcat日志传参乱码问题
问题: 在centos系统下,tomcat8.0.36控制台日志打印会出现中文乱码. 解决方案: 在catalina.sh里加上 JAVA_OPTS="-Dfile.en ...
- iOS定位权限请求时易犯的错误小结
起因 用户群反馈app可能请求了不合适的定位权限:始终定位. 看到这个截图,根据经验判断可能是后台定位功能导致可能不得不请求始终定位权限.再加上之前提交审核时,苹果要求在plist文件中新增NSLoc ...
- Linux 学习笔记 2 Centos 安装与网络的配置以及VI编辑器的使用
前言 当然,还是觉得Centos 在众多的Linux 发行版中,还是很有地位的,好多的服务器大多沿用的都是一代的Centos 因为它开源(这是废话)而且稳定,这才是服务器沿用的最重要的一项指标. 镜像 ...
- 「Luogu P4987」回文项链 解题报告
题面 求环中的长度为k(k为奇数)且回文中心不同的回文串个数 思路: 刚学manacher算法,就送上一道模板题,此题注重对manacher算法的理解 Manacher,但是不用插入其他符号,因为k是 ...
- 线程池:ThreadPoolExecutor的使用
ThreadPoolExecutor配置 一.ThreadPoolExcutor为一些Executor提供了基本的实现,这些Executor是由Executors中的工厂 newCahceThread ...
- Class 'org.apache.tomcat.jdbc.pool.DataSource' not found
把项目移动到新的运行环境时,明明包都导入了,项目也放进tomcat里面了,但是还会找不到该类 解决方法:项目右键选择底下的Properties ->project facets ->jav ...