JDBC_apache_commons_DBUtils详解

package cn.commons.DBUtils;

import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.MapHandler;
import org.apache.commons.dbutils.handlers.MapListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import org.junit.Test;

import cn.code.dbUtils.Stu;
import cn.code.jdbc.JDBCUtils2;

public class Demo1 {
    @Test
    public void fun1() throws Exception{
        QueryRunner qr = new QueryRunner();
            String sql="insert into stu values(?,?,?,?)";
            Object[]params ={"dbUtils","java",23,"boy"};
            Connection conn = qr.getDataSource().getConnection();
            qr.update(conn, sql, params);
        }
    @Test
    public void fun2() throws SQLException{
        QueryRunner qr = new QueryRunner(JDBCUtils2.getDataSource());
        String sql="select * from stu";
        //BeanListHandler多行结果集处理器,每行对应一个Stu对象
        List<Stu> stus = qr.query(sql, new BeanListHandler<Stu>(Stu.class));
        for(Stu s : stus ){
            System.out.println(s);
        }
    }
    @Test
    public void fun3() throws SQLException{
        /*
         * MapHandler
         * */
        QueryRunner qr = new QueryRunner(JDBCUtils2.getDataSource());
        String sql="select * from stu where number=?";
        //BeanListHandler多行结果集处理器,每行对应一个Stu对象
        Object[]params ={"0001"};
        Connection conn = qr.getDataSource().getConnection();
        Map stu = qr.query(conn, sql, new MapHandler(), params);
        System.out.println(stu);
    }
    @Test
    public void fun4() throws SQLException{
        QueryRunner qr = new QueryRunner(JDBCUtils2.getDataSource());
        String sql="select * from stu ";
        //BeanListHandler多行结果集处理器,每行对应一个Stu对象
        //Object[]params ={"0001"};
        Connection conn = qr.getDataSource().getConnection();
        List<Map<String,Object>> stu = qr.query(conn, sql, new MapListHandler());
        System.out.println(stu);
    }
    @Test
    public void fun5() throws SQLException{
        QueryRunner qr = new QueryRunner(JDBCUtils2.getDataSource());
        String sql="select count(*) from stu ";
        //BeanListHandler多行结果集处理器,每行对应一个Stu对象
        //Object[]params ={"0001"};
        Connection conn = qr.getDataSource().getConnection();
        //count(*)返回值用Number,接收最为合适
        Number stu = (Number)qr.query(conn, sql, new ScalarHandler());
        System.out.println(stu);
    }
    @Test
    public void fun6() throws SQLException{
        QueryRunner qr = new QueryRunner(JDBCUtils2.getDataSource());
        String sql="select * from stu where number=?";
        //BeanListHandler多行结果集处理器,每行对应一个Stu对象
        Object[]params ={"0001"};
        Connection conn = qr.getDataSource().getConnection();
        Stu stu = qr.query(conn, sql, new BeanHandler<Stu>(Stu.class), params);
        System.out.println(stu);
    }
        
}

//注意所有jdbc代码,均导入数据库连接池包,数据库连接包,自制JDBCUtils.jar等

转载于:https://www.cnblogs.com/wangyinxu/p/7428309.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值