JDBC基础应用

JDBC是Java连接数据库的一套接口,可以让我们方便的在Java中使用数据库。掌握JDBC的使用是Java开发的基本功。

预备工作

  • 导入jar包。根据使用的数据库软件导入相应的jar包。idea相应设置中添加。

代码部分(MySQL为例)

//	1.加载数据库驱动
Class.forName("com.mysql.jdbc.Driver");
// 2.从驱动管理器获取JDBC连接对象
Connection conn = DriverManager.getConnection("数据库连接地址","帐号","密码");
/********************************************************************
* 连接地址基本格式--> 主协议:子协议://ip地址:端口号/数据库名称 *
* mysql的连接地址--> jdbc:mysql://localhost:3306/mydatabase *
* oracle的连接地址--> jdbc:oracle:thin:@localhost:1521:ORCL *
********************************************************************/
// 3.从连接对象获取SQL执行环境
Statement state = conn.createStatement();
// 4.执行SQL语句
state.execute("SQL语句");
// 5.释放资源
state.close();
conn.close();
  • JDBC中的方法说明
Statement
//此方法将会执行SQL语句,如果是查询语句返回ture否则返回false
boolean execute(String sql);
//此方法执行DML和DDL语句,int返回值代表影响行数(准确的说,是筛选条件选中的行数)
int executeUpdate(String sql);
//执行查询语句,查询结果以集合形式返回
ResultSet executeQuery(String sql); /*ResultSet的行为相当于带头节点的链表,最开始指针指向头节点,而不是第一行数据*/
ResultSet
//调用一次,指针向下一行移动,如果下一行不存在函数返回false
boolean next();
//其他移动方式
boolean privious();
boolean absolute(int row);
boolean beforeFirst();
boolean afterLast();
//获取行字段,XXX是字段的类型
XXX getXXX(String columnLabel); //columnLabel是字段名
XXX getXXX(int columnIndex); //columnIndex是字段索引,从1开始

SQL参数问题--注入问题

在实际项目中,SQL的参数一定是以变量形式传入,将变量放入SQL语句中最直接的方法就是字符串拼接。

public void setName(String id,String newName){
...
state.executeUpdate("update students set s_name='" + newName + "' where s_id='" + id + "'");
}

<!>请注意

-- 上面的代码看上去没有任何问题,比如传入参数23和"张飞",就能把id为23的同学名字改为"张飞"
-- 对应生成的SQL语句为
update students set name='张飞' where sid='23' -- 当id == "1' or '1'='1"时,拼接的语句会是什么?
update students set name='张飞' where sid='1' or '1'='1'
-- 这句SQL的顾虑条件变成了恒为true的表达式!执行这句SQL将会把所有学生名字改为'张飞'
-- 这不是我们想要的结果,拼接后改变了原本的语义。这就是注入问题

预编译解决SQL注入问题

//参数用?代替
PreparedStatement state = conn.prepareStatement("update students set name=? where sid=?");
//设置参数,参数索引从1开始
state.setString(1,"张飞");
state.setString(2,"1' or '1'='1");
//预编译的SQL不会被改变语义,"1' or '1'='1"仅作为参数被传递
state.execute();

使用事务

当我们遇到类似于转账业务时,需要使用业务保障转账的安全性。资金从一个账户转移到另一个账户,两个账户数据的改变必须同时成功或失败,否则可能出现资金凭空消失或凭空增加的情况!

//conn是获得的数据库连接对象
conn.setAutoCommit(false); //开启事务
conn.rollback(); //回滚事务
conn.commit(); //提交事务 /*在try-catch块中,出现异常时应回滚事务,并在finally中释放资源*/

JDBC进阶--DAO设计模式

DAO(Data Access Object)是数据访问接口。DAO模式就是将数据库操作于业务逻辑解耦合,提高程序的扩展性。

典型的DAO实现具备四个部件

  • DAO接口。业务逻辑所面向的接口,与具体实现无关。
  • DAO接口的实现类,定义了具体与如何操作数据库。
  • 数据传递对象。业务代码从DAO拿到的数据不应该是ResultSet对象,而是根据业务重新封装的合适对象。
  • DAO的工厂类。业务从工厂获得DAO实例,实现了业务与数据库操作的进一步解耦合。

JDBC进阶--连接池

连接池和多线程中的线程池相似。使用了动态代理和装饰者模式,使得极大减少了数据库的重复连接,提高了数据库使用性能。此外连接池顺便把类加载、连接地址登录的步骤和连接参数设定封装起来,参数从代码中分离到properties文件当中。

知识点补充:使用 .properties 文件作为配置文件

properties文件是以键值对文本方式存储数据。Java中有对应的Properties类专门用于读取properties文件的内容。Properties是Map集合的一个具体实现。具体操作方式如下:

//将配置文件druid.properties放到src文件夹下
public class Demo{
public static void main(String[] args) throws Exception {
Properties ppt = new Properties();
//将properties文件作为输入流,通过.load()方法从流中将数据读入集合中。
InputStream is = Demo.class.getClassLoader().getResourceAsStream("druid.properties");
ppt.load(is);
}
}

连接池使用

  • 准备工作,导入jar包。

  • 将 properties配置文件 放到src文件夹下

  • 获得连接池对象

//读取druid.properties文件步骤见上面代码。最终得到Properties对象:ppt

//获取连接池和配置参数一步完成(代码以Druid池为例,若使用其他连接池,此处工厂类要做相应的改变)
DataSource dataSource = DruidDataSourceFactory.createDataSource(ppt);
  • 使用连接池
//	1.从连接池获取数据库连接
Connection conn = dataSource.getConnection();
// 2.使用使用步骤与前面完全相同,最后一样要释放连接资源
Statement state = conn.createStatement();
state.execute("insert into person values('zhangsan','lisi')");
state.close();
conn.close(); /*从池中获取的连接关闭只是把连接放回池中,实际的连接是否关闭由连接池动态管理*/

总结

  • JDBC是什么?
  • JDBC使用步骤?加载驱动>>获取连接>>获取SQL执行环境>>执行SQL>>处理执行结果>>释放资源
  • 解决注入问题?预编译的使用...
  • DAO设计模式?解耦合、典型四个DAO部件
  • properties配置文件的使用
  • 连接池?原理、配置、使用、区别、优点

JDBC概要的更多相关文章

  1. Java JDBC概要总结一(基本操作和SQL注入问题)

    JDBC定义: JDBC(Java DataBase Connectivity,java数据库连接)是一种用于执行SQL语句的Java API.JDBC是Java访问数据库的标准规范,可以为不同的关系 ...

  2. 程序员与数据库打交道的JDBC知识概要

    1.JDBC全称:Java database connectivity,Java数据库连接. (1)           JDBC是一种用于执行SQL语句的Java API,为多种关系数据库提供多种统 ...

  3. 不知道数据库中表的列类型的前提下,使用JDBC正确的取出数据

    概要: 使用jdbc 如果在不知道表结构的情况下,如何读出表信息? 使用ResultSetMetaData; 然后使用getColumnType 获取column 类型 使用getColumnName ...

  4. jdbc-connect-oracle12c-pdb/cdb(jdbc连接oracle12c的pdb和cdb)

      1       本文简介: 通过特意引发问题,聚焦问题,解决问题,并循序渐进 最后总结jdbc连接oracle12c中cdb和pdb的条件. 软件环境:Redhat7.1+orcacle12c 2 ...

  5. JDBC batch批处理Statement executeBatch 具体解释

    JDBC提供了数据库batch处理的能力,在数据大批量操作(新增.删除等)的情况下能够大幅度提升系统的性能.我曾经接触的一个项目,在没有採用batch处理时,删除5万条数据大概要半个小时左右,后来对系 ...

  6. JDBC batch批量Statement executeBatch 详细解释

    JDBC提供了数据库batch处理的能力,在数据大批量操作(新增.删除等)的情况下能够大幅度提升系统的性能.我曾经接触的一个项目,在没有採用batch处理时,删除5万条数据大概要半个小时左右,后来对系 ...

  7. Hibernate进化史-------Hibernate概要

    一个.Hibernate概要 什么是Hibernate呢?首先,Hibernate是数据持久层的一个轻量级框架.实现了ORMapping原理(Object Relational Mapping). 在 ...

  8. jdbc学习笔记

    知识概要: 1.JDBC简介 2.JDBC的编码步骤 3.JDBC中常用接口或类详解 4.JDBC中释放资源 5.JDBC进行CRUD 1.JDBC简介 JDBC:Java DataBase Conn ...

  9. JavaWeb核心技术学习 - 1.从JDBC说起

    作者:java1to3链接:http://www.cnblogs.com/java1to3/著作权归作者所有.未经作者本人同意,禁止一切转载.商业或非商业转载请联系作者获得授权并请注明出处. ・JDB ...

随机推荐

  1. Codeforces Gym-102219 2019 ICPC Malaysia National E. Optimal Slots(01背包+输出路径)

    题意:给你一个体积为\(T\)的背包,有\(n\)个物品,每个物品的价值和体积都是是\(a_{i}\),求放哪几个物品使得总价值最大,输出它们,并且输出价值的最大值. 题解:其实就是一个01背包输出路 ...

  2. Codeforces Round #651 (Div. 2) B. GCD Compression (构造)

    题意:有一个长度为\(2n\)的数组,删去两个元素,用剩下的元素每两两相加构造一个新数组,使得新数组所有元素的\(gcd\ne 1\).输出相加时两个数在原数组的位置. 题解:我们按照新数组所有元素均 ...

  3. 设计模式(二十一)——解释器模式(Spring 框架中SpelExpressionParser源码分析)

    1 四则运算问题 通过解释器模式来实现四则运算,如计算 a+b-c 的值,具体要求 1) 先输入表达式的形式,比如 a+b+c-d+e,  要求表达式的字母不能重复 2) 在分别输入 a ,b, c, ...

  4. BIM轻量化——浏览器展示

    此篇博客仅为记录,记录钻研过程的零碎思路.         之前考虑过很多可能性,对rvt文件转换格式:.obj.JSON..gltf等等.这些可能性前人一般都尝试过,而且也都做出来了东西.     ...

  5. Scanner用户交互

    Scanner用户交互 Scanner对象 引入语法: Scanner scanner=new Scanner(System.in);(固定的) 小写scanner为定义的名称 scanner.clo ...

  6. Nginx location相关配置说明

    Nginx location相关配置说明       基于不同的IP.不同的端口以及不用得域名实现不同的虚拟主机,依赖于核心模块ngx_http_core_module实现. 新建PC web站点 [ ...

  7. Linux 驱动框架---dm9000分析

    前面学习了下Linux下的网络设备驱动程序的框架inux 驱动框架---net驱动框架,感觉知道了一个机器的大致结构还是不太清楚具体的细节处是怎么处理的,所以今天就来以dm9000这个网上教程最多的驱 ...

  8. Linux 驱动框架---驱动中的并发

    并发指多个执行单元被同时.并行的执行,而并发执行的单元对共享资源的访问就容易导致竟态.并发产生的情况分为抢占和并行(多核)和硬抢占(中断).Linux为解决这一问题增加了一系列的接口来解决并发导致的竟 ...

  9. sentry can not delete release bug

    sentry can not delete release bug bug $ ./node_modules/@sentry/cli/bin/sentry-cli releases list $ ./ ...

  10. markdown & git diff

    markdown & git diff "dependencies": { "core-js": "3.6.5", "el ...