解决:ClassCastException: org.springframework.util.LinkedCaseInsensi

本文详细介绍了jdbcTemplate的各种查询方法,包括queryForInt、queryForObject、queryForList等,并提供了具体的使用示例。同时,还讨论了如何配置jdbcTemplate以及一些注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考如下:



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的二级缓存体系

2025-03-24 15:48:52.258[ERROR][main]-Application run failed java.lang.ClassCastException: org.springframework.boot.loader.LaunchedURLClassLoader cannot be cast to io.iec.edp.caf.app.manager.classloader.CAFClassLoader at io.iec.edp.caf.middleware.spi.impl.DefaultClassUrlResolver.addUrl(DefaultClassUrlResolver.java:42) at io.iec.edp.caf.boot.starter.middleware.spi.utils.ClassLoaderResolverUtils.addUrl(ClassLoaderResolverUtils.java:40) at io.iec.edp.caf.boot.starter.middleware.config.ServletSpringApplicationRunListener.environmentPrepared(ServletSpringApplicationRunListener.java:73) at org.springframework.boot.SpringApplicationRunListener.environmentPrepared(SpringApplicationRunListener.java:65) at org.springframework.boot.SpringApplicationRunListeners.lambda$environmentPrepared$2(SpringApplicationRunListeners.java:63) at java.util.ArrayList.forEach(ArrayList.java:1257) at org.springframework.boot.SpringApplicationRunListeners.doWithListeners(SpringApplicationRunListeners.java:117) at org.springframework.boot.SpringApplicationRunListeners.doWithListeners(SpringApplicationRunListeners.java:111) at org.springframework.boot.SpringApplicationRunListeners.environmentPrepared(SpringApplicationRunListeners.java:62) at org.springframework.boot.SpringApplication.prepareEnvironment(SpringApplication.java:375) at org.springframework.boot.SpringApplication.run(SpringApplication.java:333) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1329) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1318) at com.inspur.edp.lcm.metadata.ShellApplication.main(ShellApplication.java:20) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:49) at org.springframework.boot.loader.Launcher.launch(Launcher.java:108) at org.springframework.boot.loader.Launcher.launch(Launcher.java:58) at org.springframework.boot.loader.PropertiesLauncher.main(PropertiesLauncher.java:467) 请按任意键继续. . .
03-25
org.apache.catalina.core.StandardContext filterStart 严重: 启动过滤器异常 java.lang.ClassCastException: class org.springframework.web.filter.CharacterEncodingFilter cannot be cast to class javax.servlet.Filter (org.springframework.web.filter.CharacterEncodingFilter is in unnamed module of loader org.apache.catalina.loader.ParallelWebappClassLoader @758a34ce; javax.servlet.Filter is in unnamed module of loader java.net.URLClassLoader @4769b07b) at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:249) at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:102) at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4566) at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5203) at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183) at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1384) at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1374) at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) at org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75) at java.base/java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:145) at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:909) at org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:843) at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183) at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1384) at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1374) at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) at org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75) at java.base/java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:145) at org.apache.catalina.
03-18
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值