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;
}
}
分享到:
相关推荐
④实现了通用的sql语句执行帮助类(包含单条数据的插入、批量插入、事务处理、查询(指定内容查询、分页查询)、更新、删除等操作); ⑤可以直接获取Sqlite数据库中的所有表名称及其表包含的所有列名称; ⑥包含了...
为实现上述目的,本技术提供了如下技术方案: 一种通用的数据库迁移适配方法,该方法包括以下步骤: S1、匹配规则定义库:定义DDL规则、DML规则的基本操作,指导源数据库模板进行编写; S2、模板池来存储已实现规则...
涵盖了大部分管理系统的内容,可以当做实现这类系统的通用模板,适用于期末课程设计。 主要功能 本超市仓库管理系统,通过对数据库的查询,能够实现系统登录以及对商品与用户信息的增删改查操作。支持多用户多身份...
Access绑定combox,datagridview,treeview.treeview根据数据库动态生成树。完整的登录界面代码。代码里有详细的注释。使用的是VS2010及office2007。...此模板可套用到很多应用程序开发中。亲们!感觉好记得给好评哟!!!
基于PHP + MySQL实现的文章内容管理系统源码+数据库,采用前后端分离的模板和标签化方式.zip通用的文章内容管理系统,采用前后端分离的模板和标签化方式,支持文章内容管理、栏目分类管理、评论管理、友情链接管理、...
一个简单的KV数据库,基于C++实现C++是一种广泛使用的编程语言,它是由Bjarne Stroustrup于1979年在新泽西州美利山贝尔实验室开始设计开发的。C++是C语言的扩展,旨在提供更强大的编程能力,包括面向对象编程...
SpringBoot 的通用管理系统,包含了登陆注册、用户管理、部门管理、文件管理、权限管理、日志管理、个人中心、数据字典和代码生成**这九个功能模块,另外还有两张样例数据表和五张样例数据图,是一个很好的前后端...
毕业设计,基于SpringBoot+Vue+MySql开发的前后端分离的通用管理系统开发模板,内含Java完整源代码,数据库脚本 本软件是基于 Vue 和 SpringBoot 的前后端分离开发模板,包含了登陆注册、用户管理、部门管理、文件...
在工作中,经常中与数据库层打交道,所以,我一般用一个数据库实体类来代码来进行相应的操作. 而CodeSmith则是一个功能强大的代码生成模板系统,用它可以非常快的写出你自己的模板
自己制作的在netbean中的jsp+数据库通用类+serverlet+access实现验证登陆的功能模板,可以节省网站开发的时间。
可定义函数模板和类模板,使代码生成更加通用化。 说明:这需要事先安装.net framework 3.5 。这个完全出自本人之手。有什么建议望指正。 邮箱:hp_co@qq.com 。 类似于李天平的,但那个太死了,这个可以...
可定义函数模板和类模板,使代码生成更加通用化。 说明:这需要事先安装.net framework 3.5 。这个完全出自本人之手。有什么建议望指正。 邮箱:hp_co@qq.com 。 类似于李天平的,但那个太死了,这个可以...
秉承网软志成分类网独创的模板和数据库体系以及专业的代码设计保证了网软志成分类信息网系统的持续高效和稳定。 卓越的负载能力 网软志成分类信息系统核心参数的合理配置,专业的web 、数据库、附件和图片链的负载...
个通用的文章内容管理系统,采用前后端分离的模板和标签化方式,支持文章内容管理、栏目分类管理、评论管理、友情链接管理、碎片管理、远程图片获取器等功能。可以使用本系统很轻松地架构新闻类网站、文章类网站、...
本系统还封装了文件管理功能,在其他模块如若要实现图片/文件上传预览时,前端只需导入现成的 Vue 组件即可实现(使用 viewerjs 依赖实现),后端只需定义 String 类型的实体类变量即可,无需再去研究文件上传预览的...
通用类的类文件总体上分为两大类:基础类和扩展类 基础类包括: Class_PublicFunction.asp 常用公共函数库 Class_Application.asp Application封装库 Class_Session.asp Session封装库 Class_Conn.asp 数据库...
C++ STL (Standard Template Library标准模板库) 是通用类模板和算法的集 合,它提供给程序员一些标准的数据结构的实现
NoSQL数据库:NoSQL数据库(如MongoDB、Cassandra等)则更适用于处理这类数据。 数据仓库:数据仓库是一个用于集成和分析大规模数据的存储系统,一些知名的数据仓库包括Snowflake、Amazon Redshift等。 数据湖:...
NoSQL数据库:NoSQL数据库(如MongoDB、Cassandra等)则更适用于处理这类数据。 数据仓库:数据仓库是一个用于集成和分析大规模数据的存储系统,一些知名的数据仓库包括Snowflake、Amazon Redshift等。 数据湖:...