首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
数据库
> 详细
java操作数据库的通用的类
时间:
2015-08-10 23:50:15
阅读:
507
评论:
0
收藏:
0
[点我收藏+]
标签:
package cn.dao;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.math.BigDecimal;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
/**
* 数据库操作通用类
* @author tip
*/
public
class DBHelp {
private Connection con;
private PreparedStatement ps;
private ResultSet rs;
static Readdoc td =
new Readdoc();
//读取XML文件中的数据库连接参数
static {
try {
Class.forName(td.getDriver());
}
catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
public Connection getCon()
throws SQLException {
con = DriverManager.getConnection(
"jdbc:oracle:thin:@" + td.getAdd()
+
":1521:" + td.getDb(), td.getUname(), td.getPwd());
return con;
}
public <T> List<T> findBySql(String sql, List<String> params, Class<T> c)
throws SQLException {
List<T> list =
new ArrayList<T>();
// 取出c的这个对象中有多少个方法
Method[] ms = c.getMethods();
con =
this.getCon();
try {
ps = con.prepareStatement(sql);
this.doParams(ps, params);
rs = ps.executeQuery();
// 得到db中的表的列
ResultSetMetaData rsmd = rs.getMetaData();
// 存储全部的列名
String[] columnname =
new String[rsmd.getColumnCount()];
for (
int i =
0; i < columnname.length; i++) {
columnname[i] = rsmd.getColumnName(i +
1);
}
// id=> "set"+"I"+d=> "setId()" =>对应数据库表的字段
while (rs.next()) {
// new对象
T t = c.newInstance();
// Topic t=new Topic();
// t.setId(rs.getInt("id"));
for (
int i =
0; i < columnname.length; i++) {
String cn = columnname[i];
// id title contents
cn =
"set" + cn.substring(
0,
1).toUpperCase()
+ cn.substring(
1).toLowerCase();
// "setId"
for (Method m : ms) {
if (m.getName().equals(cn)) {
if (rs.getObject(columnname[i]) !=
null) {
if (
"java.sql.Timestamp".equals(rs.getObject(columnname[i]).getClass().getName())) {
m.invoke(t, rs.getString(columnname[i]));
}
else
if (
"java.lang.Integer".equals(rs.getObject(columnname[i]).getClass().getName())) {
m.invoke(t, rs.getInt(columnname[i]));
}
else {
m.invoke(t, rs.getObject(columnname[i]));
}
}
else {
m.invoke(t, rs.getObject(columnname[i]));
}
break;
}
}
}
list.add(t);
}
}
catch (IllegalArgumentException e) {
e.printStackTrace();
}
catch (SQLException e) {
e.printStackTrace();
}
catch (InstantiationException e) {
e.printStackTrace();
}
catch (IllegalAccessException e) {
e.printStackTrace();
}
catch (InvocationTargetException e) {
e.printStackTrace();
}
finally {
closeAll(rs, ps, con);
}
return list;
}
// insert into xx values(?,?); params={"tip","whx"};
public <T>
int doUpdate(String sql, List<T> params)
throws SQLException {
con =
this.getCon();
int i =
0;
try {
ps = con.prepareStatement(sql);
doParams(ps, params);
i = ps.executeUpdate();
}
catch (SQLException e) {
try {
con.rollback();
}
catch (SQLException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
finally {
closeAll(
null, ps, con);
}
return i;
}
// 设置预编译对象参数
public <T>
void doParams(PreparedStatement pstmt, List<T> params)
throws SQLException {
if (pstmt !=
null && params !=
null && params.size() >
0) {
for (
int i =
0; i < params.size(); i++) {
if (params.get(i) !=
null) {
if (params.get(i).getClass().getName().equals(
"java.lang.String")) {
pstmt.setString(i +
1, (String) params.get(i));
}
else
if (params.get(i).getClass().getName()
.equals(
"java.math.BigDecimal")) {
pstmt.setBigDecimal(i +
1, (BigDecimal) params.get(i));
}
else
if (params.get(i).getClass().getName().equals(
"java.sql.Timestamp")) {
pstmt.setString(i +
1, (String) params.get(i));
}
else {
pstmt.setObject(i +
1, params.get(i));
}
}
else {
pstmt.setString(i +
1,
"");
}
}
}
}
public
void closeAll(ResultSet rs, PreparedStatement pstmt, Connection con) {
if (rs !=
null) {
try {
rs.close();
}
catch (SQLException e) {
e.printStackTrace();
}
}
if (pstmt !=
null) {
try {
pstmt.close();
}
catch (SQLException e) {
e.printStackTrace();
}
}
if (con !=
null) {
try {
con.close();
}
catch (SQLException e) {
e.printStackTrace();
}
}
}
}
java操作数据库的通用的类
标签:
原文地址:http://www.cnblogs.com/SZ2015/p/4719491.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
数据库进阶
2021-07-29
在 Oracle 数据库中执行 SQL 语句遇到特殊字符的转义方式
2021-07-28
Windows Logstash同步 Sqlserver 到Elasticsearch
2021-07-26
mysql数据库(11):恢复数据
2021-07-26
mysql数据库(9):常用查询的例子
2021-07-26
SQLAlchemy 多对多
2021-07-26
ClickHouse的JDBC连接
2021-07-26
Apache HBase 1.7.1 发布,分布式数据库
2021-07-26
数据库常用架构和同步工作原理
2021-07-26
MySQL数据库设计规范(仅供参考)
2021-07-26
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!