QueryRunner的使用

欢迎使用Markdown编辑器写博客

public class JdbcUtil {
private static ComboPooledDataSource dataSource =new ComboPooledDataSource();
public static ComboPooledDataSource getDataSource()
{
return dataSource;
}

}

src目录下c3p0-config.xml

从数据库中取count(*)数据

1 int topicNum=0;
2 QueryRunner runner= new QueryRunner(JdbcUtil.getDataSource());
3 String sql =”select count(*) from topic where type_id= ? order by time desc”;
4 Object[] params={typeId};
5 topicNum=(int)(long) runner.query(sql,new ScalarHandler(),params);
6 return topicNum;

取一条数据 其中表的字段名字和类的名字要对应相同

1 Topic newlyTopic=null;
2 QueryRunner runner= new QueryRunner(JdbcUtil.getDataSource());
3 String sql =”select * from topic where type_id= ? order by time desc”;
4 Object[] params={typeId};
5 newlyTopic= runner.query(sql,new BeanHandler(Topic.class),params);
6 return newlyTopic;

取集合数据List<>返回 其中表的字段名字和类的名字要对应相同

1 List topicList=new ArrayList();
2 QueryRunner runner= new QueryRunner(JdbcUtil.getDataSource());
3 String sql =”select * from topic where type_id= ? order by time desc”;
4 Object[] params={typeId};
5 topicList=runner.query(sql, new BeanListHandler(Topic.class),params);
6 return topicList;
插入

复制代码
1 QueryRunner runner= new QueryRunner(JdbcUtil.getDataSource());
2 String sql =”insert into topic(name,author,content,time,type_id) values(?,?,?,?,?)”;
3 Object[] params={topic.getName(),topic.getAuthor(),topic.getContent(),topic.getTime(),topic.getTypeId()};
4 try {
5 //事务开始
6 runner.update(sql,params);
7 //事务提交
8 } catch (SQLException e) {
9 e.printStackTrace();
10 //事务回滚
11 throw e;
12 }
复制代码
更新

复制代码
1 QueryRunner runner= new QueryRunner(JdbcUtil.getDataSource());
2 String sql =”update topic set name=? , content=? , time=? where id= ?”;
3 Object[] params={topic.getName(),topic.getContent(),topic.getTime(),topic.getId()};
4 try {
5 //事务开始
6 runner.update(sql,params);
7 //事务提交
8 } catch (SQLException e) {
9 e.printStackTrace();
10 //事务回滚
11 throw e;
12 }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值