java dbutils自动建表_Java——DBUtils的使用(简化了JDBC操作,可以少写代码)

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)

e61352fa2aad0caf0d84f00c7ce51194.png

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);

}

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

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

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

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);

}

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

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...购买体育用品

f0cda1898eb66c011513907610bad058.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值