您的位置:首页 > 编程语言 > Java开发

JavaWeb之DButils(四)使用DBUtils实现增删查改

2017-09-06 20:08 405 查看
DBUtils是JDBC的简化开发工具包

一、JavaBean组件

JavaBean就是一个组件,在开发中常用于封装数据,有以下特性:

1.需要实现接口:java,io.Serializable(也可省略)

2.提供私有字段:private 类型 字段名;

3.提供get/set方法

4.提供无参构造

package com.shuhuadream.domain;

public class Sort {
private int sid;
private String sname;
private double sprice;
private String sdesc;
public Sort(int sid, String sname, double sprice, String sdesc) {
super();
this.sid = sid;
this.sname = sname;
this.sprice = sprice;
this.sdesc = sdesc;
}

public Sort(){}

public int getSid() {
return sid;
}

public void setSid(int sid) {
this.sid = sid;
}

public String getSname() {
return sname;
}

public void setSname(String sname) {
this.sname = sname;
}

public double getSprice() {
return sprice;
}

public void setSprice(double sprice) {
this.sprice = sprice;
}

public String getSdesc() {
return sdesc;
}

public void setSdesc(String sdesc) {
this.sdesc = sdesc;
}

@Override
public String toString() {
return "Sort [sid=" + sid + ", sname=" + sname + ", sprice=" + sprice + ", sdesc=" + sdesc + "]";
}

}



二、DBUtils完成增删改查
1、概述



2、QueryRunner核心类



3、ResultSetHandle结果集处理类





4、DBUtils工具类



三、测试DBUtils工具类 增删改操作,使用到QueryRunner类

package com.shuhuadream.queryrunner;

import java.sql.SQLException;

import javax.sql.DataSource;

import org.apache.commons.dbutils.QueryRunner;
import org.junit.Test;

import com.shuhuadream.jdbc.utils01.C3P0Utils;

/* 测试DBUtils工具类 增删改操作
* 使用QueryRunner类,实现对数据表的
* insert delete update
* 调用QueryRunner类的方法 update (Connection con,String sql,Object...param)
* Object...param 可变参数,Object类型,SQL语句会出现?占位符
* 数据库连接对象,自定义的工具类传递
*/
public class QueryRunnerDemo {
private static DataSource dataSource = C3P0Utils.getDataSource();

//定义方法,使用QueryRunner类的方法delete将数据表的数据删除
@Test
public void delete(){
try {
//创建QueryRunner类对象
QueryRunner qr = new QueryRunner(dataSource);
//写删除的SQL语句
String sql = "DELETE FROM sort WHERE sid=?";
//调用QueryRunner方法update
int row = qr.update(sql, 27);
if(row>0){
System.out.println("删除成功!");
}else{
System.out.println("删除失败!");
}
} catch (SQLException e) {
e.printStackTrace();
}
}

//定义方法,使用QueryRunner类的方法update将数据表的数据修改
@Test
public void update(){
try {
//创建QueryRunner类对象
QueryRunner qr = new QueryRunner(dataSource);
//写修改数据的SQL语句
String sql = "UPDATE sort SET sname=?,sprice=?,sdesc=? WHERE sid=?";
//定义Object数组,存储?中的参数
Object[] params = {"月饼",100.88,"中秋佳节月饼促销",25};
//调用QueryRunner方法update
int row = qr.update(sql, params);
if(row>0){
System.out.println("修改成功!");
}else{
System.out.println("修改失败!");
}
} catch (SQLException e) {
e.printStackTrace();
}

}

/*
* 定义方法,使用QueryRunner类的方法update向数据
fa5c
表中,添加数据
*/
@Test
public void insert(){
try {
//创建QueryRunner类对象
QueryRunner qr = new QueryRunner(dataSource);
String sql = "INSERT INTO sort (sname,sprice,sdesc)VALUES(?,?,?)";
//将三个?占位符的实际参数,写在数组中
Object[] params = {"体育用品",289.32,"购买体育用品"};
//调用QueryRunner类的方法update执行SQL语句
int row = qr.update(sql, params);
if(row>0){
System.out.println("数据添加成功!");
}else{
System.out.println("数据添加失败!");
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}


四、使用DBUtils运用QueryRunner数据进行查询操作并使用ResultSetHandle结果集处理类处理结果集
package com.shuhuadream.queryrunner;

import java.sql.SQLException;
import java.util.List;
import java.util.Map;

import javax.sql.DataSource;

import org.apache.commons.dbutils.*;
import org.apache.commons.dbutils.handlers.ArrayHandler;
import org.apache.commons.dbutils.handlers.ArrayListHandler;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ColumnListHandler;
import org.apache.commons.dbutils.handlers.MapHandler;
import org.apache.commons.dbutils.handlers.MapListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import org.junit.Test;

import com.shuhuadream.domain.Sort;
import com.shuhuadream.jdbc.utils01.C3P0Utils;
/**
* QueryRunner数据查询操作
* 调用QueryRunner类方法query(Connection con,String sql,ResultSetHandler r,Object..params)
* ResultSetHandler r 结果集的处理方式,传递ResultSetHandler接口实现类
* Object...params sql语句的?占位符
*
* 注意:query方法返回值,返回的是T 泛型,具体返回值类型,跟随结果集处理方式变化
* */
public class QueryRunnerDemo02 {
private static DataSource dataSource = C3P0Utils.getDataSource();
/**
* 结果集第一种处理方法,ArrayHandler
* 将结果第一行存储到对象数组中Object[]
* @throws SQLException
* */

public void ArrayHandler(){

try {
QueryRunner qr = new QueryRunner(dataSource);
String sql = "SELECT * FROM sort";
//调用query执行查询,传递连接对象,SQL语句,结果集处理方式的实现类
//返回对象数组
Object[] result = qr.query(sql,new ArrayHandler());
for (Object obj : result) {
System.out.println(obj);
}
} catch (SQLException e) {
e.printStackTrace();
}
}

/**
* 结果集的第二种处理方法,ArrayListHandler
* 将结果集的每一行,封装到对象数组中,出现很多对象数组
* 对象数组存储到List集合
* @throws SQLException
* */
@Test
public void arrayListHandler(){

try {
QueryRunner qr = new QueryRunner(dataSource);
String sql = "SELECT * FROM sort";
//调用query方法,结果集处理的参数上,传递实现类ArrayListHandler
//方法返回值 每行是一个数组
List<Object[]> result = qr.query(sql, new ArrayListHandler());
//集合的遍历
for (Object[] objs : result) {
for (Object obj : objs) {
System.out.print(obj+"\t");
}
System.out.println();
}
} catch (SQLException e) {
e.printStackTrace();
}

}
/**
* 结果集的第三种处理方法BeanHandler
* 将结果集的第一行数据,封装为JavaBean对象
* 注意:被封装成数据到JavaBean对象,Sort类必须有空参构造
* @throws SQLException
* */
@Test
public void beanHandler(){
try {
QueryRunner qr = new QueryRunner(dataSource);
String sql = "SELECT * FROM sort";
//调用方法,传递结果集实现BeanHandler
//BeanHandler(Class<T> type)
Sort s = qr.query(sql,new BeanHandler<Sort>(Sort.class));
System.out.println(s);
} catch (SQLException e) {
e.printStackTrace();
}
}

/**
* 结果集第四种处理方法,BeanListHandler
* 将数据结果集的每一行数据,封装为JavaBean对象
* 多个JavaBean对象封装到List集合中
* @throws SQLException
* */
@Test
public void beanListHandler(){
try {
QueryRunner qr = new QueryRunner(dataSource);
String sql = "SELECT * FROM sort";
//调用方法传递结果集的实现类BeanListHandler
//BeanListHandler(Class<T> type)
List<Sort> list = qr.query(sql, new BeanListHandler<Sort>(Sort.class));
for (Sort s : list) {
System.out.println(s);
}
} catch (SQLException e) {
e.printStackTrace();
}
}

/**
* 结果集第五种处理方法,ColumnListHandler
* 结果集,指定列的数据,存储到List集合中
* List<Object> 每个列数据类型不同
* @throws SQLException
* */
@Test
public void columnListHandler(){
try {
QueryRunner qr = new QueryRunner(dataSource);
String sql = "SELECT * FROM sort";
//调用方法query,传递结果集实现类ColumnListHandler
//实现类构造方法,使用字符串的列名
List<Object> list = qr.query(sql, new ColumnListHandler("sname"));
for (Object obj : list) {
System.out.println(obj);
}
} catch (SQLException e) {
e.printStackTrace();
}
}
/**
* 结果集第六种处理方法 ScalarHandler
* 对于查询后,只有一个结果
* @throws SQLException
* */
@Test
public void scalarHandler(){
try {
QueryRunner qr = new QueryRunner(dataSource);
String sql = "SELECT COUNT(*) FROM sort";
//调用方法query,传递结果集处理类ScalarHandler
Object count = qr.query(sql,new ScalarHandler());
System.out.println(count);
} catch (SQLException e) {
e.printStackTrace();
}

}

/**
* 结果集的第七种处理方式,MapHandler
* 将结果集第一行数据,封装到Map集合中
* Map<键,值> 键:列名 值:这列数据
* @throws SQLException
* */
@Test
public void mapHandler(){
try {
QueryRunner qr = new QueryRunner(dataSource);
String sql = "SELECT * FROM sort";
//调用方法query,传递结果集实现类MapHandler
//返回值:Map集合,Map接口实现类 泛型
Map<String, Object> map = qr.query(sql,new MapHandler());
for (String key : map.keySet()) {
System.out.println(key+"..."+map.get(key));
}
} catch (SQLException e) {
e.printStackTrace();
}
}
/**
* 结果集第八种处理方法,MapListHandler
* 将结果集每一行存储到Map集合,键:列名 值:数据
* Map集合过多,存储到List集合
* @throws SQLException
* */
@Test
public void mapListHandler(){
try {
QueryRunner qr = new QueryRunner(dataSource);
String sql = "SELECT * FROM sort";
//调用方法query,传递结果集实现类MapListHander
//返回值List集合,存储的是Map集合
List<Map<String, Object>> list = qr.query(sql,new MapListHandler());
for (Map<String, Object> map : list) {
for (String key : map.keySet()) {
System.out.print(key+"..."+map.get(key));
}
System.out.println();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}


该操作用到了上一篇笔记当中的C3P0Utils工具类,实际开发当中建议使用C3P0Utils工具类

后记:每一天都是新的,学习路上加油
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: