JavaWeb开发之JDBC知识总结
Posted nuist__NJUPT
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaWeb开发之JDBC知识总结相关的知识,希望对你有一定的参考价值。
JDBC(Java数据库连接),是一种用于执行SQL语句的Java的API,它由一组Java语言编写的类和接口组成,可以为多种关系型数据库提供统一访问。没有JDBC的时候,如果现在要开发一套系统,使用Java连接mysql数据库,那么这时候Java程序员需要了解MySQL驱动API,如果使用Java连接Oracle数据库,那么这个时候Java程序员需要了解Oracle数据库驱动API。SUN公司提供一套统一的规范(接口)。然后各个数据库生产商提供这套接口的实现。这套接口规范就是JDBC的规范。
目录
5、JDBC的CRUD操作之PreparedStatement
10、DBUtils使用之ResultSetHandler实现类
1、JDBC入门程序
首先创建数据库和表,并参插入数据,导入连接mysql的jar包,然后编写程序实现:加载驱动,获得连接,执行基本查询操作,释放资源。
创建数据库和表,插入记录代码如下:
create database if not exists web_test1;
use web_test1;
create table if not exists user(
id int primary key auto_increment,
username varchar(20),
password varchar(20),
nickname varchar(20),
age int
);
insert into user values (null,'aaa','123','小丽',34);
insert into user values (null,'bbb','123','大王',32);
insert into user values (null,'ccc','123','小明',28);
insert into user values (null,'ddd','123','大黄',21);
jdbc连接数据库,并执行查询语句:
import java.sql.*;
public class JDBCDemo01
public static void main(String[] args) throws ClassNotFoundException, SQLException
test() ;
private static void test() throws ClassNotFoundException, SQLException
// 1.加载驱动
Class.forName("com.mysql.jdbc.Driver");
// 2.获得连接
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/web_test1", "root", "123456");
Statement statement = conn.createStatement();
// 3.2编写SQL语句:
String sql = "select * from user";
// 3.3执行SQL:
ResultSet rs = statement.executeQuery(sql);
// 3.4遍历结果集:
while(rs.next())
System.out.print(rs.getInt("id")+" ");
System.out.print(rs.getString("username")+" ");
System.out.print(rs.getString("password")+" ");
System.out.print(rs.getString("nickname")+" ");
System.out.print(rs.getInt("age"));
System.out.println();
// 4.释放资源
rs.close();
statement.close();
conn.close();
注意:上述包含了JDBC的几个API
1)DriverManager:驱动管理类,用于获得连接。
2)Connection:与数据库连接的对象,用于创建执行SQL语句的对象,主要包括下面三个:
- Statement :执行SQL
- CallableStatement :执行数据库中存储过程
- PreparedStatement :执行SQL.对SQL进行预处理。解决SQL注入漏洞。
另外Connection也可以进行事务管理。
3)Statement对象主要用于执行SQL语句,也可以执行批处理,具体如下:
- boolean execute(String sql): 执行查询,修改,添加,删除的SQL语句。
- ResultSet executeQuery(String sql):执行查询(执行select语句)。
- int executeUpate(String sql): 执行修改,添加,删除的SQL语句。
4)ResultSet是结果集,一般使用查询语句查到的结果都是一个结果集,对结果集进行遍历使用next()方法。
2、JDBC的CRUD操作
使用executeQuery(String sql)方法执行增删改的操作会返回被影响的记录行,使用这个executeUpate(String sql)方法执行查询操作会返回一个ResultSet结果集。最后需要进行资源的释放。
import java.sql.*;
public class JDBCDemo01
public static void main(String[] args)
test() ;
private static void test()
Connection conn = null ;
Statement statement = null ;
ResultSet rs = null ;
try
// 1.加载驱动
Class.forName("com.mysql.jdbc.Driver");
// 2.获得连接
conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/web_test1", "root", "123456");
statement = conn.createStatement();
// 3.2编写SQL语句:
String sql1 = "insert into user values (null,'eee','123','阿黄',21)";
String sql2 = "update user set password='abc',nickname='旺财' where id = 5";
String sql3 = "delete from user where id = 5";
String sql = "select * from user";
// 3.3执行SQL:
int num1 = statement.executeUpdate(sql1);
if (num1 > 0)
System.out.println("插入成功");
int num2 = statement.executeUpdate(sql2);
if (num2 > 0)
System.out.println("修改成功");
int num3 = statement.executeUpdate(sql3);
if (num3 > 0)
System.out.println("删除成功");
rs = statement.executeQuery(sql);
// 3.4遍历结果集:
while (rs.next())
System.out.print(rs.getInt("id") + " ");
System.out.print(rs.getString("username") + " ");
System.out.print(rs.getString("password") + " ");
System.out.print(rs.getString("nickname") + " ");
System.out.print(rs.getInt("age"));
System.out.println();
catch (Exception e)
e.printStackTrace();
finally
if(rs != null)
try
rs.close();
catch (SQLException e)
e.printStackTrace();
rs = null;
if(statement != null)
try
statement.close();
catch (SQLException e)
e.printStackTrace();
statement = null;
if(conn != null)
try
conn.close();
catch (SQLException e)
e.printStackTrace();
conn = null;
3、JDBC之工具类的抽取
因为传统JDBC的开发,注册驱动,获得连接,释放资源这些代码都是重复编写的。所以可以将重复的代码提取到一个类中来完成。
首先在src目录下创建配置文件db.properties,配置Mysql,后面在工具类中直接加载就可以。
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/web_test1
username=root
password=123456
编写工具类:
import java.io.FileInputStream;
import java.io.IOException;
import java.sql.*;
import java.util.Properties;
public class JDBCUtils
private static String driverClassName;
private static String url;
private static String username;
private static String password;
static
Properties properties = new Properties() ;
try
properties.load(new FileInputStream("src/db.properties"));
catch (IOException e)
e.printStackTrace();
driverClassName=properties.getProperty("driverClassName");
url=properties.getProperty("url");
username=properties.getProperty("username");
password=properties.getProperty("password");
/**
* 注册驱动的方法
*/
public static void loadDriver()
try
Class.forName(driverClassName);
catch (ClassNotFoundException e)
e.printStackTrace();
/**
* 获得连接的方法
*/
public static Connection getConnection()
Connection conn = null;
try
// 将驱动一并注册:
loadDriver();
// 获得连接
conn = DriverManager.getConnection(url,username, password);
catch(Exception e)
e.printStackTrace();
return conn;
/**
* 释放资源的方法
*/
public static void release(Statement stmt, Connection conn)
if(stmt != null)
try
stmt.close();
catch (SQLException e)
e.printStackTrace();
stmt = null;
if(conn != null)
try
conn.close();
catch (SQLException e)
e.printStackTrace();
conn = null;
public static void release(ResultSet rs, Statement stmt, Connection conn)
// 资源释放:
if(rs != null)
try
rs.close();
catch (SQLException e)
e.printStackTrace();
rs = null;
if(stmt != null)
try
stmt.close();
catch (SQLException e)
e.printStackTrace();
stmt = null;
if(conn != null)
try
conn.close();
catch (SQLException e)
e.printStackTrace();
conn = null;
调用工具类进行测试:
import utils.JDBCUtils;
import java.sql.*;
public class JDBCDemo01
public static void main(String[] args)
test() ;
private static void test()
Connection conn = null ;
Statement statement = null ;
ResultSet rs = null ;
try
conn = JDBCUtils.getConnection() ;
statement = conn.createStatement();
// 3.2编写SQL语句:
String sql = "select * from user";
// 3.3执行SQL
rs = statement.executeQuery(sql);
// 3.4遍历结果集:
while (rs.next())
System.out.print(rs.getInt("id") + " ");
System.out.print(rs.getString("username") + " ");
System.out.print(rs.getString("password") + " ");
System.out.print(rs.getString("nickname") + " ");
System.out.print(rs.getInt("age"));
System.out.println();
catch (Exception e)
e.printStackTrace();
finally
JDBCUtils.release(rs,statement,conn);
4、JDBC的SQL注入问题及解决
在早期互联网上SQL注入漏洞普遍存在。有一个网站,用户需要进行注册,用户注册以后根据用户名和密码完成登录。假设现在用户名已经被其他人知道了,但是其他人不知道你的密码,也可以登录到网站上进行相应的操作。
- 输入用户名
- aaa’ or ‘1=1 密码随意
- aaa’ -- 密码随意
使用的用户名和密码中带有SQL语句的关键字,使得不需要验证密码即实现登录的功能。
采用PreparedStatement对象解决SQL注入漏洞。这个对象将SQL预先进行编译,使用?作为占位符。?所代表内容是SQL所固定。再次传入变量(包含SQL的关键字)。这个时候也不会识别这些关键字,就可以避免SQL注入为问题发生。
5、JDBC的CRUD操作之PreparedStatement
使用PreparedStatement可以进行预编译SQL,后面不会识别输入的关键子,防止出现SQL注入问题,整个过程如下:首先连接数据库,编写SQL语句,预编译SQL,设置参数,并执行相应的DML操作,最后释放资源。
import utils.JDBCUtils;
import java.sql.*;
public class JDBCDemo01
public static void main(String[] args)
test() ;
private static void test()
Connection conn = null ;
PreparedStatement statement = null ;
ResultSet rs = null ;
try
conn = JDBCUtils.getConnection() ;
String sql1 = "insert into user values (null,?,?,?,?)";
String sql2 = "update user set username = ?,password =?,nickname=?,age = ? where id = ?";
String sql3 = "delete from user where id = ?";
String sql = "select * from user";
// 插入操作
statement = conn.prepareStatement(sql1);
// 设置参数:
statement.setString(1, "eee");
statement.setString(2, "abc");
statement.setString(3, "旺财");
statement.setInt(4, 32);
// 执行SQL
int num = statement.executeUpdate();
if(num > 0)
System.out.println("插入成功!");
// 修改操作
statement = conn.prepareStatement(sql2);
// 设置参数:
statement.setString(1, "abc");
statement.setString(2, "1234");
statement.setString(3, "旺旺");
statement.setInt(4, 23);
statement.setInt(5, 6);
// 执行SQL:
num = statement.executeUpdate();
if(num > 0)
System.out.println("修改成功!");
//删除操作
statement = conn.prepareStatement(sql3);
statement.setInt(1,4);
num = statement.executeUpdate();
if(num > 0)
System.out.println("删除成功!");
//查询操作
statement = conn.prepareStatement(sql);
rs = statement.executeQuery(sql);
// 3.4遍历结果集:
while (rs.next())
System.out.print(rs.getInt("id") + " ");
System.out.print(rs.getString("username") + " ");
System.out.print(rs.getString("password") + " ");
System.out.print(rs.getString("nickname") + " ");
System.out.print(rs.getInt("age"));
System.out.println();
catch (Exception e)
e.printStackTrace();
finally
JDBCUtils.release(rs,statement,conn);
6、JBDC的事务管理
事务指的是逻辑上的一组操作,组成这组操作各个逻辑单元要么全都成功,要么全都失败。进行事务管理之前,我们先进行数据准备,创建一个数据库和表,并插入一些数据,具体如下:
create database if not exists web_test1;
use web_test1;
create table account(
id int primary key auto_increment,
name varchar(20),
money double
);
insert into account values (null,'aaa',10000);
insert into account values (null,'bbb',10000);
insert into account values (null,'ccc',10000);
事务管理常用的API包括开启事务,提交事务,事务回滚,具体如下:
通过下面的的转账案例学习JDBC的事务管理,首先开启事务,在整个事务执行过程中没有发生异常则提交事务,否则回滚事务到最初的状态。
import utils.JDBCUtils;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class JDBCDemo02
public static void main(String[] args)
demo1() ;
public static void demo1()
Connection conn = null;
PreparedStatement pstmt = null;
try
/**
* 完成转账代码:
* * 扣除某个账号的钱
* * 给另外一个账号加钱
*/
// 获得连接:
conn = JDBCUtils.getConnection();
// 开启事务
conn.setAutoCommit(false);
// 编写SQL语句:
String sql = "update account set money = money + ? where name = ?";
// 预编译SQL:
pstmt = conn.prepareStatement(sql);
// 设置参数:
// 用aaa账号给bbb账号转1000元
pstmt.setDouble(1, -1000);
pstmt.setString(2, "aaa");
// 执行SQL:扣除aaa账号1000元
pstmt.executeUpdate();
//int i = 1 / 0;
// 给bbb账号加1000
pstmt.setDouble(1, 1000);
pstmt.setString(2, "bbb");
pstmt.executeUpdate();
// 提交事务:
conn.commit();
catch (Exception e)
// 回滚事务:
try
conn.rollback();
catch (SQLException e1)
e1.printStackTrace();
e.printStackTrace();
finally
JDBCUtils.release(pstmt, conn);
7、连接池之Druid与C3P0
连接池是装有连接的容器,使用连接的话,可以从连接池中进行获取,使用完成之后将连接归还给连接池。连接对象创建和销毁是需要耗费时间的,在服务器初始化的时候就初始化一些连接。把这些连接放入到内存中,使用的时候可以从内存中获取,使用完成之后将连接放入连接池中。从内存中获取和归还的效率要远远高于创建和销毁的效率。(提升性能)。
我们先来看第一个连接池,Druid阿里旗下开源连接池产品,使用非常简单,可以与Spring框架进行快速整合。
首先需要引入连接数据库的jar包和连接池的jar包,具体如下:
下面从连接池中直接获得连接,编写SQL语句,预编译,然后进行查询操作,最后释放资源。
import com.alibaba.druid.pool.DruidDataSource;
import utils.JDBCUtils;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class JDBCDemo02
public static void main(String[] args)
demo1() ;
public static void demo1()
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try
// 使用连接池:
DruidDataSource dataSource = new DruidDataSource();
// 手动设置数据库连接的参数:
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql:///web_test1");
dataSource.setUsername("root");
dataSource.setPassword("123456");
// 获得连接:
// conn = JDBCUtils.getConnection();
conn = dataSource.getConnection();
// 编写SQL:
String sql = "select * from account";
// 预编译SQL:
pstmt = conn.prepareStatement(sql);
// 设置参数:
// 执行SQL:
rs = pstmt.executeQuery();
while(rs.next())
System.out.println(rs.getInt("id")+" "+rs.getString("name")+" "+rs.getDouble("money"));
catch(Exception e)
e.printStackTrace();
finally
JDBCUtils.release(rs, pstmt, conn);
上面的连接池案例是使用手动配置MySQL参数的方法,我们将配置参数卸载.properties文件中,通过加载配置文件的方式获取配置参数,具体如下:
import com.alibaba.druid.pool.DruidDataSourceFactory;
import utils.JDBCUtils;
import javax.sql.DataSource;
import java.io.FileInputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Properties;
public class JDBCDemo02
public static void main(String[] args)
demo1() ;
public static void demo1()
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try
// 配置文件的方式获取配置参数
Properties properties = new Properties();
properties.load(new FileInputStream("src/db.properties"));
DataSource dataSource = DruidDataSourceFactory.createDataSource(properties);
// 获得连接:
conn = dataSource.getConnection();
// 编写SQL:
String sql = "select * from account";
// 预编译SQL:
pstmt = conn.prepareStatement(sql);
// 设置参数:
// 执行SQL:
rs = pstmt.executeQuery();
while(rs.next())
System.out.println(rs.getInt("id")+" "+rs.getString("name")+" "+rs.getDouble("money"));
catch(Exception e)
e.printStackTrace();
finally
JDBCUtils.release(rs, pstmt, conn);
我们下面学习另外一个开源的连接池C3P0,首先我们需要导入相关jar包,具体如下:
首先我们使用手动设置MySQL参数的方式使用C3P0连接池,首先创建连接,设置参数,然后从连接池获得连接,后面就可以写SQL语句,预编译并执行查询操作了,具体如下:
import com.mchange.v2.c3p0.ComboPooledDataSource;
import utils.JDBCUtils;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class JDBCDemo02
public static void main(String[] args)
demo1() ;
public static void demo1()
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try
// 创建连接池:
ComboPooledDataSource dataSource = new ComboPooledDataSource();
// 设置连接参数:
dataSource.setDriverClass("com.mysql.jdbc.Driver");
dataSource.setJdbcUrl("jdbc:mysql:///web_test1");
dataSource.setUser("root");
dataSource.setPassword("123456");
// 从连接池中获得连接:
conn = dataSource.getConnection();
// 编写SQL:
String sql = "select * from account";
// 预编译SQL:
pstmt = conn.prepareStatement(sql);
// 执行SQL:
rs = pstmt.executeQuery();
while(rs.next())
System.out.println(rs.getInt("id")+" "+rs.getString("name")+" "+rs.getDouble("money"));
catch(Exception e)
e.printStackTrace();
finally
JDBCUtils.release(rs, pstmt, conn);
下面将数据库的参数配置在c3p0-config.xml文件中,这样会自动加载配置,不粗要在程序中设置数据库的配置信息,具体如下,包含两种配置,一种是默认配置,另外一种是带名称参数的配置。
<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
<!-- 这是默认配置信息 -->
<default-config>
<!-- 连接四大参数配置 -->
<property name="jdbcUrl">jdbc:mysql://localhost:3306/web_test1?useUnicode=true&characterEncoding=utf-8</property>
<property name="driverClass">com.mysql.jdbc.Driver</property>
<property name="user">root</property>
<property name="password">123456</property>
<!-- 池参数配置 -->
<property name="acquireIncrement">3</property>
<property name="initialPoolSize">10</property>
<property name="minPoolSize">2</property>
<property name="maxPoolSize">10</property>
</default-config>
<named-config name="otherConfig">
<!-- 连接四大参数配置 -->
<property name="jdbcUrl">jdbc:mysql://localhost:3306/web_test1?useUnicode=true&characterEncoding=utf-8</property>
<property name="driverClass">com.mysql.jdbc.Driver</property>
<property name="user">root</property>
<property name="password">123456</property>
<!-- 池参数配置 -->
<property name="acquireIncrement">3</property>
<property name="initialPoolSize">10</property>
<property name="minPoolSize">2</property>
<property name="maxPoolSize">10</property>
</named-config>
</c3p0-config>
加载配置文件并从连接池获得连接,然后编写SQL语句,预编译并执行查询操作的代码如下:
import com.mchange.v2.c3p0.ComboPooledDataSource;
import utils.JDBCUtils;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class JDBCDemo02
public static void main(String[] args)
demo1() ;
public static void demo1()
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try
// 创建连接池:
ComboPooledDataSource dataSource = new ComboPooledDataSource();
// 从连接池中获得连接:
conn = dataSource.getConnection();
// 编写SQL:
String sql = "select * from account";
// 预编译SQL:
pstmt = conn.prepareStatement(sql);
// 执行SQL:
rs = pstmt.executeQuery();
while(rs.next())
System.out.println(rs.getInt("id")+" "+rs.getString("name")+" "+rs.getDouble("money"));
catch(Exception e)
e.printStackTrace();
finally
JDBCUtils.release(rs, pstmt, conn);
8、JDBC之改写工具类
之前的工具类是使用传统的方式获得连接,现在直接在工具类中创建连接,每次直接使用即可,不用重复创建,具体如下:
import com.mchange.v2.c3p0.ComboPooledDataSource;
import javax.sql.DataSource;
import java.sql.*;
public class JDBCUtils02
private static final ComboPooledDataSource datasource = new ComboPooledDataSource() ;
public static DataSource getDataSource()
return datasource ;
public static Connection getConnection()
Connection conn = null;
try
conn = datasource.getConnection() ;
catch(Exception e)
e.printStackTrace();
return conn;
public static void release(Statement stmt, Connection conn)
if(stmt != null)
try
stmt.close();
catch (SQLException e)
e.printStackTrace();
stmt = null;
if(conn != null)
try
conn.close();
catch (SQLException e)
e.printStackTrace();
conn = null;
public static void release(ResultSet rs, Statement stmt, Connection conn)
// 资源释放:
if(rs != null)
try
rs.close();
catch (SQLException e)
e.printStackTrace();
rs = null;
if(stmt != null)
try
stmt.close();
catch (SQLException e)
e.printStackTrace();
stmt = null;
if(conn != null)
try
conn.close();
catch (SQLException e)
e.printStackTrace();
conn = null;
9、DBUtils的学习之CRUD操作
DBUtils是Apache提供的一个对JDBC进行简单封装的工具类,可以简化JDBC应用的开发。JDBC手写比较麻烦,而且有非常多的代码是类似的。比如获得连接,预编译SQL,释放资源等..那么可以将这些代码抽取出来放到工具类中。将类似的代码进行抽取。大大简化JDBC的编程。
它的核心运行类对象是QueryRunner对象,该对象有一些常用的API
通过QueryRunner核心运行类是西安CRUD操作,不需要预编译之类的,当然这个也需要导入相关jar包,代码具体如下:
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
public class DBUtils
public static void main(String[] args) throws SQLException
test() ;
private static void test() throws SQLException
QueryRunner queryRunner = new QueryRunner(JDBCUtils02.getDataSource());
//添加操作
queryRunner.update("insert into account values (null,?,?)", "ddd",10000);
//修改操作
queryRunner.update("update account set name=?,money=? where id =?", "eee",20000,4);
//删除操作
queryRunner.update("delete from account where id = ?", 3);
//查询一条记录的操作
Account account = queryRunner.query("select * from account where id = ?", new ResultSetHandler<Account>()
@Override
public Account handle(ResultSet resultSet) throws SQLException
Account account = new Account() ;
while(resultSet.next())
account.setId(resultSet.getInt("id"));
account.setName(resultSet.getString("name"));
account.setMoney(resultSet.getDouble("money"));
return account ;
, 1) ;
System.out.println(account);
//查询多条语句
List<Account> list = queryRunner.query("select * from account", new ResultSetHandler<List<Account>>()
@Override
public List<Account> handle(ResultSet resultSet) throws SQLException
List<Account> list = new ArrayList<>();
while(resultSet.next())
Account account = new Account() ;
account.setId(resultSet.getInt("id"));
account.setName(resultSet.getString("name"));
account.setMoney(resultSet.getDouble("money"));
list.add(account) ;
return list ;
) ;
for(Account account1 : list)
System.out.println(account1);
10、DBUtils使用之ResultSetHandler实现类
1)ArrayHandler和ArrayListHandler
将一条记录封装到一个数组当中。这个数组应该是Object[]
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ArrayHandler;
import java.sql.SQLException;
import java.util.Arrays;
public class DBUtils02
public static void main(String[] args) throws SQLException
test() ;
private static void test() throws SQLException
QueryRunner queryRunner = new QueryRunner(JDBCUtils02.getDataSource()) ;
Object [] objects = queryRunner.query("select * from account where id = ?",new ArrayHandler(),1) ;
System.out.println(Arrays.toString(objects));
将多条记录封装到一个装有Object[]的List集合中。
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ArrayListHandler;
import java.sql.SQLException;
import java.util.Arrays;
import java.util.List;
public class DBUtils02
public static void main(String[] args) throws SQLException
test() ;
private static void test() throws SQLException
QueryRunner queryRunner = new QueryRunner(JDBCUtils02.getDataSource()) ;
List<Object[]> list = queryRunner.query("select * from account ",new ArrayListHandler()) ;
for(Object [] objects : list)
System.out.println(Arrays.toString(objects));
2)BeanHandler和BeanListHandler
将一条记录封装到一个JavaBean中。
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import java.sql.SQLException;
public class DBUtils02
public static void main(String[] args) throws SQLException
test() ;
private static void test() throws SQLException
QueryRunner queryRunner = new QueryRunner(JDBCUtils02.getDataSource()) ;
Account account = queryRunner.query("select * from account where id = ?",new BeanHandler<Account>(Account.class),1) ;
System.out.println(account);
将多条记录封装到一个装有JavaBean的List集合中。
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import java.sql.SQLException;
import java.util.List;
public class DBUtils02
public static void main(String[] args) throws SQLException
test() ;
private static void test() throws SQLException
QueryRunner queryRunner = new QueryRunner(JDBCUtils02.getDataSource()) ;
List<Account> account = queryRunner.query("select * from account",new BeanListHandler<Account>(Account.class)) ;
for(Account account1 : account)
System.out.println(account1);
3)MapHandler和MapListHandler
将一条记录封装到一个Map集合中,Map的key是列名,Map的value就是表中列的记录值。
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.MapHandler;
import java.sql.SQLException;
import java.util.Map;
public class DBUtils02
public static void main(String[] args) throws SQLException
test() ;
private static void test() throws SQLException
QueryRunner queryRunner = new QueryRunner(JDBCUtils02.getDataSource()) ;
Map<String,Object> map = queryRunner.query("select * from account where id = ?",new MapHandler(),1) ;
System.out.println(map);
将多条记录封装到一个装有Map的List集合中。
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.MapListHandler;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;
public class DBUtils02
public static void main(String[] args) throws SQLException
test() ;
private static void test() throws SQLException
QueryRunner queryRunner = new QueryRunner(JDBCUtils02.getDataSource()) ;
List<Map<String,Object>> list = queryRunner.query("select * from account",new MapListHandler()) ;
for(Map map : list)
System.out.println(map);
4)ColumnListHandler、ScalarHandler
将数据中的某列封装到List集合中。
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ColumnListHandler;
import java.sql.SQLException;
import java.util.List;
public class DBUtils02
public static void main(String[] args) throws SQLException
test() ;
private static void test() throws SQLException
QueryRunner queryRunner = new QueryRunner(JDBCUtils02.getDataSource()) ;
List<Object> list = queryRunner.query("select * from account",new ColumnListHandler("name")) ;
for(Object object : list)
System.out.println(object);
将单个值封装。
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import java.sql.SQLException;
public class DBUtils02
public static void main(String[] args) throws SQLException
test() ;
private static void test() throws SQLException
QueryRunner queryRunner = new QueryRunner(JDBCUtils02.getDataSource()) ;
Object object = queryRunner.query("select count(*) from account",new ScalarHandler()) ;
System.out.println(object);
以上是关于JavaWeb开发之JDBC知识总结的主要内容,如果未能解决你的问题,请参考以下文章