使用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>>的更多相关文章

  1. oracle 连接数据库并查询,返回List<Map<String, Object>> 数据

    package JDBC; import java.sql.Clob; import java.sql.Connection; import java.sql.DriverManager; impor ...

  2. jpa返回List<Map<String, Object>>相当于jdbctemplate的queryForlist

    public class Test(){ @PersistenceContext(unitName = "manageFactory") protected EntityManag ...

  3. 多条查询sql语句返回多表数据集

    + + "';SELECT ProductID,ProductTitle,ProductName,SalePrice,ListingPrice,MainPicture,SaledItemCo ...

  4. 分页查询和分页缓存查询,List<Map<String, Object>>遍历和Map遍历

    分页查询 String sql = "返回所有符合条件记录的待分页SQL语句"; int start = (page - 1) * limit + 1; int end = pag ...

  5. 查询sql语句所花时间

    --1:下面这种是SQL Server中比较简单的查询SQL语句执行时间方法,通过查询前的时间和查询后的时间差来计算的: declare @begin_date datetime declare @e ...

  6. Entity Framework执行Sql语句返回DataTable

    Entity Framework中对外开放了数据库连接字符串,使用的时候可以直接得到这个连接字符串,然后进行相关的操作.如果在使用的过程中,发现Entity Framework中有一些满足不了的需求的 ...

  7. 多表查询sql语句

    多表查询sql语句 1 --解锁SCOTT用户 2 alter user scott account unlock 3 --检索指定的列 4 select job,ename,empno from e ...

  8. mysql 中字符串拼接,查询sql语句总结

    DELIMITER $$ USE `ld_wpfmgl_sys`$$ DROP PROCEDURE IF EXISTS `code_query`$$ CREATE DEFINER=`root`@`%` ...

  9. 跨服务器查询sql语句样例

    若2个数据库在同一台机器上:insert into DataBase_A..Table1(col1,col2,col3----)select col11,col22,col33-- from Data ...

随机推荐

  1. linux 命令笔记

    linux 命令 创建目录 mkdir XX 列出目录 ls 进入目录 cd .. 进入上层目录 cd xx 进入xx目录 cd ~ 进入用户主目录 删除目录 rm -fr XX 清空目录,谨慎使用 ...

  2. 17. Letter Combinations of a Phone Number

    题目: Given a digit string, return all possible letter combinations that the number could represent. A ...

  3. 你真的了解iOS代理设计模式吗?

    在项目中我们经常会用到代理的设计模式,这是iOS中一种消息传递的方式,也可以通过这种方式来传递一些参数.这篇文章会涵盖代理的使用技巧和原理,以及代理的内存管理等方面的知识.我会通过这些方面的知识,带大 ...

  4. iOS之九宫格图片

    照片 现在人们的生活越来越丰富了,很多美好的瞬间都定格在一张张色彩绚丽的照片上,或许把照片珍藏在相册里,或许通过社交软件分享给亲朋好友.那社交软件上的照片是以什么形式展现的呢?那么接下来就要说到九宫格 ...

  5. STM32F407Discovery开发板使用环境搭建

    差不多4年前买了STM32F407Discovery这块开发板,也用它作为我的毕业设计的一部分,今晚整理一下东西,觉得这么不错的东西应该再次利用起来,做个智能家居系统的一部分什么的也不错,于是,记录一 ...

  6. php中"::"双冒号有什么作用

    PHP代码 lazycms::$sysname 第一次见到这种表现方式,请问是双冒号什么意思 答:直接属类的方法或属性.也就是static 静态方法或属性的使用.域运算符,一般用于在B类对象中使用A类 ...

  7. Linux学习笔记(5)-hello world

    经过三天的熟悉,我已经将教程中那些常用命令都使用了一遍,所以,从今天起,我已经从一直Linux菜鸟蜕变成了大雕-- Linux的命令无穷多,要想背下来那肯定是不可能的,所以我的目标便是混个手熟,那些常 ...

  8. Python爬虫学习(1): urllib的使用

    1.urllib.urlopen 打开一个url的方法,返回一个文件对象,然后可以进行类似文件对象的操作 In [1]: import urllibIn [2]: file = urllib.urlo ...

  9. 不想说作用域scope,因为是scopeTree,

    ps:本文前面大部分是错的,后边大部分也是错的,搞混了不要怪我................... 这篇文章讲述了一个悲伤的故事,从一个似似而非的概念一步一步到错误的理解,最后勉强正确的过程 其实我 ...

  10. event

    当一个事件被调用后,它会收到一个参数,第一个参数就是事件对象,事件对象包含type, target, timestamp三个. 类型:事件的名称,例如:点击目标:事件的目标元素时间戳:事件触发的时间