jdbc完美封装-传入类型返回bean或者list集合
liuian 2025-05-27 15:53 42 浏览
程序员打交道最多的还是数据库。一般我们会选择各种各样的框架,其对数据库的操作完全封装了,但是有些小 项目,小网站什么的用框架又太小题大作了,还有就是入门的程序员需要了解jdbc的过程。所以小编自己封装了这个jdbc,就当小框架用吧,第一次写,还请朋友们多指点。
废话不多说,上图。
1.采用数据库连接池的
使用数据库连接池的
package com.zhumeng.util;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.sql.DataSource;
/**
* @author 刘鹏 功能:jdbc连接工具类
* jdbc的简单封装
* */
public class MyConnection {
private static Connection conn =null;// 数据库连接
private static PreparedStatement ps =null;// 预编译声明
private static ResultSet rs =null;// 结果集
/**
* 获取数据库连接
*
* @return Connection
*/
public static Connection getConnection() {
try{
Context c =newInitialContext();
DataSource ds = (DataSource)c.lookup("java:comp/env/jdbc/mysql");
conn = ds.getConnection();
// conn = DriverManager.getConnection(url, user, password);
}catch(Exception e) {
e.printStackTrace();
thrownewRuntimeException("获取链接对象connection出现错误");
}
returnconn;
}
/**
* 获得预编译声明
* */
public static PreparedStatement getPreparedStatement(String sql) {
getConnection();// conn实例化
try{
ps = conn.prepareStatement(sql);
}catch(SQLException e) {
// e.printStackTrace();
thrownewRuntimeException("获取预编译对象PreparedStatement出现错误");
}
returnps;
}
/**
* 执行查找,单个或者多个查找都可以返回List<Map<String, Object>>试用于网站
*
* @return List<Map<String, Object>>
* */
// public static List<Map<String, Object>> find(String sql, Object... obj) {
// // 定义一个list,用来存放resultset的数据,map即一result的某一行的数据,即存的一个对象
// List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
// getPreparedStatement(sql);// 实例化预编译对象ps
// try {
// if (obj.length > 0) {// 如果obj有数据,即有传来的参数
// for (int i = 0; i < obj.length; i++) {// 循环把参数 赋给预编译的声明
// ps.setObject(i + 1, obj[i]);
// }
// }
// rs = ps.executeQuery();
// ResultSetMetaData metaDate = rs.getMetaData();// 获得结果集的元数据
// int colsNum = metaDate.getColumnCount();// 获取查询的列数
//
// while (rs.next()) {
// Map<String, Object> map = new HashMap<String, Object>();//
// 定义一个map用来存放结果集的某一行的数据
// for (int i = 0; i < colsNum; i++) {
// String colsName = metaDate.getColumnName(i + 1);// 获得列名
// Object colsValue = rs.getObject(colsName);// 获得列值
// if (colsValue == null) {// 如果或的列值为空,赋值为空字符串
// colsValue = "";
// }
// map.put(colsName, colsValue);// 保存为键值对
// }
// list.add(map);// 添加到list集合
// }
//
// } catch (Exception e) {
// // e.printStackTrace();
// throw new RuntimeException("查询时出现错误");
// } finally {
// closeAll();
// }
// return list;
// }
public static <T> List<T> find(T javaBean, String sql, Object... obj) {
// 定义一个list,用来存放resultset的数据,map即一result的某一行的数据,即存的一个对象
List<Map<String, Object>> mapList =newArrayList<Map<String, Object>>();
getPreparedStatement(sql);// 实例化预编译对象ps
try{
if(obj.length > 0) {// 如果obj有数据,即有传来的参数
for(int i = 0; i < obj.length; i++) {// 循环把参数 赋给预编译的声明
ps.setObject(i + 1, obj[i]);
}
}
rs = ps.executeQuery();
ResultSetMetaData metaDate = rs.getMetaData();// 获得结果集的元数据
int colsNum = metaDate.getColumnCount();// 获取查询的列数
while(rs.next()) {
Map<String, Object> map =newHashMap<String, Object>();// 定义一个map用来存放结果集的某一行的数据
for(int i = 0; i < colsNum; i++) {
String colsName = metaDate.getColumnName(i + 1);// 获得列名
Object colsValue = rs.getObject(colsName);// 获得列值
// if (colsValue == null) {// 如果或的列值为空,赋值为空字符串
// colsValue = "";
// }
map.put(colsName, colsValue);// 保存为键值对
}
mapList.add(map);// 添加到list集合
}
}catch(Exception e) {
e.printStackTrace();
// throw new RuntimeException("查询时出现错误");
} finally {
closeAll();
}
List<T> list = MapUtils.map2Java(javaBean, mapList);// 获得查询的数据,并封装成对应的bean返回list集合
returnlist;
}
/**
* 单个查询,传入什么类型的,返回什么类型。泛型bean
*
* @return T
* */
public static <T> T findOne(T javaBean, String sql, Object... obj) {
List<T> list = find(javaBean, sql, obj);
if(list ==null|| list.size() == 0) {// list为空返回null,除去空指针异常
returnnull;
}else{
returnlist.get(0);
}
}
/**
* 查询总数据
* */
public static int dateCount(String sql){
ps=getPreparedStatement(sql);
int row=0;
try{
rs = ps.executeQuery();
if(rs.next()){
row= rs.getInt(1);
}
}catch(SQLException e) {
// e.printStackTrace();
thrownewRuntimeException("查询总数据条数失败!");
}
returnrow;
}
/**
* 查询,返回ResultSet结果集
*
* @return ResultSet
* */
// public static ResultSet findMany(String sql, Object... obj) {
// /*
// * 可变参数的特点:只能出现在参数列表的最后;
// * ...位于变量类型和变量名之间,前后有无空格都可以;调用可变参数的方法时,编译器为该可变参数隐含创建一个数组
// * ,在方法体中一数组的形式访问可变参数。
// */
// getPreparedStatement(sql);// 实例化预编译对象ps
// try {
// if (obj.length > 0) {
// for (int i = 0; i < obj.length; i++) {// 循环把参数 赋给预编译的声明
// ps.setObject(i + 1, obj[i]);
// }
// }
// rs = ps.executeQuery();// 获得查询结果
// } catch (Exception e) {
// // e.printStackTrace();
// throw new RuntimeException("查询时出现错误");
// } finally {
// closeAll();
// }
// return rs;
// }
/**
* update 执行修改数据
*
* @return int
* */
public static int update(String sql, Object... obj) {
int result = 0;
getPreparedStatement(sql);// 实例化预编译对象ps
try{
if(obj.length > 0) {
for(int i = 0; i < obj.length; i++) {// 循环把参数 赋给预编译的声明
ps.setObject(i + 1, obj[i]);
}
}
result = ps.executeUpdate();
}catch(Exception e) {
// e.printStackTrace();
thrownewRuntimeException("执行DML语句(增,删,改)时出现错误");
} finally {
closeAll();
}
returnresult;
}
/**
* 关闭数据库连接
*/
public static void closeAll() {
try{
if(rs !=null) {
rs.close();
}
if(ps !=null) {
ps.close();
}
if(conn !=null) {
conn.close();
}
}catch(SQLException e) {
// e.printStackTrace();
thrownewRuntimeException("关闭连接时出现错误");
}
}
}为了操作方便,我封装了个map转bean的类
package com.zhumeng.util;
import java.beans.BeanInfo;
import java.beans.Introspector;
import java.beans.PropertyDescriptor;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
/**
* Map工具类
* 实习map跟object的转换
*/
public class MapUtils {
/**
* Map集合对象转化成 JavaBean集合对象
*
* @param javaBean JavaBean实例对象
* @param mapList Map数据集对象
* @return
*/
public static <T> List<T> map2Java(T javaBean, List<Map<String, Object>> mapList) {
if(mapList == null || mapList.isEmpty()){
return null;
}
List<T> objectList = new ArrayList<T>();
T object = null;
for(Map<String, Object> map : mapList){
if(map != null){
object = map2Java(javaBean, map);
objectList.add(object);
}
}
return objectList;
}
/**
* Map对象转化成 JavaBean对象
*
* @param javaBean JavaBean实例对象
* @param map Map对象
* @return
*/
@SuppressWarnings("unchecked")
public static <T> T map2Java(T javaBean, Map<String, Object> map) {
try {
// 获取javaBean属性
BeanInfo beanInfo = Introspector.getBeanInfo(javaBean.getClass());
// 创建 JavaBean 对象
Object obj = javaBean.getClass().newInstance();
PropertyDescriptor[] propertyDescriptors = beanInfo.getPropertyDescriptors();
if (propertyDescriptors != null && propertyDescriptors.length > 0) {
String propertyName = null; // javaBean属性名
Object propertyValue = null; // javaBean属性值
for (PropertyDescriptor pd : propertyDescriptors) {
propertyName = pd.getName();
if (map.containsKey(propertyName)) {
propertyValue = map.get(propertyName);
pd.getWriteMethod().invoke(obj, new Object[] { propertyValue });
}
}
return (T) obj;
}
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
/**
* JavaBean对象转化成Map对象
*
* @param javaBean
* @return map
*
*/
// @SuppressWarnings({ "rawtypes", "unchecked" })
// public static Map java2Map(Object javaBean) {
// Map map = new HashMap();
//
// try {
// // 获取javaBean属性
// BeanInfo beanInfo = Introspector.getBeanInfo(javaBean.getClass());
//
// PropertyDescriptor[] propertyDescriptors = beanInfo.getPropertyDescriptors();
// if (propertyDescriptors != null && propertyDescriptors.length > 0) {
// String propertyName = null; // javaBean属性名
// Object propertyValue = null; // javaBean属性值
// for (PropertyDescriptor pd : propertyDescriptors) {
// propertyName = pd.getName();
// if (!propertyName.equals("class")) {
// Method readMethod = pd.getReadMethod();
// propertyValue = readMethod.invoke(javaBean, new Object[0]);
// map.put(propertyName, propertyValue);
// }
// }
// }
//
// } catch (Exception e) {
// e.printStackTrace();
// }
//
// return map;
// }
//
}
2.从文件外读取参数的方式:
db.properties中的参数
/**
* @author 刘鹏 功能:jdbc连接工具类 1.获得连接connection对象(需要从properties文件读取连接信息)
* */
public class MyConnection {
private static String driver;// 驱动
private static String url;// 数据库url
private static String user;// 用户名
private static String password;// 密码
private static Connection conn = null;// 数据库连接
private static PreparedStatement ps = null;// 预编译声明
private static ResultSet rs = null;// 结果集
// 从properties文件读取链接信息
public static void getProperties() {
try (BufferedInputStream bi = new BufferedInputStream(
new FileInputStream("src/com/peng/util/db.properties"));) {
Properties pro = new Properties();
pro.load(bi);
driver = pro.getProperty("jdbc.driver").trim();
url = pro.getProperty("jdbc.url").trim();
user = pro.getProperty("jdbc.user").trim();
password = pro.getProperty("jdbc.password").trim();
} catch (Exception e) {
new RuntimeException("获得链接驱动信息出现错误");
}
}
// 类一装入内存是就加载数据库连接驱动
static {
getProperties();
try {
Class.forName(driver);
} catch (ClassNotFoundException e) {
new RuntimeException("加载驱动类出现错误");
}
}
/**
* 获取数据库连接
*
* @return Connection
*/
public static Connection getConnection() {
try {
conn = DriverManager.getConnection(url, user, password);
} catch (SQLException e) {
// e.printStackTrace();
throw new RuntimeException("获取链接对象connection出现错误");
}
return conn;
}
/**
* 获得预编译声明
* */
public static PreparedStatement getPreparedStatement(String sql) {
getConnection();// conn实例化
try {
ps = conn.prepareStatement(sql);
} catch (SQLException e) {
// e.printStackTrace();
throw new RuntimeException("获取预编译对象PreparedStatement出现错误");
}
return ps;
}
剩下的方法同上边使用数据库连接池的。查询单个数据或者批量查找数据
相关推荐
- 傲游浏览器(傲游浏览器app下载)
-
1、开始——程序——找到遨游——打开,如果能打开说明快捷方式有问题2、362急救箱系统修复、网络修复傲游浏览器曾经是一个备受推荐的浏览器,由于其强大的功能和用户友好的界面,在中国的浏览器市场占有一...
- 电脑怎么定时关机软件(电脑怎样定时开关机软件)
-
给电脑设置定时开关机的方法如下:1、点击桌面左下角的开始按钮,打开“控制面板”。2、然后我们点击“系统和安全3、点击下方的“管理工具”。4、再点击“任务计划程序”。5、点击“计划任务程序库”,选择“创...
- 网易邮箱企业邮箱登录入口(网易邮箱企业免费邮箱登录)
-
网易企业邮箱官网(qiye.163.com),除此之外所看到的都是经销商网站。现阶段在该官网是可以填写信息直接开通网易企业邮箱体验试用的。如果有不明白的地方需要专人服务也是可以在官网点击在线咨询按钮或...
-
- qq电子邮箱怎么写(电子邮件信箱怎么注册)
-
1.每个人在注册QQ时都会有关联的一个邮箱,它的格式就是“QQ号码@qq.com”。2.用户可以免费开通自己的手机号码邮箱帐号。3.QQ邮箱还可以注册“……@foxmail.com”这样的商务型帐号。4.@qq.com邮箱可以有...
-
2026-01-12 22:05 liuian
- 台式机装机步骤(台式机 装机)
-
原因:1、更新的驱动不正确或未更新完成(使用USB键鼠经常发生);2、电脑更新驱动时假死,导致进程反应过慢。解决方法:1、如更新时驱动不正确,USB键盘、鼠标无作用时;可等待1~2分钟,看键鼠是否恢复...
- win8手机下载安装(win8安卓)
-
在电脑上面就可以下载,打开浏览器搜索windous8系统会出现一些下拉选择,选择第一条或者选择有官网字样的,就直接有下载按钮,然后点击下载就可以了关闭应用自动更新第一步、在系统中找到应用商店。第二...
- 台式电脑显卡怎么升级(台式电脑显卡升级方案)
-
一般情况下,建议到产品(您的显卡)品牌官网上去下载相应最新的驱动,这虽然并不能保证一定就是显卡最新的驱动,但相对于稳定性来说是首选。如果是高级玩家,追求更新、更好的性能发挥,可以利用驱动精灵一类的驱动...
- u盘数据丢失的原因(u盘数据丢失的原因有哪些)
-
U盘出现了损坏造成的磁道出现了损坏。这个U盘的磁道是最容易损坏的,有的时候你不知道怎么碰到它,它就有数据丢失了就无法显示这样的情况,你可以在电脑上进行修复,首先你点击U盘右键找到属性选择修复,这样把...
- window7下载哪个版本的ie(windows7用哪个版本的ie浏览器)
-
WIN7系统自带的IE浏览器是8.0版本的。IE全称InternetExplorer,是美国微软公司推出的一款网页浏览器。IE8扩展的新功能有:1、Activities(活动内容服务)。用户可以从网页...
- 服务器回收(上海服务器回收)
-
回收服务器内存后,首先应该彻底清除内存存储的所有数据和敏感信息,然后进行分类处理。如果内存仍然有效,可以进行检测、测试和修复后再重新使用。如果内存已损坏或过期,应该妥善处理,比如通过专业的硬件回收公司...
- 戴尔官网入口学生通道(戴尔学生渠道)
-
戴尔官网地址如下,在浏览器输入就可以加入了。DELL官方网站http://www.dell.com.cn/DELL官方旗舰店(天猫)http://dell.tmall.com/DELL官方旗舰店(京东...
- win7旗舰版激活码病毒(win7旗舰版激活密钥 永久激活码)
-
激活和破解工具会修改一些系统文件或数据,一般都会被杀毒软件识别为木马。而且现在网上的windows和office激活工具有的确实是带有木马的,最好去值得信任的网站或者论坛下载。
- 421文档 全文免费阅读(421小说在线阅读)
-
根据1,我回答如下:1,"421文档"是在4月21日发布的。2,"421文档"作为一份重要的文件,通常在特定日期或时间点发布,供相关人员参考和使用。3,除了发布日...
- 一周热门
-
-
飞牛OS入门安装遇到问题,如何解决?
-
如何在 iPhone 和 Android 上恢复已删除的抖音消息
-
Boost高性能并发无锁队列指南:boost::lockfree::queue
-
大模型手册: 保姆级用CherryStudio知识库
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
威联通NAS安装阿里云盘WebDAV服务并添加到Infuse
-
Trae IDE 如何与 GitHub 无缝对接?
-
idea插件之maven search(工欲善其事,必先利其器)
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
