jdbcTemplate的queryForList的使用方法如下,它不一样的地方是,它获得的结果,会再放到一个map里去:

  • List rows = jdbcTemplate.queryForList("SELECT * FROM USER");
  • Iterator it = rows.iterator();
  • while(it.hasNext()) {
  • Map userMap = (Map) it.next();
  • System.out.print(userMap.get("user_id") + "\t");
  • System.out.print(userMap.get("name") + "\t");
  • System.out.print(userMap.get("sex") + "\t");
  • System.out.println(userMap.get("age") + "\t");
  • }
  • 我的一个例子中,得到的结果只有一列数字类型的数据(targer_id),但使用queryForList得到的结果集个数与数据库的内容一致,但每一项都是null。不清楚其原因,修改成

    jdbcTemplate.query(sql,

    才能正确得到结果。

    附上带用的一些方法

    使用jdbcTemplate查询数据的时候可以使用queryForXXX等方法。下面我们就一一解析一下:
    1、jdbcTemplate.queryForInt()和jdbcTemplate.queryForLong()
    --使用queryForInt返回user表中的记录数量,queryForInt搭配这样的sql可以在分页的时候计算总记录数
    jdbcTemplate.queryForInt("select count(*) from user");

    2、jdbcTemplate.queryForObject()
    --本质上和queryForInt相同,只是可以返回不同的对象,例如返回一个String对象
    String name = (String) jdbcTemplate.queryForObject(  --3个参数,1、sql 2、要传递的参数数组 3、返回来的对象class
    "SELECT name FROM USER WHERE id = ?",  
    new Object[] {id},  
    java.lang.String.class);

    3、jdbcTemplate.queryForList(???)
    --返回一个装有map的list,每一个map是一条记录,map里面的key是字段名
    List rows = jdbcTemplate.queryForList("SELECT * FROM user");  --得到装有map的list
    for(int i=0;i<rows.size();i++){                   --遍历
    Map userMap=rows.get(i);
    System.out.println(userMap.get("id"));  
    System.out.println(userMap.get("name"));  
    System.out.println(userMap.get("age"));
    }

    4、jdbcTemplate.queryForMap(SQL)
    --这个查询只能是查询一条记录的查询,返回一个map,key的值是column的值
    Map map = jdbcTemplate.queryForMap("select count(*) as keyval from user");
    map.get("keyval")

    5、jdbcTemplate.queryForRowSet(???)
    --返回一个RowSet   然后调用.getString或者getInt等去取值

    6、jdbc1.query(sql, new RowCallbackHandler()
    --返回一个ResultSet对象, processRow有自动循环的机制,它会自动执行processRow中的语句直到
    --rs的size执行完了为止。我们可以在这其中用list完成对象的转移,只不过list要用final来修饰
    jdbc1.query(sql, new RowCallbackHandler() { //editing
                public void processRow(ResultSet rs) throws SQLException {
            VideoSearch vs = new VideoSearch();
            vs.setRECORDINGFILENAME(rs.getString("RECORDINGFILENAME"));
            vs.setCALLID(rs.getString("CALLID"));
            list.add(vs);

        }
        }

    说明:
    JDBCTemplate的使用方法:
    在ApplicationContext.xml中定义一个jdbcTemplate的节点,使用POJO注入,获得注入后可以执行操作
    不需要继承什么基类

    <bean id="jdbcTemplate"
    class="org.springframework.jdbc.core.JdbcTemplate">            
          <property name="dataSource" ref="dataSource"/>         
    </bean>

    SqlRowSet rs = jdbcTemplate.queryForRowSet(sql, params);
    jdbcTemplate有很多的ORM化回调操作将返回结果转为对象列表,
    但很多时候还是需要返回ResultSet,Spring有提供一个类似ResultSet的,实现JDBC3.0 RowSet接口的Spring SqlRowSet
    注意
    jdbcTemplate尽量只执行查询操作,莫要进行更新,否则会破坏Hibernate的二级缓存体系

    jdbcTemplate的queryForList的更多相关文章

    1. Spring JdbcTemplate的queryForList(String sql , Class<T> elementType)返回非映射实体类的解决方法

      Spring JdbcTemplate的queryForList(String sql , Class<T> elementType)易错使用 一直用ORM,今天用JdbcTemplate ...

    2. jdbcTemplate的queryForList的使用方法

      jdbcTemplate的queryForList的使用方法如下,它不一样的地方是,它获得的结果,会再放到一个map里去: List rows = jdbcTemplate.queryForList( ...

    3. Spring JdbcTemplate的queryForList(String sql , Class<T> elementType)易错使用--转载

      原文地址: http://blog.csdn.net/will_awoke/article/details/12617383 一直用ORM,今天用JdbcTemplate再次抑郁了一次. 首先看下这个 ...

    4. 关于JdbcTemplate的queryForList返回值

      通过spring的jdbctemplate返回的list其实封装的是需要通过如下方法得到里面的内容的 public void getAllUsers() { List allUsers = new A ...

    5. 简单了解jdbcTemplate的queryForList是如何查询

      queryForList方法会调用query方法,同时会传入一个新的ColumnMapRowMapper对象 ArgumentPreparedStatementSetter对象只有一个Object[] ...

    6. spring jdbcTemplate使用queryForList示例

      查询代码: LogVo 日志要显示的内容(Log的部分或者全部列) Log是日志完整的实体 public List<LogVO> findLogByDate(String startDat ...

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

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

    8. 如何使用多数据源,同时使用jpa和jdbctemplate

      spring: datasource: first: type: com.alibaba.druid.pool.DruidDataSource url: jdbc:mysql://xx.xx.xx.x ...

    9. Spring JdbcTemplate 查询结果集Map反向生成Java实体(转)

      原文地址:Spring JdbcTemplate 查询结果集Map反向生成Java实体 以前写过一篇文章吐槽过Spring JdbcTemplate的queryForList方法(参见:http:// ...

    随机推荐

    1. bzoj1767[Ceoi2009]harbingers 斜率优化dp

      1767: [Ceoi2009]harbingers Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 421  Solved: 112[Submit][S ...

    2. Linux 基本概念和操作2

      接着上一篇 "Linux 基本概念和操作" 1.删除文件 有时候我们想要删除的文件是只读文件,直接使用rm 文件名,会报错.这时使用" -f " 参数强制删除. ...

    3. ScalaPB(0): 找寻合适的内部系统微服务集成工具

      前一段时间我们探讨了SDP的一个基于集群的综合数据平台解决方案,由多种数据库组成,包括:JDBC, Cassandra 及MongoDB.其中Cassandra和MongoDB属于分布式数据库,可以在 ...

    4. C语言作业程序设计第一次作业

      1.求圆面积和面积 (1)题目: 输入圆的半径,计算圆的周长和面积 (2)流程图: (3)测试数据及运行结果 测试数据:r=4 运行结果: (4)实验分析 没有遇到问题 2.判断闰年问题 (1)题目: ...

    5. SQL语句删除字段,改变字段长度

      1.改变字段长度 ALTER TABLE T_MSG_SEND_R_ACC MODIFY reply_content VARCHAR(512); 2.删除字段ALTER TABLE MSG_TX_BA ...

    6. 原生js之canvas时钟组件

      canvas一直是前端开发中不可或缺的一种用来绘制图形的标签元素,比如压缩上传的图片.比如刮刮卡.比如制作海报.图表插件等,很多人在面试的过程中也会被问到有没有接触过canvas图形绘制. 定义 ca ...

    7. web领域的实时推送技术-WebSocket

      WebSocket protocol 是HTML5一种新的协议.它实现了浏览器与服务器全双工通信(full-duplex),即是所谓的及时推送技术. 在此之前,很多网站为了实现及时推送技术通常采用的是 ...

    8. python序列化pickle/cPickle

      一.pickle/Cpickle简介 Python序列化的概念很简单.内存里面有一个数据结构,你希望将它保存下来,重用,或者发送给其他人.你会怎么做?这取决于你想要怎么保存,怎么重用,发送给谁.很多游 ...

    9. Spring消息之AMQP.

      一.AMQP 概述 AMQP(Advanced Message Queuing Protocol),高级消息队列协议. 简单回忆一下JMS的消息模型,可能会有助于理解AMQP的消息模型.在JMS中,有 ...

    10. init,initialize,initWithFrame,initWithCoder,awakeFromNib等区别

      1.init 与initialize 对于iOS程序,创建几个类对象,就会调用几次init.下面分别重写 举例如下: 创建一个Person类,分别重写initialize和init方法 #import ...