`
yunchow
  • 浏览: 324403 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

数据库通用模板类实现

    博客分类:
  • DBI
阅读更多
package com.yunchow.util;

import java.util.*;
import java.sql.*;

/**
 * jdbc操作模板
 * @author yunchow
 * @version 1.2  09/8/5
 */
final public class JdbcTemplate {
	
	/**
	 * 统计指定表的记录条数
	 * @param tabName 表名
	 * @return 记录条数
	 */
	public int count(String tabName) {
		return count(tabName, null);
	}
	/**
	 * 按条件查询记录条数
	 * @param tabName 表名
	 * @param sqlwhere 条件
	 * @return 记录条数
	 */
	public int count(String tabName, String sqlwhere) {
		String sql = "select count(*) from " + tabName ;
		if(sqlwhere!=null && !"".equals(sqlwhere.trim())) {
			sql += " where " + sqlwhere;
		}
		return find(sql, new RowMapper<Integer>(){
				
				public Integer mapperRow(ResultSet rs) throws SQLException {
					return rs.getInt(1);
				}
				
			});
	}
	/**
	 * 执行批量更新
	 * @param sqls sql语句数组,其中每个sql子句只支持statement格式的,
	 *		  不支持preparedStatement格式,必须自已将参数拼装好再传过来.
	 * @return 所影响的行数
	 */
	public int[] updateBatch(String[] sqls) {
		Connection conn = null;
		Statement stmt = null;
		int[] rtn = null;
		try {
			conn = JdbcUtils.getConnection();
			stmt = conn.createStatement();
			conn.setAutoCommit(false);
			if(sqls!=null && sqls.length>0) {
				for(String sql : sqls)
				{
					stmt.addBatch(sql);
					//System.out.println(sql);
				}
			}
			rtn = stmt.executeBatch(); // 批量执行
			conn.commit();
			conn.setAutoCommit(true); // 此句必不可少,不然会引发死锁现象
		} catch(Exception ex) {
		   ex.printStackTrace();
			rtn = null;
			try{
				conn.rollback();
			} catch(SQLException e){
			  e.printStackTrace();
				// ignore the rollback exception
			}
			throw new RuntimeException(ex);
		} finally {
			JdbcUtils.close(stmt, conn);
		}
		return rtn;
	}
	/**
	 * 查询一个对象的集合
	 * @param sql sql语句,必须符合PreparedStatement格式
	 * @param params 为sql语句准备的参数,必须与sql中的?号一一对应
	 * @param mapper 行映射器,将结果集映射到特定的类
	 * @return T 查询结果的java bean风格类封装的集合
	 */
	public <T> List<T> findList(String sql, RowMapper<T> mapper, Object... params) {
		Connection conn = null;
		PreparedStatement ps = null;
		ResultSet rs = null;
		List<T> list = new ArrayList<T>();
		try {
			
			conn = JdbcUtils.getConnection();
			ps = conn.prepareStatement(sql);
			if(params!=null && params.length>0) {
				for(int i=0; i<params.length; i++){
					ps.setObject(i+1, params[i]);
				}
			}
			rs = ps.executeQuery();
			while(rs.next()) { 
				list.add(mapper.mapperRow(rs));
			}
		} catch(SQLException ex) {
			throw new RuntimeException(ex.getMessage(), ex);
		} finally {
			//System.out.println("JdbcTemplate: close()");
			JdbcUtils.close(rs, ps, conn);
		}
		return list;
	}
	/**
	 * 查询一个对象
	 * @param sql sql语句,必须符合PreparedStatement格式
	 * @param params 为sql语句准备的参数,必须与sql中的?号一一对应
	 * @param mapper 行映射器,将结果集映射到特定的类
	 * @return T 查询结果的java bean风格类封装
	 */
	public <T> T find(String sql, RowMapper<T> mapper, Object... params) {
		List<T> list = findList(sql, mapper, params);
		if(list!=null && list.size()>0){
			return list.get(0);
		}
		return null;
	}
	/**
	 * 支持所有更新操作 增,删,改
	 * @param sql 传过来的sql语句,其中的参数用?代替
	 * @param params 传过来的参数信息, 必须与sql中的问号相对应
	 * @return  更新的行数
	 */
	public int update(String sql, Object... params) {
		return update(sql, false, params);
	}
	/**
	 * 添加信息,并返回自动生成的主键
	 * @param sql 传过来的sql语句,其中的参数用?代替
	 * @param params 传过来的参数信息, 必须与sql中的问号相对应
	 * @return int 主键值
	 */
	public int save(String sql, Object... params) {
		return update(sql, true, params);
	}
	/**
	 * 支持所有更新操作,增,删,改
	 * @param sql 传过来的sql语句,其中的参数用?代替
	 * @param params 传过来的参数信息, 必须与sql中的问号相对应
	 * @param boo 为true获取自动生成的主键,否则忽略
	 * @return true 更新成功
	 */
	protected int update(String sql, Boolean boo, Object... params) {
		Connection conn = null;
		PreparedStatement ps = null;
		ResultSet rs = null;
		int rtn = -1;
		try {
			conn = JdbcUtils.getConnection();
			ps = boo?conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS):conn.prepareStatement(sql);
			if(params!=null && params.length>0) { //有参数传过来才设置参数
				for(int i=0; i<params.length; i++) {
					ps.setObject(i+1, params[i]);
				}
			}
			rtn = ps.executeUpdate();
			// 获取主键
			if(boo) {
				rs = ps.getGeneratedKeys();
				if(rs.next()) {
					rtn = rs.getInt(1);
				}
			}
		} catch(SQLException ex) {
			throw new RuntimeException(ex);
		} finally {
			JdbcUtils.close(ps, conn);
		}
		return rtn;
	}
	
	
} 
分享到:
评论

相关推荐

    jsp连接数据库通用类

    这个"jsp连接数据库通用类"旨在为各种JSP应用提供一个标准的方式来访问和操作数据库,无论何时需要进行数据库交互,都可以便捷地调用此类。 通用数据库连接类通常包含以下几个核心组件和功能: 1. **配置信息**:...

    MFC数据库基类模板

    MFC数据库基类模板是开发者常用的一种工具,它帮助程序员快速地创建数据库相关的类,以实现对数据库的增、删、改、查等基本操作,从而避免重复编写大量繁琐的代码。 MFC数据库支持的主要库有两个:ODBC(Open ...

    网站数据库模板_拿来即用_通用网站数据库模板_

    一个通用的网站数据库模板能够适应多种类型的网站需求,无论是电子商务、博客、论坛还是新闻资讯类网站,都能找到适用的数据库设计。这样的模板通常包含了对用户信息、文章、评论、商品、订单等常见数据实体的表结构...

    多种 数据库通用类 通用sql语句拼接 通用各种数据库功能的操作

    在IT行业中,数据库是存储和管理数据的核心工具,而数据库通用类和通用SQL语句的拼接技术则是实现跨数据库平台高效开发的关键。本话题主要围绕如何设计和使用这些技术来实现不同数据库系统的增删改查操作、事务管理...

    MySql数据库CodeSmith模板

    4. **生成代码**:运行模板,CodeSmith会根据数据库中的表信息自动生成对应的代码文件,这些文件可能包括C#的实体类、接口、实现类,或者其他你定制的代码格式。 5. **整合到项目**:最后,将生成的代码文件导入到...

    Java数据库连接+操作(模板方法模式应用)

    在数据库操作中,我们可以定义一个抽象类,包含通用的增删改查方法,然后由具体的数据库操作类继承并实现这些方法。 例如,我们可以定义一个`DatabaseOperation`抽象类,包含如下模板方法: ```java public ...

    使用设计模式构建通用数据库访问类.

    本文将围绕“使用设计模式构建通用数据库访问类”这一主题,深入探讨如何通过抽象基类与继承机制,结合具体的设计模式,如工厂模式和策略模式,来创建一个灵活且高效的数据库访问层。 ### 设计模式的重要性 设计...

    通用数据库连接类(配置文件)

    本文将详细介绍如何使用提供的“通用数据库连接类(配置文件)”来实现灵活的数据库访问。这个工具类集成了多种常见数据库(如SQLServer、Oracle、MySQL)的支持,使得开发者无需修改源代码,只需调整配置文件即可...

    一个通用的数据库分页类

    这里提到的"一个通用的数据库分页类",很可能是PHP中设计的一个可复用的分页组件,用于简化数据库查询的分页逻辑。在PHP开发中,这样的类通常会包含一些核心功能,如计算总页数、获取当前页数据、设置和获取每页记录...

    java连接sql数据库的通用类

    在Java编程中,连接SQL数据库是一项基础且重要的任务。这里我们关注的是一个名为...同时,这个类也可以作为模板,根据不同的数据库类型进行适当的修改,实现对其他类型数据库(如MySQL、Oracle等)的支持。

    JavaEE需牢记的模板类

    例如,你可以为每个数据库操作创建一个DAO工厂,根据传入的参数动态地返回相应的DAO实例,这些DAO可以是基于模板类的,从而实现对多种数据库的支持。 总的来说,JavaEE中的模板类是一个强大的工具,它有助于我们...

    C#通用数据库操作类库

    - `BaseSqlMapDao.cs`:基础SQL映射数据访问对象类,可能是用于存储和执行SQL语句的模板类。 - `DbConfig.cs`:数据库配置类,通常包含数据库连接字符串和其他配置信息。 - `DBActivator.cs`:数据库激活器类,...

    SpringBoot集成MyBatis-Plus实现国产数据库适配.docx

    SpringBoot 集成 MyBatis-Plus 实现国产数据库适配 MyBatis-Plus 是一款在 MyBatis 的基础上进行扩展的开源工具包,只做增强不做改变,引入 MyBatis-Plus 不会对您现有的 Mybatis 构架产生任何影响。MyBatis-Plus ...

    大数据Excel通过POI导入数据库通用设计方案

    【大数据Excel通过POI导入数据库通用设计方案】 大数据处理中,Excel作为常见的数据交换格式,其导入到数据库的需求频繁出现。为了提高效率并避免重复工作,本方案旨在提供一种通用的Excel导入策略,利用Apache POI...

    用QT封装的操作各类数据库的接口类

    首先,`DBHelper`类是整个系统的中心,它负责提供与各种数据库交互的通用方法。在`DBHelper.cpp`和`DBHelper.h`中,我们可以找到这些接口的实现和声明。`DBHelper`类通常会包含连接数据库、执行SQL语句、获取结果集...

    c++模板存储类数据结构

    在C++中,这可以通过组合多个模板类来实现。例如,我们可以定义一个`Node`类,它包含一个`T`类型的值和一个`std::vector&lt;Storage&lt;T&gt;&gt;`子节点列表,这样就可以实现多层次的数据存储。 ```cpp template class Node {...

    JSP数据库通用模块开发与系统移植.rar

    本资源"JSP数据库通用模块开发与系统移植.rar"聚焦于如何利用JSP进行数据库交互,并提供了通用模块以简化开发过程和系统的移植。 首先,JSP与数据库的结合是Web应用开发中的核心部分,特别是对于那些需要存储和检索...

    PDM导出通用模板wordTemplate

    总的来说,"PDM导出通用模板wordTemplate"是一个高效的数据建模文档管理方法,它结合了PowerDesigner的强大功能和Word的易读性,对于IT行业的数据库设计和管理工作而言,是一个实用的工具。通过熟练掌握这类模板的...

    通用数据库万能查询控件

    1. **自定义查询字段**:用户可以根据需要选择数据库中的任何字段进行查询,无需预先设定特定的查询模板。这提高了查询的灵活性,适应了不同用户的需求。 2. **多条件组合**:控件支持多个查询条件的组合,可以实现...

    vc++实现反射式数据库模版(4.实现数据库模版)

    实现反射式数据库模板的关键在于构建一个能够解析和操作类元数据的系统。在C++中,由于语言本身并不支持内置的反射机制,我们需要利用预处理器宏、元编程技巧或者第三方库(如Boost.Serialization或Qt的meta-object...

Global site tag (gtag.js) - Google Analytics