JDBC总结(含DbUtils组件)
jdbc
1. jdbc:使用java代码(程序)发送sql语句的技术 2. jdbc的核心接口(查看API):
java.sql
Driver,DriverManger,Statement,ResultSet(常用)
javax.sql 3.jdbc 主要应用内容
Statement执行( DDL,DML,DQL)
CallableStatment执行存储过程
PreparedStatment执行sql(预编译可防止恶意密码,防止sql注入)
存储过程的调用
批处理插入,删除,更新数据
事务
存储二进制文件(如图片) 4.DBUtils 组件(commons-dbutils.jar)
Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,
学习成本极低,并且使用dbutils能极大简化jdbc编码的工作量,同时也不会影响程序的性能。
因此dbutils成为很多不喜欢hibernate的公司的首选。 两个常用的 (org.apache.commons.dbutils )classes -- 查看APIdoc
DbUtils
连接数据库,关闭资源 QueryRunner
查询,更新,批处理等 Interface ResultSetHandler<T> All Known Implementing Classes:
---》(一些DbUtils 提供的封装结果集对象)
AbstractKeyedHandler, AbstractListHandler,
ArrayHandler, ArrayListHandler,
BaseResultSetHandler, BeanHandler, BeanListHandler, BeanMapHandler,
ColumnListHandler, KeyedHandler,
MapHandler, MapListHandler,
ScalarHandler
以下较常用:
1)BeanHandler: 查询返回单个对象
2)BeanListHandler: 查询返回list集合,集合元素是指定的对象
3) ArrayHandler, 查询返回结果记录的第一行,封装对对象数组, 即返回:Object[]
4) ArrayListHandler, 把查询的每一行都封装为对象数组,再添加到list集合中
5) ScalarHandler 查询返回结果记录的第一行的第一列 (在聚合函数统计的时候用)
6) MapHandler 查询返回结果的第一条记录封装为map 自定义结果集封装数据:(我查询的是student表中的id=29的学生)
public void testQuery() throws Exception {
String sql = "select * from student where id=?";
conn = JdbcUtil.getConnection();
QueryRunner qr = new QueryRunner();
// select
Student student = qr.query(conn, sql, new ResultSetHandler<Student>() {
//封装student对象
public Student handle(ResultSet rs) throws SQLException{
if (rs.next()) {
Student student = new Student();
student.setId(rs.getInt("id"));
student.setName(rs.getString("name"));
student.setAge(rs.getInt("age"));
return student;
}
return null;
}
},29);
System.out.println(student);
conn.close();
}
使用DbUtils 组件封装结果集数据:
public void testQuery()throws Exception{
String sql = "select * from student where id=?";
conn = JdbcUtil.getConnection();
QueryRunner qr = new QueryRunner();
// 使用DbUtils 中已经封装好的方法(注意好参数)
Student student = qr.query(conn,sql, new BeanHandler<Student>(Student.class),29);
System.out.println(student);
conn.close();
}
----------------------------------------------------------------------------------------
jdbc连接数据库的方式:
--》基础做法
public class Demo1 {
private String url = "jdbc:mysql://localhost:3306/demo";
private String user = "root";
private String password = "root";
public void test() {
try {
// 1.驱动
Driver driver = new com.mysql.jdbc.Driver();
// 设置用户名和密码
Properties props = new Properties();
props.setProperty("user", user);
props.setProperty("pwd", password);
// 2.连接数据库
Connection conn = driver.connect(url, props);
System.out.println(conn);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
--》优化做法(封装成一个工具类)
public class JdbcUtil {
private static String url = "jdbc:mysql:///jdbc_demo";
private static String user = "root";
private static String password = "root";
public static Connection conn;
public static Statement stat;
public static ResultSet rs;
// 连接
public static Connection getConnection(){
try {
//注册驱动
Class.forName("com.mysql.jdbc.Driver");
// 连接数据库
return DriverManager.getConnection(url,user,password);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
public static void close(){
try {
if (rs != null){
rs.close();
rs = null;
}
if (stat != null){
stat.close();
stat=null;
}
if (conn != null){
conn.close();
conn=null;
}
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}
JDBC总结(含DbUtils组件)的更多相关文章
- BenUtils组件和DbUtils组件
BenUtils组件和DbUtils组件 [TOC] 1.BenUtils组件 1.1.简介 程序中对javabean的操作很频繁,所有Apache提供了一套开源api,方便javabean的操作!即 ...
- DbUtils组件
DbUtils组件 DbUtils组件, 1. 简化jdbc操作 2. 下载组件,引入jar文件 : commons-dbutils-1.6.jar |-- DbUtils 关闭资源.加载驱动 |-- ...
- .NET开发邮件发送功能的全面教程(含邮件组件源码)
今天,给大家分享的是如何在.NET平台中开发“邮件发送”功能.在网上搜的到的各种资料一般都介绍的比较简单,那今天我想比较细的整理介绍下: 1) 邮件基础理论知识 2) ...
- 如何在JDBC Connection Configuration配置组件上添加控件
如何在JDBC Connection Configuration配置组件上添加控件 最近项目刚上线,闲来无事又把Jmeter的源码拿出来研究研究,最初的目的是想扒一扒Jmeter里数据库处理的逻辑是怎 ...
- 【JDBC&Dbutils】JDBC&JDBC连接池&DBUtils使用方法(重要)
-----------------------JDBC---------- 0. db.properties文件 driver=com.mysql.jdbc.Driver url=jdbc: ...
- JDBC连接池&DBUtils使用
使用连接池改造JDBC的工具类: 1.1.1 需求: 传统JDBC的操作,对连接的对象销毁不是特别好.每次创建和销毁连接都是需要花费时间.可以使用连接池优化的程序. * 在程序开始的 ...
- JDBC 学习笔记(四)—— 自定义JDBC框架+Apache—DBUtils框架+事务管理+操作多表
本文目录: 1.自定义JDBC框架 ——数据库元数据:DataBaseMetaData 2.自定义JDBC框架 ——数据库元数据:DataBaseMetaData ...
- 开源JDBC工具类DbUtils
本篇将会详细地介绍Apache公司的JDBC帮助工具类DbUtils以及如何使用.在上一篇中我们已经通过将以前对dao层使用JDBC操作数据库的冗余代码进行了简易封装形成自己的简单工具类JdbcUti ...
- Junit 注解 类加载器 .动态代理 jdbc 连接池 DButils 事务 Arraylist Linklist hashset 异常 哈希表的数据结构,存储过程 Map Object String Stringbufere File类 文件过滤器_原理分析 flush方法和close方法 序列号冲突问题
Junit 注解 3).其它注意事项: 1).@Test运行的方法,不能有形参: 2).@Test运行的方法,不能有返回值: 3).@Test运行的方法,不能是静态方法: 4).在一个类中,可以同时定 ...
随机推荐
- linux关闭双显卡的方法
我正在使用的一体机是双显卡,在linux下没有很么太好的办法来切换双显卡, 导致使用一会儿后就发烫,关键是这时风扇呜呜的响很吵人 最后找到了下面的解决方法来关掉独立显卡 见 https://githu ...
- java图书管理的一个小模块(增删改查,不使用数据库)
图书管理模块:某图书管需要对图书进行信息化管理,要求管理员能够进行新增图书,能按照书名进行模糊查看图书能进行价格统计 系统实现如下:1.新增2.查询3.统计价格 1请输入新书:图书号,书名,作者,价格 ...
- qt qml qchart 图表组件
qt qml qchart 图表组件 * Author: Julien Wintz * Created: Thu Feb 13 23:41:59 2014 (+0100) 这玩意是从chart.js迁 ...
- Hibernate设置自增
hibernate设置自增,在映射生成的实体类中需要实现Serializable接口 public class GWgDyEntity implements Serializable { //在主键上 ...
- Welogic中的JMS
WebLogic JMS 概述 企业消息传递系统使得应用程序能够通过消息的交换与其他系统之间进行通信.消息是包含协调不同应用程序之间通信所需信息的请求.报告和/或事 件.消息提供了提取级别,使您能够从 ...
- android微信支付总结+自己搭建服务器
1.前期注册操作 1-1:微信开发平台:https://open.weixin.qq.com/ 1-2:创建移动应用 签名获取: 1.将自己的apk签名打包,运行到手机上. 2.将微信支付的签名工具, ...
- 在mac电脑上创建java的一些简单操作
首先你要在电脑上下载一个JDK创造出一个java环境 如下第二个: 然后步奏如下: step1:苹果->系统偏好设置->最下边点MySQL 在弹出页面中 关闭mysql服务(点击stop ...
- easyui DataGrid 工具类之 util js
var jq; var tab; var tabsIndex; /** ...
- jQuery validation学习(1)验证只输入空格通过验证
当input输入了空格是不会提示信息的 一般会去除空格然后进行验证 这个时候就要添加onkeyup事件去除左侧的空格 验证只输入空格通过验证 //添加验证手机方法 jQuery.validator.a ...
- Linux之RHEL6的开机流程分析
开机——很多人觉得很简单的事情,只要按下电源开关,然后系统就会自然启动,没有什么需要学习的.其实不然,如果系统没有什么问题,可以正常登陆的时候,当然开机很简单.但更多的时候,我们需要知道当机子不能正常 ...