DBUtils(增刪改查)

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.













最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市风钻,隨后出現(xiàn)的幾起案子顷蟀,更是在濱河造成了極大的恐慌,老刑警劉巖骡技,帶你破解...
    沈念sama閱讀 218,204評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鸣个,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡布朦,警方通過(guò)查閱死者的電腦和手機(jī)囤萤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)是趴,“玉大人涛舍,你說(shuō)我怎么就攤上這事∷敉荆” “怎么了富雅?”我有些...
    開封第一講書人閱讀 164,548評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)肛搬。 經(jīng)常有香客問(wèn)我没佑,道長(zhǎng),這世上最難降的妖魔是什么温赔? 我笑而不...
    開封第一講書人閱讀 58,657評(píng)論 1 293
  • 正文 為了忘掉前任图筹,我火速辦了婚禮,結(jié)果婚禮上让腹,老公的妹妹穿的比我還像新娘远剩。我一直安慰自己,他們只是感情好骇窍,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評(píng)論 6 392
  • 文/花漫 我一把揭開白布瓜晤。 她就那樣靜靜地躺著,像睡著了一般腹纳。 火紅的嫁衣襯著肌膚如雪痢掠。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,554評(píng)論 1 305
  • 那天嘲恍,我揣著相機(jī)與錄音足画,去河邊找鬼。 笑死佃牛,一個(gè)胖子當(dāng)著我的面吹牛淹辞,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播俘侠,決...
    沈念sama閱讀 40,302評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼象缀,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼蔬将!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起央星,我...
    開封第一講書人閱讀 39,216評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤霞怀,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后莉给,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體毙石,經(jīng)...
    沈念sama閱讀 45,661評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評(píng)論 3 336
  • 正文 我和宋清朗相戀三年颓遏,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了徐矩。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,977評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡州泊,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出漂洋,到底是詐尸還是另有隱情遥皂,我是刑警寧澤,帶...
    沈念sama閱讀 35,697評(píng)論 5 347
  • 正文 年R本政府宣布刽漂,位于F島的核電站演训,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏贝咙。R本人自食惡果不足惜样悟,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望庭猩。 院中可真熱鬧窟她,春花似錦、人聲如沸蔼水。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)趴腋。三九已至吊说,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間优炬,已是汗流浹背颁井。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蠢护,地道東北人雅宾。 一個(gè)月前我還...
    沈念sama閱讀 48,138評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像葵硕,于是被迫代替她去往敵國(guó)和親秀又。 傳聞我的和親對(duì)象是個(gè)殘疾皇子单寂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容