JDBC操作数据库 封装好的工具类
mysql sqlserver oracle 数据库的驱动jar包
http://download.csdn.net/download/csdn576038874/8833683
package cn.hp.svse.jdbc; import java.sql.Connection;
import java.sql.SQLException; import javax.sql.DataSource; import com.mchange.v2.c3p0.ComboPooledDataSource; /**
* 使用本类的方法,必须提供c3p0-copnfig.xml文件
* @author qdmmy6
*/
public class JdbcUtils {
// 饿汉式
private static DataSource ds = new ComboPooledDataSource(); /**
* 它为null表示没有事务
* 它不为null表示有事务
* 当开启事务时,需要给它赋值
* 当结束事务时,需要给它赋值为null
* 并且在开启事务时,让dao的多个方法共享这个Connection
*/
private static ThreadLocal<Connection> tl = new ThreadLocal<Connection>(); public static DataSource getDataSource() {
return ds;
} /**
* dao使用本方法来获取连接
* @return
* @throws SQLException
*/
public static Connection getConnection() throws SQLException {
/*
* 如果有事务,返回当前事务的con
* 如果没有事务,通过连接池返回新的con
*/
Connection con = tl.get();//获取当前线程的事务连接
if(con != null) return con;
return ds.getConnection();
} /**
* 开启事务
* @throws SQLException
*/
public static void beginTransaction() throws SQLException {
Connection con = tl.get();//获取当前线程的事务连接
if(con != null) throw new SQLException("已经开启了事务,不能重复开启!");
con = ds.getConnection();//给con赋值,表示开启了事务
con.setAutoCommit(false);//设置为手动提交
tl.set(con);//把当前事务连接放到tl中
} /**
* 提交事务
* @throws SQLException
*/
public static void commitTransaction() throws SQLException {
Connection con = tl.get();//获取当前线程的事务连接
if(con == null) throw new SQLException("没有事务不能提交!");
con.commit();//提交事务
con.close();//关闭连接
con = null;//表示事务结束!
tl.remove();
} /**
* 回滚事务
* @throws SQLException
*/
public static void rollbackTransaction() throws SQLException {
Connection con = tl.get();//获取当前线程的事务连接
if(con == null) throw new SQLException("没有事务不能回滚!");
con.rollback();
con.close();
con = null;
tl.remove();
} /**
* 释放Connection
* @param con
* @throws SQLException
*/
public static void releaseConnection(Connection connection) throws SQLException {
Connection con = tl.get();//获取当前线程的事务连接
if(connection != con) {//如果参数连接,与当前事务连接不同,说明这个连接不是当前事务,可以关闭!
if(connection != null &&!connection.isClosed()) {//如果参数连接没有关闭,关闭之!
connection.close();
}
}
}
}
package cn.hp.svse.jdbc; import java.sql.Connection;
import java.sql.SQLException; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler; public class TxQueryRunner extends QueryRunner { //批量操作
@Override
public int[] batch(String sql, Object[][] params) throws SQLException {
Connection con = JdbcUtils.getConnection();
int[] result = super.batch(con, sql, params);
JdbcUtils.releaseConnection(con);
return result;
}
//带多个参数的查询
@Override
public <T> T query(String sql, ResultSetHandler<T> rsh, Object... params)
throws SQLException {
Connection con = JdbcUtils.getConnection();
T result = super.query(con, sql, rsh, params);
JdbcUtils.releaseConnection(con);
return result;
}
//不带参数的查询
@Override
public <T> T query(String sql, ResultSetHandler<T> rsh) throws SQLException {
Connection con = JdbcUtils.getConnection();
T result = super.query(con, sql, rsh);
JdbcUtils.releaseConnection(con);
return result;
}
//不带参数的增,删,改的操作
@Override
public int update(String sql) throws SQLException {
Connection con = JdbcUtils.getConnection();
int result = super.update(con, sql);
JdbcUtils.releaseConnection(con);
return result;
}
//带一个参数的增,删,改的操作
@Override
public int update(String sql, Object param) throws SQLException {
Connection con = JdbcUtils.getConnection();
int result = super.update(con, sql, param);
JdbcUtils.releaseConnection(con);
return result;
}
//带多个参数的增,删,改的操作
@Override
public int update(String sql, Object... params) throws SQLException {
Connection con = JdbcUtils.getConnection();
int result = super.update(con, sql, params);
JdbcUtils.releaseConnection(con);
return result;
}
}
package com.wenjie; 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.itcast.jdbc.JdbcUtils;
import cn.itcast.jdbc.TxQueryRunner; /**
* dao层要操作数据库
* 调用测试代码
* new一个 QueryRunner qr = new TxQueryRunner();
*
* qr.query(),qr.update()...所有的方法都是不需要获取连接的 因为在TxQueryRunner这个类中 每个方法都写了Connection con = JdbcUtils.getConnection();
* 获取连接所以调用方法时,无需再获取连接
* @author 00
*
*/
public class JdbcTest {
/**
* 添加
* 给stuinfo插入一条数据
* @throws Exception
*/
@Test
public void update1() throws Exception{
QueryRunner qr = new TxQueryRunner();
//sql语句
String sql = "insert into stuinfo(stuname,stuno,stuage,stuaddress,stuemail) values(?,?,?,?,?)";
//参数
Object[] params = {"aa","123","22","asdasd","asd@qq.com"};
qr.update(sql, params);
} /**
* 修改
* 把stuid=10020的学生的名字改为关凤
* @throws SQLException
*/
@Test
public void update2() throws SQLException{
String sql = "update stuinfo set stuname=? where stuid=?";
QueryRunner qr = new TxQueryRunner();
Object[] params = {"关凤","10020"};
qr.update(sql, params);
} /**
* 删除
* 将stuid=10021的学生删除掉
* @throws SQLException
*/
@Test
public void update3() throws SQLException{
String sql = "delete from stuinfo where stuid=?";
QueryRunner qr = new TxQueryRunner();
Object[] params = {"10021"};
qr.update(sql, params);
} /**
* 查询
* 根据id查询 一个参数的查询 查询出stuid=10000的学生的信息 这里query的第二个参数要为BeanHandler<User>(User.class)
* 因为查询出来必是一个对象 最后加上参数param
* @throws SQLException
*/
@Test
public void query1() throws SQLException{
String sql = "select * from stuinfo where stuid=?";
QueryRunner qr = new TxQueryRunner();
Object param = 10000;
User user = qr.query(sql, new BeanHandler<User>(User.class),param);
System.out.println(user);
} /**
* 查询所有
* query的第二个参数要为BeanListHandler<User>(User.class) 查询多月没有参数
* @throws SQLException
*/
@Test
public void query2() throws SQLException{
String sql = "select * from stuinfo";
QueryRunner qr = new TxQueryRunner();
List<User> users = qr.query(sql, new BeanListHandler<User>(User.class));
for (int i = 0; i < users.size(); i++) {
System.out.println(users.get(i));
}
} /**
* 根据id查询 吧查询出来的结果映射成map对象 如果是单表操作的话 MapHandler和BeanHandler没有区别
* 但是如果你要操作的表 与其他表有外键关系的话 用BeanHandler那么外键就映射不到为空值
* 你必须先用MapHandler 然后得到所有的列的数据 然后再转换成实体 这个大家自己试试就知道了
* @throws SQLException
*/
@Test
public void query3() throws SQLException{
String sql = "select * from stuinfo where stuid=?";
QueryRunner qr = new TxQueryRunner();
Object param = 10001;
Map<String, Object> map = qr.query(sql, new MapHandler(),param);
System.out.println(map);
} @Test
public void query4() throws SQLException{
String sql = "select * from stuinfo";
QueryRunner qr = new TxQueryRunner();
List<Map<String, Object>> mapList = qr.query(sql, new MapListHandler());
for (int i = 0; i < mapList.size(); i++) {
System.out.println(mapList.get(i));
}
} /**
* 查询记录数
* 用ScalarHandler得到一个对象 转换成Number对象 再用number.intValue()返回int类型的值
* @throws SQLException
*/
@Test
public void query5() throws SQLException{
String sql = "select count(*) from stuinfo";
QueryRunner qr = new TxQueryRunner();
Number number = (Number) qr.query(sql, new ScalarHandler());
int i = number.intValue();
System.out.println(i);
} /**
* 批量删除
* @throws SQLException
*/
@Test
public void query6() throws SQLException{
String sql = "delete from stuinfo where stuid=?";
Object params[][] = {{"10020"},{"10024"},{"10022"},{"10023"}};
QueryRunner qr = new TxQueryRunner();
qr.batch(sql, params);
} /**
* 事物操作
* @throws SQLException
*/
@Test
public void query7() throws SQLException{
try {
//直接调用写好的jdbcUtils帮助类
JdbcUtils.beginTransaction();//开启事物
//修改第一个表的一条数据
//被事物包含的操作 如果有异常 事物就会回滚 量表的数据都没发生改变
//修改第二条表的数据
JdbcUtils.commitTransaction();//两条语句都执行成功后 提交事物
} catch (SQLException e) {
try {
JdbcUtils.rollbackTransaction();
} catch (SQLException e1) {
e1.printStackTrace();
}
} } }
//数据库连接的配置文件 必须放在src目录下面 而且名字必须为c3p0-config.xml 以下是以mysql为例 oracle sqlserver都可以 只要提供相应的驱动jar包即可
<?xml version="1.0" encoding="UTF-8" ?>
<c3p0-config>
<default-config>
<property name="jdbcUrl">jdbc:mysql://localhost:3306/mydb1</property>
<property name="driverClass">com.mysql.jdbc.Driver</property>
<property name="user">root</property>
<property name="password">123</property> <property name="acquireIncrement">3</property>
<property name="initialPoolSize">10</property>
<property name="minPoolSize">2</property>
<property name="maxPoolSize">10</property>
</default-config>
</c3p0-config>
JDBC操作数据库 封装好的工具类的更多相关文章
- PHP中将对数据库的操作,封装成一个工具类以及学会使用面向对象的方式进行编程
<?php class SqlTool { //属性 private $conn; private $host="localhost"; private $user=&quo ...
- 用于JDBC操作数据库的公共类
/* * @(#)CommonSql.java 2011-9-5 * * Copyright 2011 Bianjing,All rights reserved. */ import java.sql ...
- Redis操作Hash工具类封装,Redis工具类封装
Redis操作Hash工具类封装,Redis工具类封装 >>>>>>>>>>>>>>>>>> ...
- Redis操作字符串工具类封装,Redis工具类封装
Redis操作字符串工具类封装,Redis工具类封装 >>>>>>>>>>>>>>>>>>& ...
- JDBC操作数据库的学习(2)
在上一篇博客<JDBC操作数据库的学习(1)>中通过对例1,我们已经学习了一个Java应用如何在程序中通过JDBC操作数据库的步骤流程,当然我们也说过这样的例子是无法在实际开发中使用的,本 ...
- 免费IP代理池定时维护,封装通用爬虫工具类每次随机更新IP代理池跟UserAgent池,并制作简易流量爬虫
前言 我们之前的爬虫都是模拟成浏览器后直接爬取,并没有动态设置IP代理以及UserAgent标识,本文记录免费IP代理池定时维护,封装通用爬虫工具类每次随机更新IP代理池跟UserAgent池,并制作 ...
- Java基础之原生JDBC操作数据库
前言 日常开发中,我们都习惯了使用ORM框架来帮我们操作数据库,本文复习.记录Java如何使用原生JDBC操作数据库 代码编写 封装几个简单方法 find查询方法 findOne查询方法 update ...
- JDBC操作数据库的学习(1)
单单对数据库的操作,比如说MySQL,我们可以在命令行窗口中执行,但是一般是应用程序要操作数据库,因此我们应该在程序中的代码上体现对数据库的操作,那么使用程序应用如何操作数据库呢?那就要使用到数据库的 ...
- JDBC操作数据库的三种方式比较
JDBC(java Database Connectivity)java数据库连接,是一种用于执行上sql语句的javaAPI,可以为多种关系型数据库提供统一访问接口.我们项目中经常用到的MySQL. ...
随机推荐
- 【POJ 3162】 Walking Race (树形DP-求树上最长路径问题,+单调队列)
Walking Race Description flymouse's sister wc is very capable at sports and her favorite event is ...
- QString的不常见用法
QString str("Hello"); QString str = "Hello"; static const QChar data[4] = { 0x00 ...
- 一起啃PRML - 1.2.2 Expectations and covariances 期望和协方差
一起啃PRML - 1.2.2 Expectations and covariances 期望和协方差 @copyright 转载请注明出处 http://www.cnblogs.com/chxer/ ...
- Hash Killer I II
题意大概: 1.字符串hash不取模,自动溢出 构造数据卡这种hash 2.字符串hash取模1000000007,构造数据卡这种hash 题解传送门:VFleaKing http://vfleak ...
- ES2015 (ES6)
是时候使用ES 2015了 你可能不再需要Underscore BABEL Grunt 先 babel 再用 babel 后的文件 uglify 去掉严格模式.严格模式下全局的this转成了undef ...
- 清理ms sql server 大日志文件数据
1.手动分离数据库: 2.手动删除日志文件: 3.重新生成日志文件: CREATE DATABASE FMIS0 ON (FILENAME = 'E:\FMIS0_DATA\FMIS0-Date') ...
- 【转】关于Certificate、Provisioning Profile、App ID的介绍及其之间的关系
原文网址:http://www.cnblogs.com/cywin888/p/3263027.html 刚接触iOS开发的人难免会对苹果的各种证书.配置文件等不甚了解,可能你按照网上的教程一步一步的成 ...
- 【转】Android4.4(MT8685)源码蓝牙解析--BLE搜索
原文网址:http://blog.csdn.net/u013467735/article/details/41962075 BLE:全称为Bluetooth Low Energy.蓝牙规范4.0最重要 ...
- MD5Helper辅助类
DES加密和解密 public class MD5Helper { ///DES加密 ///sKey public string MD5Encrypt(string pToEncrypt, strin ...
- 用户故事(User Story)
摘要: 一件用户通过系统完成他一个有价值的目标(买一罐饮料)的事.这样的过程就叫“用户案例(user case)”或者“用户故事(user story)”.本文描述了敏捷开发的技巧:如何以用户故事管理 ...