1:如果只使用JDBC進(jìn)行開發(fā)挠轴,會(huì)導(dǎo)致冗余代碼過(guò)多,為了簡(jiǎn)化JDBC開發(fā)耳幢,采用apache commons組件一個(gè)成員:DBUtils。
DBUtils就是JDBC的簡(jiǎn)化開發(fā)工具包欧啤。需要項(xiàng)目導(dǎo)入commons-dbutils-1.4.jar(還有更高的版本)才能夠正常使用DBUtils工具睛藻。
2:首先在Maven工程下導(dǎo)入jar包,在pom.xml下邢隧,找到最底下的一對(duì)<dependency>店印,在它們中間輸入<depdendency>然后輸入commons-dbutils,選擇1.4版本.
3:Dbutils三個(gè)核心功能介紹
●QueryRunner中提供對(duì)sql語(yǔ)句操作的API.
●ResultSetHandler接口,用于定義select操作后倒慧,怎樣封裝結(jié)果集.
●DbUtils類按摘,它就是一個(gè)工具類,定義了關(guān)閉資源與事務(wù)處理的方法
QueryRunner中提供對(duì)sql語(yǔ)句操作的API.
update(Connection conn, String sql, Object... params) ,用來(lái)完成表數(shù)據(jù)的增加纫谅、刪除炫贤、更新操作
query(Connection conn, String sql, ResultSetHandler<T> rsh, Object... params) ,用來(lái)完成表數(shù)據(jù)的查詢操作
4:增刪改查
@增加:
```
public class dbs {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="insert into stu(name,age,sex) values(?,?,?)";
Connection connection = JdbcUtil.getConnection();
Object []objects={"王芝洋",21,"女"};
int update = qr.update(connection, sql, objects);
}
```
注意:如果不設(shè)置id,就會(huì)自動(dòng)在第一行前面設(shè)置第0行付秕,加入此條語(yǔ)句兰珍,但是只能操作一次,如果想再加入询吴,就必須在最后一行增加語(yǔ)句掠河,找到最后一行的id,將id加入sql語(yǔ)句,如下圖,在最后一行(12)行加入id:
```
public class dbs {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="insert into stu(id,name,age,sex) values(?,?,?,?)";
Connection connection = JdbcUtil.getConnection();
Object []objects={12,"王芝洋",100,"女"};
int update = qr.update(connection, sql, objects);
}
```
@修改:
比如將第二個(gè)id的名字修改為“王博聰”猛计,年齡修改為111歲唠摹,代碼如下:
```
public class dbsup {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="update stu set name=?,age=? where id=?";
Connection connection = JdbcUtil.getConnection();
Object []objects={"王博聰",111,2};
int update = qr.update(connection, sql, objects);
}
```
@刪除
刪除id=12的信息
```
public class dbsup {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="delete from stu where id=?";
Connection connection = JdbcUtil.getConnection();
Object []objects={12};
int update = qr.update(connection, sql, objects);
}
```
@查詢
●ArrayHandler:將結(jié)果集中的第一條記錄封裝到一個(gè)Object[]數(shù)組中,數(shù)組中的每一個(gè)元素就是這條記錄中的每一個(gè)字段的值
```
public class dbQuery {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="select * from stu";
Connection connection = JdbcUtil.getConnection();
Object [] parms={};
Object[] objects = qr.query(connection, sql, new ArrayHandler(), parms);
System.out.println(Arrays.toString(objects));
connection.close();
}
```
結(jié)果如下:
```
[0, 王芝洋, 21, 女, null]
```
●ArrayListHandler:將結(jié)果集中的每一條記錄都封裝到一個(gè)Object[]數(shù)組中勾拉,將這些數(shù)組再封裝到List集合中。(查詢?nèi)空Z(yǔ)句)
public class dbQuery {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="select * from stu";
Connection connection = JdbcUtil.getConnection();
Object [] parms={};
List<Object[]> list = qr.query(connection, sql, new ArrayListHandler(), parms);
for (Object [] objects:list) {
System.out.println(Arrays.toString(objects));
}
connection.close();
}
}
查詢結(jié)果:
[0, 王芝洋, 21, 女, null]
[1, 王博聰, 90, 女, 1]
[2, 王博聰, 111, 男, 2]
[4, ewdwe, 66, 女, 1]
[5, ewdw, 77, 女, 1]
[6, 張得到, 23, 女, 2]
[7, 張給他, 23, 女, 2]
[8, 放入福, 23, 女, 2]
[9, 一湖光塔影, 33, 男, 1]
[11, 漢斯, 30, 男, 2]
●條件查詢
```
public class dbQuery {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="select * from stu where age>?";
Connection connection = JdbcUtil.getConnection();
Object [] parms={50};
List<Object[]> list = qr.query(connection, sql, new ArrayListHandler(), parms);
for (Object [] objects:list) {
System.out.println(Arrays.toString(objects));
}
connection.close();
}
}
```
查詢結(jié)果:
```
[1, 王博聰, 90, 女, 1]
[2, 王博聰, 111, 男, 2]
[4, ewdwe, 66, 女, 1]
[5, ewdw, 77, 女, 1]
```
5:BeanHandler與BeanListHandler查詢
●BeanHandler :將結(jié)果集中第一條記錄封裝到一個(gè)指定的javaBean中盗温。
public class dbQuery {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="select * from stu where age>?";
Connection connection = JdbcUtil.getConnection();
Object [] parms={50};
Student student = qr.query(connection, sql, new BeanHandler<Student>(Student.class), parms);
System.out.println(student);
connection.close();
}
}
查詢結(jié)果:
Student{id=1,
name='王博聰',
age=90,
sex='女,
tname='null'
}
●BeanListHandler :將結(jié)果集中每一條記錄封裝到指定的javaBean中望艺,將這些
javaBean在封裝到List集合中。
public class dbQuery {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="select * from stu where age>?";
Connection connection = JdbcUtil.getConnection();
Object [] parms={50};
List<Student> query = qr.query(connection, sql, new BeanListHandler<Student>(Student.class), parms);
System.out.println(query);
connection.close();
}
}
查詢結(jié)果:
[Student{id=1,
name='王博聰',
age=90,
sex='女39,
tname='null'
}
, Student{id=2,
name='王博聰',
age=111,
sex='男39,
tname='null'
}
, Student{id=4,
name='ewdwe',
age=66,
sex='女39,
tname='null'
}
, Student{id=5,
name='ewdw',
age=77,
sex='女39,
tname='null'
}
]
6:● ColumnListHandler:將結(jié)果集中指定的列的字段值肌访,封裝到一個(gè)List集合中
查詢年齡在50歲以上的人,ColumnListHandler()里什么都不寫默認(rèn)的是id值找默。如果想查詢具體的字段比如年齡name,則用ColumnListHandler("name")
public class dbQuery {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="select * from stu where age>?";
Connection connection = JdbcUtil.getConnection();
Object [] parms={50};
List<Object> student = qr.query(connection, sql, new ColumnListHandler(), parms);
System.out.println(student);
connection.close();
}
}
運(yùn)行結(jié)果為:
[1, 2, 4, 5]
●ScalarHandler:它是用于單數(shù)據(jù)。例如select count(*) from 表操作吼驶。
查詢最大年齡:輸入sql語(yǔ)句“select Max(age) from stu”惩激,用ScalarHandler()店煞。
```
public class dbQuery {
public static void main(String[] args) throws SQLException {
QueryRunner qr = new QueryRunner();
String sql="select Max(age) from stu";
Connection connection = JdbcUtil.getConnection();
Object [] parms={};
Object query = qr.query(connection, sql, new ScalarHandler(), parms);
System.out.println(query);
connection.close();
}
}
```
運(yùn)行結(jié)果為最大年齡 :111.