JDBC连接和DBUtils的使用详解

     JDBC(Java Data Base Conntectivity  java数据库连接)是一种用于执行SQL语句的JAVA API,可以为多种关系数据库提供统一访问,它由一组用java语言编写的类和接口组成.是java访问数据的标准规范.    JDBC提供一种标准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序.    JDBC需要连接驱动(JDBC接口的实现类),驱动是两个设备要进行通信,满足一定数据格式,数据格式有设备提供商规定,设备提供商为设备提供驱动软件,通过软件可以与设备进行通信.

JDBC是接口,驱动是接口的实现,没有驱动将无法完成数据库连接,从不能操作数据库!每个数据库厂商都需要自己提供自己的驱动,用来连接自己公司的数据库,也就是说驱动一般都有数据厂商提供.(JDBC就是接口,好比我们电脑生产定义了外接鼠标,键盘,硬盘连接的接口,usb的规格,连接方法,如果你的设备想和电脑连接,那么连接的头一定要遵循我的usb规范且连接口要厂商自己制造.这样做的好处任何厂商只要按照usb规范生产就能连接到电脑上使用.这就是面向接口开发的思想)

JDBC开发的步骤

1.注册驱动: 告诉jvm使用的是哪一个数据的驱动

2.获取连接: 使用jdbc中的类,完成对mysql的连接

3.获取语句执行者: 通过连接对象获取sql语句的执行者对象

4.执行sql语句:使用执行者对象,执行操作数据sql语句,获取sql语句执行后的结果

5.处理结果: 拿到返回的结果想干的什么

6.释放资源: 释放执行者, 连接对象

注册驱动前项目中要到mysql驱动.也就是JDBC接口的实现类打成的jar包


DBUtils

如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC开发,本案例我们讲采用apache commons组件一个成员:DBUtils。

DBUtils就是JDBC的简化开发工具包。需要项目导入commons-dbutils-1.6.jar才能够正常使用DBUtils工具。

  1. 概述

DBUtils是java编程中的数据库操作实用工具,小巧简单实用。

DBUtils封装了对JDBC的操作,简化了JDBC操作,可以少写代码。

Dbutils三个核心功能介绍

  • QueryRunner中提供对sql语句操作的API.
  • ResultSetHandler接口,用于定义select操作后,怎样封装结果集.
  • DbUtils类,它就是一个工具类,定义了关闭资源与事务处理的方法
    1. QueryRunner核心类


    • update(Connection conn, String sql, Object... params) ,用来完成表数据的增加、删除、更新操作
    • query(Connection conn, String sql, ResultSetHandler rsh, Object... params) ,用来完成表数据的查询操作
    1. QueryRunner实现添加、更新、删除操作
    • update(Connection conn, String sql, Object... params) ,用来完成表数据的增加、删除、更新操作

    添加

    public void insert(){

    try {

    //获取一个用来执行SQL语句的对象   QueryRunner

    QueryRunner qr = new QueryRunner();

    String sql = "INSERT INTO person(,pname,age) VALUES(?,?)";

    Object[] params = {’二哈’, 18};

    Connection conn = JDBCUtils.getConnection();

    int line = qr.update(conn,sql,params);// 用来完成表数据的增加、删除、更新操作

    //结果集处理

    System.out.println("line = " + line);

    catch (SQLException e) {

    throw new RuntimeException(e);

    }

    }


    更新

    public void update(){

    try {

    //创建一个QueryRunner对象,用来完成SQL语句的执行

    QueryRunner qr = new QueryRunner();

    //执行SQL语句

    String sql = "UPDATE person SET age = age+2 WHERE name=?";

    Object[] params = {二哈"};

    Connection conn = JDBCUtils.getConnection();

    int line = qr.update(connsqlparams);

    //结果集的处理

    System.out.println("line="+line);

    catch (SQLException e) {

    throw new RuntimeException(e);

    }

    }

    删除

    public void delete(){

    try {

    //创建一个QueryRunner对象,用来完成SQL语句的执行

    QueryRunner qr = new QueryRunner();

    //执行SQL语句

    String sql = "DELETE FROM person WHERE pname = ?";

    Object[] params = {"妖"};

    Connection conn = JDBCUtils.getConnection();

    int line = qr.update(connsqlparams);

    //结果集的处理

    System.out.println("line="+line);

    catch (SQLException e) {

    throw new RuntimeException(e);

    }

    }


  1. ArrayHandlerArrayListHandler查询
  • ArrayHandler:将结果集中的第一条记录封装到一个Object[]数组中,数组中的每一个元素就是这条记录中的每一个字段的值

public class ArrayHandlerDemo {

@Test

public void method(){

try {

//获取QueryRunner对象

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT * FROM person";

Object[] params = {};

Connection conn = JDBCUtils.getConnection();

Object[] objArray = qr.query(connsqlnew ArrayHandler(), params);

//结果集的处理

System.out.println( Arrays.toString(objArray) );

conn.close();

catch (SQLException e) {

e.printStackTrace();

}

}

}


  • ArrayListHandler:将结果集中的每一条记录都封装到一个Object[]数组中,将这些数组在封装到List集合中。

public class ArrayListHandlerDemo {

@Test

public void method(){

try {

//获取QueryRunner对象

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT * FROM pid WHERE age>?";

Object[] params = {20};

Connection conn = JDBCUtils.getConnection();

 List list = qr.query(connsqlnew ArrayListHandler(), params);

//结果集的处理

 for (Object[] objArray : list) {

System.out.println(  Arrays.toString(objArray) );

}

conn.close();

catch (SQLException e) {

e.printStackTrace();

}

}

}


  1. JavaBean

JavaBean就是一个类,在开发中常用封装数据。具有如下特性

  1. 需要实现接口:java.io.Serializable ,通常实现接口这步骤省略了,不会影响程序。
  2. 提供私有字段:private 类型 字段名;
  3. 提供getter/setter方法:
  4. 提供无参构造

public class Person  implements Serializable{

private int pid;

private String pname;

private int age;

public Person() {

}

public int getPid() {

return pid;

}

public void setPid(int pid) {

this.pid = pid;

}

public String getPname() {

return pname;

}

public void setPname(String pname) {

this.pname = pname;

}

public int getAge() {

return age;

}

public void setAge(int age) {

this.age = age;

}

}

  1. BeanHandlerBeanListHandler查询
  • BeanHandler :将结果集中第一条记录封装到一个指定的javaBean中。

public class BeanHandlerDemo {

@Test

public void method(){

try{

//获取QueryRunner 

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT * FROM person WHERE pid=?";

Object[] params = {1};

Connection conn = JDBCUtils.getConnection();

Perosn p = qr.query(connsqlnew BeanHandler(Person.class), params);

//结果集处理

System.out.println(zw);

conn.close();

catch(SQLException e){

throw new RuntimeException(e);

}

}

}

  • BeanListHandler :将结果集中每一条记录封装到指定的javaBean中,将这些javaBean在封装到List集合中

public class BeanListHandlerDemo {

@Test

public void method(){

try{

//获取QueryRunner 

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT * FROM zhangwu WHERE money>?";

Object[] params = {2000};

Connection conn = JDBCUtils.getConnection();

Listlist=qr.query(conn,sql,new BeanListHandler(Person.class), params);

//结果集处理

for (Person zw : list) {

System.out.println(zw);

}

conn.close();

catch(SQLException e){

throw new RuntimeException(e);

}

}

}

  1. ColumnListHandlerScalarHandler查询
  • ColumnListHandler:将结果集中指定的列的字段值,封装到一个List集合中

public class ColumnListHandlerDemo {

@Test

public void method(){

try {

//获取QueryRunner对象

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT name FROM person WHERE age>?";

Object[] params = {12};

Connection conn = JDBCUtils.getConnection();

List list = qr.query(connsqlnew ColumnListHandler(), params); 

//结果集的处理

for (String str : list) {

System.out.println(str);

}


conn.close();

catch (SQLException e) {

e.printStackTrace();

}

}

}



  • ScalarHandler:它是用于单数据。例如select count(*) from 表操作。

public class ScalarHandlerDemo {

@Test

public void method(){

try {

//获取QueryRunner对象

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT MAX(age) FROM person";

Object[] params = {};

Connection conn = JDBCUtils.getConnection();

Integer max = qr.query(connsqlnew ScalarHandler(), params);

//结果集的处理

System.out.println("max=" + max);

conn.close();

catch (SQLException e) {

e.printStackTrace();

}

}

}



你可能感兴趣的:(基础技术,常用技术)