JdbcUtil

转自:https://github.com/ghyg525/util_java_jdbc

 JdbcUtil.java

import java.io.IOException;
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.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Properties;/*** 简单封装数据库工具类* 查询返回结果有数组, List, Map* 其他类型语句都调用execute* @author YJ*/
public class JdbcUtil {/*** 查询返回String二维数组* @param sql* @param args* @return*/public static String[][] queryForArray(String sql, Object... args) {Connection conn = null;PreparedStatement stmt = null;ResultSet rs = null;String[][] result = null;try {conn = getConnection();stmt = conn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);if (args != null) {for (int i = 0; i < args.length; i++) {stmt.setObject(i + 1, args[i]);}}rs = stmt.executeQuery();rs.last();int rows = rs.getRow();rs.beforeFirst();ResultSetMetaData rsmd = rs.getMetaData();int cols = rsmd.getColumnCount();result = new String[rows+1][cols];for (int i = 0; i < cols; i++) {result[0][i] = rsmd.getColumnName(i + 1);}int currentRow = 1;while (rs.next()) {for (int i = 0; i < cols; i++) {result[currentRow][i] = rs.getObject(i + 1).toString();}currentRow++;}} catch (SQLException e) {e.printStackTrace();} finally {try {if (rs != null)rs.close();if (stmt != null)stmt.close();if (conn != null)conn.close();} catch (SQLException e) {e.printStackTrace();}}return result;}/*** 查询返回List类型* @param sql* @param args* @return 多条记录的List集合*/public static List<Map<String, Object>> queryForList(String sql, Object... args) {Connection conn = null;PreparedStatement stmt = null;ResultSet rs = null;List<Map<String, Object>> result = new ArrayList<Map<String, Object>>();try {conn = getConnection();stmt = conn.prepareStatement(sql);if (args != null) {for (int i = 0; i < args.length; i++) {stmt.setObject(i + 1, args[i]);}}rs = stmt.executeQuery();ResultSetMetaData rsmd = rs.getMetaData();int cols = rsmd.getColumnCount();String[] colNames = new String[cols];for (int i = 0; i < cols; i++) {colNames[i] = rsmd.getColumnName(i + 1);}while (rs.next()) {Map<String, Object> row = new LinkedHashMap<String, Object>();for (int i = 0; i < cols; i++) {row.put(colNames[i], rs.getObject(i + 1));}result.add(row);}} catch (SQLException e) {e.printStackTrace();} finally {try {if (rs != null)rs.close();if (stmt != null)stmt.close();if (conn != null)conn.close();} catch (SQLException e) {e.printStackTrace();}}return result;}/*** 查询返回Map类型 当确定返回结果唯一时调用* @param sql* @param args* @return 一条记录的Map*/public static Map<String, Object> queryForMap(String sql, Object... args) {List<Map<String, Object>> result = queryForList(sql, args);Map<String, Object> row = null;if (result.size() == 1) {row = result.get(0);return row;} else {return null;}}/*** 执行除查询外(增加/删除/修改)* @param sql* @param args* @return 是否执行成功*/public static boolean execute(String sql, Object... args) {Connection conn = null;PreparedStatement stmt = null;boolean result = true;try {conn = getConnection();stmt = conn.prepareStatement(sql);if (args != null) {for (int i = 0; i < args.length; i++) {stmt.setObject(i + 1, args[i]);}}stmt.executeUpdate();} catch (SQLException e) {e.printStackTrace();result = false;} finally {try {if (stmt != null)stmt.close();if (conn != null)conn.close();} catch (SQLException e) {e.printStackTrace();}}return result;}/*** 获得数据库连接* @return*/private static Connection getConnection() {Connection conn = null;try {Class.forName(getProperties().getProperty("driver"));conn = DriverManager.getConnection(getProperties().getProperty("url"),getProperties().getProperty("username"), getProperties().getProperty("password"));} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}return conn;}/*** 读取配置文件信息* @return*/private static Properties getProperties(){Properties properties = new Properties();try {properties.load(JdbcUtil.class.getResourceAsStream("/jdbc.properties"));} catch (IOException e) {e.printStackTrace();}return properties;}}

 

jdbc.properties

url=jdbc:mysql://localhost:3306/esweb
driver=com.mysql.jdbc.Driver
username=root
password=root

 

测试:

public class JdbcMysql {public static void main(String[] args) {String sql1 = "select * from screen_201808";String sql2 = "select * from screen_201808 where id = ?";System.out.println(JdbcUtil.queryForArray(sql1)[1][1]);System.out.println(JdbcUtil.queryForList(sql1));System.out.println(JdbcUtil.queryForMap(sql2,1));}
}

 

 参考文档:

https://github.com/ghyg525/util_java_jdbc

https://www.shiyanlou.com/courses/110

转载于:https://www.cnblogs.com/libin2015/p/9443395.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/388859.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习 综合评价_PyCaret:机器学习综合

机器学习 综合评价Any Machine Learning project journey starts with loading the dataset and ends (continues ?!) with the finalization of the optimum model or ensemble of models for predictions on unseen data and production deployment.任何机器学习项目的旅程都…

silverlight 3D 游戏开发

http://www.postvision.net/SilverMotion/DemoTech.aspx silverlight 3D 游戏开发 时间:2010-10-22 06:33来源:开心银光 作者:黎东海 点击: 562次意外发现一个silverlight的实时3D渲染引擎。性能比开源那些强很多。 而且支持直接加载maya,3Dmax等主流3D模型文件。 附件附上它的…

redis终端简单命令

keys * 获取所有键lRange hongbao:44 0 -1获取该键的所有值del hongbao:44 删除该键的所有值 hgetAll user:44 获取该键的所有队列hget hongbao:44 8 获取该队列用户为8的值hset hongbao:44 7 asdf设置该队列用户为7的值hdel user:44 8 删除该队列用户为8的值 flushall 清空red…

python中ix用法_Python中使用ix的数据帧子集

您可以使用X[var2].iloc[[0,1]]&#xff1a;In [280]: X[var2].iloc[[0,1]]Out[280]:0 NaN4 9Name: var2, dtype: float64由于X[var2]是X的视图&#xff0c;因此X[var2].iloc[[0,1]]对两者都是安全的访问和分配。但是如果你使用这种“链式索引”要小心模式(例如这里使用的index…

LintCode 16. 带重复元素的排列

写在前面&#xff1a;这题和全排列不含重复元素的那题几乎一样&#xff0c;我比较垃圾&#xff0c;就用HashSet去掉了重复的元素但是看了九章算法的答案也没看懂&#xff0c;他写的很有感觉。 用了hash&#xff0c;本来想着怎么写hashcode()和equal()方法的&#xff0c;哪知道都…

皮尔逊相关系数 相似系数_皮尔逊相关系数

皮尔逊相关系数 相似系数数据科学和机器学习统计 (STATISTICS FOR DATA SCIENCE AND MACHINE LEARNING) In the last post, we analyzed the relationship between categorical variables and categorical and continuous variables. In this case, we will analyze the relati…

【洛谷】P1641 [SCOI2010]生成字符串(思维+组合+逆元)

题目 传送门&#xff1a;QWQ 分析 不想画图。 https://www.luogu.org/problemnew/solution/P1641 好神仙的题啊。 代码 1 // luogu-judger-enable-o22 #include <bits/stdc.h>3 using namespace std;4 typedef long long ll;5 const int maxn15000000;6 const ll MOD2010…

Kubernetes持续交付-Jenkins X的Helm部署

Jenkins X 是一个集成化的 CI / CD 平台&#xff0c;可用于 部署在Kubernetes集群或云计算中心。支持在云计算环境下简单地开发和部署应用。本项目是在Kubernetes上的安装支持工具集。 本工具集中包含&#xff1a; Jenkins - 定制好的流水线和运行环境&#xff0c;完全整合CI/C…

中国石油大学(华东)暑期集训--二进制(BZOJ5294)【线段树】

问题 C: 二进制 时间限制: 1 Sec 内存限制: 128 MB提交: 8 解决: 2[提交] [状态] [讨论版] [命题人:]题目描述 pupil发现对于一个十进制数&#xff0c;无论怎么将其的数字重新排列&#xff0c;均不影响其是不是3的倍数。他想研究对于二进制&#xff0c;是否也有类似的性质。于…

2018年10个最佳项目管理工具及链接

要在任何业务中取得成功&#xff0c;对项目进行适当的管理非常重要。 项目管理是一系列活动&#xff0c;包括计划&#xff0c;执行&#xff0c;控制和完成项目。项目管理工具有助于简化此过程。这里是Best 10项目管理工具及其功能和下载链接的精选列表。1&#xff09;AsanaAsan…

Java 8 新特性之Stream API

1. 概述 1.1 简介 Java 8 中有两大最为重要的改革&#xff0c;第一个是 Lambda 表达式&#xff0c;另外一个则是 Stream API&#xff08;java.util.stream.*&#xff09;。 Stream 是 Java 8 中处理集合的关键抽象概念&#xff0c;它可以指定你希望对集合进行的操作&#xff0c…

[Python设计模式] 第17章 程序中的翻译官——适配器模式

github地址:https://github.com/cheesezh/python_design_patterns 适配器模式 适配器模式&#xff0c;将一个类的接口转换成客户希望的另外一个接口。Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作[DP]。 当系统的数据和行为都正确&#xff0c;但是接口…

Ubuntu中NS2安装详细教程

前言&#xff1a; NS2是指 Network Simulator version 2&#xff0c;NS&#xff08;Network Simulator&#xff09; 是一种针对网络技术的源代码公开的、免费的软件模拟平台&#xff0c;研究人员使用它可以很容易的进行网络技术的开发&#xff0c;而且发展到今天&#xff0c;它…

es6核心特性图

转载于:https://juejin.im/post/5c19e188e51d452db4753925

带你利用一句话完成转场动画

这篇文章主要给大家介绍了关于iOS如何利用一句话完成转场动画的相关资料&#xff0c;文中通过示例代码介绍的非常详细&#xff0c;对大家的学习或者工作具有一定的参考学习价值&#xff0c;需要的朋友们下面来一起学习学习吧前言本文介绍SS_AnimationTransition 的使用方法,利用…

14.vue路由脚手架

一.vue路由&#xff1a;https://router.vuejs.org/zh/ 1、定义 let router new VueRouter({mode:"history/hash",base:"基本路径" 加一些前缀 必须在history模式下有效linkActiveClass:"active", 范围选择linkExactActiveClass:"exact&qu…

工程师、产品经理、数据工程师是如何一起工作的?

做为一名工程师&#xff0c;免不了与产品经理打交道&#xff0c;如果公司大一些&#xff0c;数据量多一些&#xff0c;还会有数据工程师这个角色。今天会和你主要聊一聊在工作中&#xff0c;产品经理和数据工程师在哪些方面对我们工程师的帮助最大&#xff0c;以及我从他们身上…

linux-buff/cache过大导致内存不足-程序异常

2019独角兽企业重金招聘Python工程师标准>>> 问题描述 Linux内存使用量超过阈值&#xff0c;使得Java应用程序无可用内存&#xff0c;最终导致程序崩溃。即使在程序没有挂掉时把程序停掉&#xff0c;系统内存也不会被释放。 找原因的过程 这个问题已经困扰我好几个月…

Android 适配(一)

一、Android适配基础参数1.常见分辨率&#xff08;px&#xff09;oppx 2340x1080oppR15 2280x1080oppor11sp 2160*10801080*1920 (主流屏幕16&#xff1a;9)1080*216018:9 手机主流分辨率&#xff1a; 1080*2160高端 16:9 手机主流分辨率&#xff1a; 1080P (1080*1920) 或 2K …

Source Insight 创建工程(linux-2.6.22.6内核源码)

1. 软件设置 安装完Source Insight&#xff0c;需要对其进行设置添加对“.S”汇编文件的支持&#xff1a; 2. 新建linux-2.6.22.6工程 1&#xff09;选择工程存放的路径&#xff1a; 2&#xff09;下载linux-2.6.22.6内核源码&#xff0c;并解压。在Source Insight中 指定源码的…