DBUtils(增刪改查)

1:如果只使用JDBC進行開發(fā),會導致冗余代碼過多,為了簡化JDBC開發(fā),采用apache commons組件一個成員:DBUtils。
DBUtils就是JDBC的簡化開發(fā)工具包。需要項目導入commons-dbutils-1.4.jar(還有更高的版本)才能夠正常使用DBUtils工具。

2:首先在Maven工程下導入jar包,在pom.xml下,找到最底下的一對<dependency>,在它們中間輸入<depdendency>然后輸入commons-dbutils,選擇1.4版本.

3:Dbutils三個核心功能介紹

●QueryRunner中提供對sql語句操作的API.
●ResultSetHandler接口,用于定義select操作后,怎樣封裝結(jié)果集.
●DbUtils類,它就是一個工具類,定義了關(guān)閉資源與事務(wù)處理的方法

QueryRunner中提供對sql語句操作的API.
update(Connection conn, String sql, Object... params) ,用來完成表數(shù)據(jù)的增加、刪除、更新操作
query(Connection conn, String sql, ResultSetHandler<T> rsh, Object... params) ,用來完成表數(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,就會自動在第一行前面設(shè)置第0行,加入此條語句,但是只能操作一次,如果想再加入,就必須在最后一行增加語句,找到最后一行的id,將id加入sql語句,如下圖,在最后一行(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);
    }
```

@修改:
比如將第二個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é)果集中的第一條記錄封裝到一個Object[]數(shù)組中,數(shù)組中的每一個元素就是這條記錄中的每一個字段的值

```
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é)果集中的每一條記錄都封裝到一個Object[]數(shù)組中,將這些數(shù)組再封裝到List集合中。(查詢?nèi)空Z句)

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é)果集中第一條記錄封裝到一個指定的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é)果集中指定的列的字段值,封裝到一個List集合中
查詢年齡在50歲以上的人,ColumnListHandler()里什么都不寫默認的是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();
    }
}
運行結(jié)果為:
[1, 2, 4, 5]
  ●ScalarHandler:它是用于單數(shù)據(jù)。例如select count(*) from 表操作。
查詢最大年齡:輸入sql語句“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();
    }
}
```
運行結(jié)果為最大年齡 :111.













最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容