• JdbcTemplate进行查询


    1、jdbcTemplate.queryForInt() 和 jdbcTemplate.queryForLong()

     例如:下面使用queryForInt()方法传回user表中的记录数:

    jdbcTemplate.queryForInt("select count(*) from user");

     

    2 jdbcTemplate.queryForObject()

    本质上和 queryForInt() ,相同。返回都是单行单列一个数据。例如下例传回一个 String 对象:

    String name = (String) jdbcTemplate.queryForObject( "SELECT name FROM USER WHERE id = ?", new Object[] {id}, java.lang.String.class);

     

    3 jdbcTemplate.queryForList(???)

    返回 a List of Maps, using column name as key. 每一个map代表一条记录 例如:

    List rows = jdbcTemplate.queryForList("SELECT * FROM user"); 

    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(???)

    和 queryForList(), 差不多,只是预期查询一行数据。返回 a Map, using column name as key.

    The query is expected to be a single row query

     

    5 jdbcTemplate.queryForRowSet(???)

    返回 RowSet, representing disconnected java.sql.ResultSet

     

    JDBCTemplate 的使用很简单,只要在 ApplicationContext 文件里定义一个 jdbcTemplate 节点,POJO 获得注入后可以直接执行操作,不需要继承什么基类。

    xml 代码

    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">          

          <property name="dataSource" ref="dataSource"/>       

    </bean>  

    java 代码

    SqlRowSet rs = jdbcTemplate.queryForRowSet(sql, params);  

    Tips1 : jdbcTemplate 有很多的 ORM化回调操作将返回结果转为对象列表,但很多时候还是需要返回 ResultSet ,Spring 有提供一个类似 ResultSet 的,实现 JDBC3.0 RowSet接口的 Spring SqlRowSet 。

     

    Tips2 :. 注意 jdbcTemplate 尽量只执行查询操作,莫要进行更新,否则会破坏 Hibernate 的二级缓存体系。

  • 相关阅读:
    1058 A+B in Hogwarts (20)
    1046 Shortest Distance (20)
    1061 Dating (20)
    1041 Be Unique (20)
    1015 Reversible Primes (20)(20 分)
    pat 1027 Colors in Mars (20)
    PAT 1008 Elevator (20)
    操作系统 死锁
    Ajax的get方式传值 避免& 与= 号
    让IE浏览器支持CSS3表现
  • 原文地址:https://www.cnblogs.com/fengzhanfei/p/6136982.html
Copyright © 2020-2023  润新知