使用 JDBC 和 JavaTemplate 查询SQL语句返回 List<Map<String,Object>>
使用JDBC执行sql语句返回List 类型:
public class JdbcUtil {
private static Log log = LogFactory.getLog(JdbcUtil.class);
public static Connection getConnection(String driverClassName, String url, String username, String password) {
Connection connection = null;
try {
Class.forName(driverClassName);
connection = DriverManager.getConnection(url, username, password);
return connection;
} catch (ClassNotFoundException e) {
log.error("error message:" + e.getMessage());
e.printStackTrace();
return null;
} catch (SQLException e) {
log.error("error message:" + e.getMessage());
e.printStackTrace();
return null;
}
}
public static List<Map<String, Object>> execQuerySql(String driverClassName, String url, String username, String password, String sql) {
Connection connection = JdbcUtil.getConnection(driverClassName, url, username, password);
Statement statement = null;
ResultSet rs = null;
List<Map<String, Object>> rsList = null;
try {
//参考:http://www.sitesbay.com/jdbc/jdbc-scrollable-resultset.php
statement = connection.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
rs = statement.executeQuery(sql);
if (rs.getType() == ResultSet.TYPE_FORWARD_ONLY) {
log.error("error message: ResultSet non-scrollable.");
return null;
}
rs.last();
int rsRows = rs.getRow();
rsList = new ArrayList<>();
for (int i = 0; i < rsRows; i++) {
rs.absolute(i + 1);
Map<String, Object> rsMaps = new HashMap<>();
ResultSetMetaData resultSetMetaData = rs.getMetaData();
int columnCount = resultSetMetaData.getColumnCount();
for (int j = 0; j < columnCount; j++) {
String columnLable = resultSetMetaData.getColumnLabel(j + 1);
Object columnValue = rs.getObject(j + 1);
rsMaps.put(columnLable, columnValue);
}
rsList.add(rsMaps);
}
return rsList;
} catch (SQLException e) {
log.error("error message:" + e.getMessage());
e.printStackTrace();
return null;
} finally {
try {
if (statement != null) {
if (!statement.isClosed()) {
statement.close();
}
}
if (connection != null) {
if (!connection.isClosed()) {
connection.close();
}
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
上面的代码问题是返回的Map中的键是英文全大写(如何解决?求解),例如:
{"ID": 1,"USERNAME": "user"}
还可以使用JavaTemplate中封装的方法来执行sql语句返回List:
public class JdbcUtil{
public static JdbcTemplate getJdbcTemplate(String driverClassName, String url, String username, String password) {
DriverManagerDataSource driverManagerDataSource = new DriverManagerDataSource(url, username, password);
driverManagerDataSource.setDriverClassName(driverClassName));
JdbcTemplate jdbcTemplate = new JdbcTemplate(driverManagerDataSource);
return jdbcTemplate;
}
public static List<Map<String, Object>> execQuerySql(String driverClassName, String url, String username, String password, String sql) {
JdbcTemplate jdbcTemplate = getJdbcTemplate(driverClassName, url, username, password);
List<Map<String, Object>> mpList = null;
/*JdbcTemplate封装了三个返回List<Map<String, Object>>对象的方法,可以直接调用
List<Map<String, Object>> queryForList(String sql, Object[] args, int[] argTypes) throws DataAccessException;
List<Map<String, Object>> queryForList(String sql, Object... args) throws DataAccessException;
List<Map<String, Object>> queryForList(String sql) throws DataAccessException;
*/
return mpList;
}
}
使用 JDBC 和 JavaTemplate 查询SQL语句返回 List<Map<String,Object>>的更多相关文章
- oracle 连接数据库并查询,返回List<Map<String, Object>> 数据
package JDBC; import java.sql.Clob; import java.sql.Connection; import java.sql.DriverManager; impor ...
- jpa返回List<Map<String, Object>>相当于jdbctemplate的queryForlist
public class Test(){ @PersistenceContext(unitName = "manageFactory") protected EntityManag ...
- 多条查询sql语句返回多表数据集
+ + "';SELECT ProductID,ProductTitle,ProductName,SalePrice,ListingPrice,MainPicture,SaledItemCo ...
- 分页查询和分页缓存查询,List<Map<String, Object>>遍历和Map遍历
分页查询 String sql = "返回所有符合条件记录的待分页SQL语句"; int start = (page - 1) * limit + 1; int end = pag ...
- 查询sql语句所花时间
--1:下面这种是SQL Server中比较简单的查询SQL语句执行时间方法,通过查询前的时间和查询后的时间差来计算的: declare @begin_date datetime declare @e ...
- Entity Framework执行Sql语句返回DataTable
Entity Framework中对外开放了数据库连接字符串,使用的时候可以直接得到这个连接字符串,然后进行相关的操作.如果在使用的过程中,发现Entity Framework中有一些满足不了的需求的 ...
- 多表查询sql语句
多表查询sql语句 1 --解锁SCOTT用户 2 alter user scott account unlock 3 --检索指定的列 4 select job,ename,empno from e ...
- mysql 中字符串拼接,查询sql语句总结
DELIMITER $$ USE `ld_wpfmgl_sys`$$ DROP PROCEDURE IF EXISTS `code_query`$$ CREATE DEFINER=`root`@`%` ...
- 跨服务器查询sql语句样例
若2个数据库在同一台机器上:insert into DataBase_A..Table1(col1,col2,col3----)select col11,col22,col33-- from Data ...
随机推荐
- Java、JVM模型
程序计数器:记录当前线程的执行位置(便于CPU切换线程的时候执行) 虚拟机栈:Java方法,方法从调用到执行完成对应一个栈帧从虚拟机栈入栈到出栈的过程. 本地方法区:Native方法(C++) 方法区 ...
- Python~~~关键字~~~
https://docs.python.org/2.7/library/index.html # -*- coding: UTF-8 -*- 缩进indent raw_input tuple() ...
- AngularJS的JSONP服务
有些页面的response中,包含了 Access-Control-Allow-Origin 这个header,说明可以进行跨域请求,如果没有包含这个header的页面可以利用JSONP进行跨域 sc ...
- iOS开发UI篇—CAlayer层的属性
iOS开发UI篇—CAlayer层的属性 一.position和anchorPoint 1.简单介绍 CALayer有2个非常重要的属性:position和anchorPoint @property ...
- virtaulbox视图模式常用切换
virtaulbox发现菜单不见,如何切换视图模式呢? 很简单,通过快捷键主机(host)键 Host+F 换到全屏模 ...
- [BI项目记]-对项目文件进行规划
BI项目中会有很多不同种类的项目,此篇会对这些项目进行一个总结,并且在TFS中进行分类. 根据笔者对BI项目的经验和理解,主要将BI项目中的项目类型进行如下分类: DB脚本 DB脚本是BI项目中重要的 ...
- iOS--UIScrollView图片动画切换【实现每次只加载3张图片,进而减少占用内存,可循环滚动】
#import "ViewController.h" #define IMAGENUMBER 5 #define SIZE self.view.bounds.size @inter ...
- 分布式缓存技术redis学习系列(三)——redis高级应用(主从、事务与锁、持久化)
上文<详细讲解redis数据结构(内存模型)以及常用命令>介绍了redis的数据类型以及常用命令,本文我们来学习下redis的一些高级特性. 安全性设置 设置客户端操作秘密 redis安装 ...
- HTML5 meta最全使用手册
1.声明文档使用的字符编码 <meta charset='utf-8'> 2.声明文档的兼容模式 <meta http-equiv="X-UA-Compatible&quo ...
- thinkphp pathinfo nginx 无法加载模块:Index
thinkphp 报了 无法加载模块:Index 错误位置 FILE: /var/multrix/wxactivity_archive/ThinkPHP/Library/Think/Dispatche ...