DBUtils

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

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

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

Dbutils三个核心功能

QueryRunner中提供对sql语句操作的API.

ResultSetHandler接口,用于定义select操作后,怎样封装结果集.

DbUtils类,它就是一个工具类,定义了关闭资源与事务处理的方法

QueryRunner核心类

update(Connection conn, String sql, Object... params),用来完成表数据的增加、删除、更新操作

query(Connection conn, String sql, ResultSetHandler rsh, Object... params),用来完成表数据的查询操作

一、QueryRunner实现增删改操作

使用格式:

update (Connection con,String sql,Object...param)

java 自启创建表格 java实现自动建表_java dbutils自动建表

private static void func() throws SQLException {
//创建QueryRunner对象
QueryRunner qr = new QueryRunner();
//书写sql语句
//String sql = "insert into sort(sname,sprice,sdesc)VALUES(?,?,?)"; // 增
//String sql = "UPDATE sort SET sname=?,sprice=?,sdesc=? WHERE sid=?"; // 改
String sql = "DELETE FROM sort WHERE sid=?"; // 删
//将三个?占位符的实际参数,写在数组中
Object[] params = {2};
//调用QueryRunner类的方法update执行SQL语句,返回受影响的函数
int row = qr.update(conn, sql, params);
//打印行数
System.out.println(row);
/*
* 判断insert,update,delete执行是否成功
* 对返回值row判断
* if(row>0) 执行成功
*/
//关闭连接
DbUtils.closeQuietly(conn);
}

java 自启创建表格 java实现自动建表_java dbutils自动建表_02

java 自启创建表格 java实现自动建表_结果集_03

1 packagecn.x5456.demo;2
3 importjava.io.IOException;4 importjava.io.InputStream;5 importjava.sql.Connection;6 importjava.sql.DriverManager;7 importjava.util.Properties;8
9 public classJDBCUtils {10 privateJDBCUtils(){}11 private staticConnection conn ;12 private staticString dirverClass;13 private staticString url;14 private staticString username;15 private staticString password;16
17 //静态代码块,调用就执行
18 static{19 try{20 func();21 Class.forName(dirverClass);22 conn =DriverManager.getConnection(url, username, password);23 }catch(Exception ex){24 throw new RuntimeException(ex+"数据库连接失败");25 }26 }27
28
29 private static void func() throwsIOException {30 //获取类的加载器 返回指定资源的输入流
31 InputStream in = JDBCUtils.class.getClassLoader().getResourceAsStream("database.properties");32
33 Properties prop = newProperties();34 prop.load(in);35
36 dirverClass = prop.getProperty("dirverClass");37 url = prop.getProperty("url");38 username = prop.getProperty("username");39 password = prop.getProperty("password");40 }41
42 /*
43 * 定义静态方法,返回数据库的连接对象44 */
45 public staticConnection getConnection(){46 returnconn;47 }48 }

JDBCUtils

java 自启创建表格 java实现自动建表_java dbutils自动建表_02

java 自启创建表格 java实现自动建表_结果集_03

1 dirverClass=com.mysql.jdbc.Driver2 url=jdbc:mysql://127.0.0.1:3306/testdb
3 username=root4 password=xxx
database.properties

二、QueryRunner实现查询操作

query(Connection conn, String sql, ResultSetHandler rsh, Object... params)
ArrayHandler

将结果集中的第一条记录封装到一个Object[]数组中,数组中的每一个元素就是这条记录中的每一个字段的值

ArrayListHandler

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

BeanHandler

将结果集中第一条记录封装到一个指定的javaBean中。

BeanListHandler

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

ColumnListHandler

将结果集中指定的列的字段值,封装到一个List集合中

ScalarHandler

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

MapHandler

将结果集第一行封装到Map集合中,Key列名, Value该列数据

MapListHandler

将结果集第一行封装到Map集合中,Key列名, Value该列数据,Map集合存储到List集合

1) ArrayHandler
/*
* 结果集第一种处理方法, ArrayHandler
* 将结果集的第一行存储到对象数组中 Object[]
*/
public static void arrayHandler() throws SQLException {
QueryRunner qr = new QueryRunner();
String sql = "SELECT * FROM sort";
Object[] result = qr.query(conn,sql,new ArrayHandler()); // 返回一个Object数组
for (Object obj : result){
System.out.print(obj+"\t");
}
}

结果

1 书 9.9 年终大促
2)ArrayListHandler
/*
* 结果集第二种处理方法,ArrayListHandler
* 将结果集的每一行,封装到对象数组中, 出现很多对象数组
* 对象数组存储到List集合
*/
public static void arrayListHandler() throws SQLException {
QueryRunner qr = new QueryRunner();
String sql = "SELECT * FROM sort";
List result = qr.query(conn,sql,new ArrayListHandler()); // 返回一个Object数组
for (Object[] objs : result){
for (Object obj : objs){
System.out.print(obj+"\t");
}
System.out.println();
}
}

结果

1 书 9.9 年终大促

3椅子998.0只要998

5体育用品289.32购买体育用品

JavaBean

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

需要实现接口:java.io.Serializable,通常实现接口这步骤省略了,不会影响程序。

提供私有字段:private类型字段名。

提供getter/setter方法。

提供无参构造。

全部可以使用IDE自动生成

3)beanHandler
/*
* 结果集第三种处理方法,BeanHandler
* 将结果集的第一行数据,封装成JavaBean对象
* 注意: 被封装成数据到JavaBean对象, Sort类必须有空参数构造
*/
private static void beanHandler() throws SQLException {
QueryRunner qr = new QueryRunner();
String sql = "SELECT * FROM sort";
Sort s = qr.query(conn,sql,new BeanHandler(Sort.class)); //传递Sort的class文件的对象,目的是反射创建对象
System.out.println(s);
}

java 自启创建表格 java实现自动建表_java dbutils自动建表_02

java 自启创建表格 java实现自动建表_结果集_03

1 packagecn.x5456.bean;2
3 public classSort {4 private intsid;5 privateString sname;6 private doublesprice;7 privateString sdesc;8
9 public Sort(int sid, String sname, doublesprice, String sdesc) {10 this.sid =sid;11 this.sname =sname;12 this.sprice =sprice;13 this.sdesc =sdesc;14 }15
16 publicSort() {17 }18
19 public intgetSid() {20 returnsid;21 }22
23 publicString getSname() {24 returnsname;25 }26
27 public doublegetSprice() {28 returnsprice;29 }30
31 publicString getSdesc() {32 returnsdesc;33 }34
35 public void setSid(intsid) {36 this.sid =sid;37 }38
39 public voidsetSname(String sname) {40 this.sname =sname;41 }42
43 public void setSprice(doublesprice) {44 this.sprice =sprice;45 }46
47 public voidsetSdesc(String sdesc) {48 this.sdesc =sdesc;49 }50
51 @Override52 publicString toString() {53 return "Sort{" +
54 "sid=" + sid +
55 ", sname='" + sname + '\'' +
56 ", sprice=" + sprice +
57 ", sdesc='" + sdesc + '\'' +
58 '}';59 }60 }
Sort.java

结果

Sort{sid=1, sname='书', sprice=9.9, sdesc='年终大促'}
4)beanListHandler
/*
* 结果集第四种处理方法, BeanListHandler
* 结果集每一行数据,封装JavaBean对象
* 多个JavaBean对象,存储到List集合
*/
private static void beanListHandler() throws SQLException {
QueryRunner qr = new QueryRunner();
String sql = "SELECT * FROM sort";
List list = qr.query(conn,sql,new BeanListHandler(Sort.class)); //传递Sort的class文件的对象,目的是反射创建对象
for (Sort s : list){
System.out.println(s);
}
}

结果

Sort{sid=1, sname='书', sprice=9.9, sdesc='年终大促'}
Sort{sid=3, sname='椅子', sprice=998.0, sdesc='只要998'}
Sort{sid=5, sname='体育用品', sprice=289.32, sdesc='购买体育用品'}
5)ColumnListHandler
/*
* 结果集第五种处理方法,ColumnListHandler
* 结果集,指定列的数据,存储到List集合
* List 每个列数据类型不同
*/
private static void columnListHandler() throws SQLException {
QueryRunner qr = new QueryRunner();
String sql = "SELECT * FROM sort";
//调用方法 query,传递结果集实现类ColumnListHandler
//实现类构造方法中,使用字符串的列名
List list = qr.query(conn,sql,new ColumnListHandler("sname"));
for(String str : list){
System.out.println(str);
}
}

结果

椅子

体育用品

6)ScalarHandler

/*
* 结果集第六种处理方法,ScalarHandler
* 对于查询后,只有1个结果
*/
private static void scalarHandler() throws SQLException {
QueryRunner qr = new QueryRunner();
String sql = "SELECT count(*) FROM sort";
//调用方法query,传递结果集处理实现类ScalarHandler
long count = qr.query(conn,sql,new ScalarHandler());
System.out.println(count);
}

7)MapHandler

/*
* 结果集第七种处理方法,MapHandler
* 将结果集第一行数据,封装到Map集合中
* Map 键:列名 值:这列的数据
*/
public static void mapHandler()throws SQLException{
QueryRunner qr = new QueryRunner();
String sql = "SELECT * FROM sort";
//调用方法query,传递结果集实现类MapHandler
//返回值: Map集合,Map接口实现类, 泛型
Map map = qr.query(conn, sql, new MapHandler());
//遍历Map集合
for(String key : map.keySet()){
System.out.println(key+".."+map.get(key));
}
}

结果

sid..1

sname..书

sprice..9.9

sdesc..年终大促

8)MapListHandler

/*
* 结果集第八种处理方法,MapListHandler
* 将结果集每一行存储到Map集合,键:列名,值:数据
* Map集合过多,存储到List集合
*/
public static void mapListHandler()throws SQLException{
QueryRunner qr = new QueryRunner();
String sql = "SELECT * FROM sort";
//调用方法query,传递结果集实现类MapListHandler
//返回值List集合, 存储的是Map集合
List> list = qr.query(conn, sql, new MapListHandler());
//遍历集合list
for( Map map : list ){
for(String key : map.keySet()){
System.out.print(key+"..."+map.get(key));
}
System.out.println();
}
}

结果

sid...1sname...书sprice...9.9sdesc...年终大促

sid...3sname...椅子sprice...998.0sdesc...只要998

sid...5sname...体育用品sprice...289.32sdesc...购买体育用品

java 自启创建表格 java实现自动建表_java 自启创建表格_08