开发者社区> 技术小阿哥> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

记录:Spring JdbcTemplate查询返回的Map与数据库对查询字段名的处理

简介:
+关注继续查看

 1.先说Spring JdbcTemplate查询返回的Map


    在使用Spring提供的JdbcTemplate类对数据库进行操作的时候,直接使用如下所示的系列重载方法需要特别注意返回的Map类型。

    org.springframework.jdbc.core.JdbcTemplate

1
2
3
public Map<String, Object> queryForMap(String sql, Object[] args, int[] argTypes) throws DataAccessException {
        return queryForObject(sql, args, argTypes, getColumnMapRowMapper());
    }
1
2
3
public List<Map<String, Object>> queryForList(String sql, Object[] args, int[] argTypes) throws DataAccessException {
        return query(sql, args, argTypes, getColumnMapRowMapper());
    }


    JdbcTemplate在处理查询结果包装成Map的时候使用了自己定义的Map,该Map继承自LinkedHashMap,且其key值的大小写不区分。

    该Map是org.springframework.util.LinkedCaseInsensitiveMap,其内部用一个Map来维护key的映射关系:小写key-原始key,而LinkedCaseInsensitiveMap本身的映射关系仍然是:原始key-元素。这样在处理添加,删除,获取的时候就可以实现忽略key的大小写。

    例如获取指定key映射的元素:

    

1
2
3
4
5
6
7
8
9
@Override
    public V get(Object key) {
        if (key instanceof String) {
            return super.get(this.caseInsensitiveKeys.get(convertKey((String) key)));
        }
        else {
            return null;
        }
    }

   那么在实际开发中使用JdbcTemplate对象查询后获得Map,然后获取指定key(数据库字段名)的值时下面所示获取同样的结果。

   

1
2
System.out.println("clientId=" + m.get("clientId") + ", clientid="
                    + m.get("clientid"));

 

  2.接下来说数据库对查询字段名的处理(字段名的大小写问题)

   

    Postgresql:

    由于Postgresql是大小写敏感,对数据库中的对象名称默认采用小写,查询字段名统一处理为小写,而SQL是不区分大小写。

    如果要在Postgresql中使得查询字段名大小写敏感需要用双引号("")引住,数据库中的对象名同理。

    如果要在Postgresql中使用字符串常量,则需要用单引号('')引住。

    !!Postgresql数据库使用需要格外注意命名。

 

    MySQL:

    Linux下:数据库名,表名,表的别名,变量名严格区分大小写(操作系统本身是区分大小写的)

    列名和列的别名不区分大小写。

    Windows下:不区分大小写,不过Mysql有个系统变量lower_case_table_names可以帮助在windows下配置[my.ini]使得表名数据库名区分大小写。

    !!最好是约定一种较为合理能被开发人员和DBA接受的命名策略。


    SQL Server:

    SQLServer是否区大小写取决于其安装方式,可以通过设置来校对。

    比如通过修改数据库来设置是否区分大小写:


1
2
3
4
5
--大小写不敏感(Case-Insensitivity)
ALTER DATABASE [DatabaseName] COLLATE Chinese_PRC_CI_AI 
 
--大小写敏感(Case-Sensitivity)
ALTER DATABASE [DatabaseName] COLLATE Chinese_PRC_CS_AI

        其它可以设置的内容,可以参考:http://technet.microsoft.com/zh-cn/library/ms174269.aspx


    这里两个问题放在一起,源于JdbcTemplate中使用的LinkedCaseInsensitiveMap,当然也是应该开发过程中犯的一些错,如数据库设计时命名不规范,AS别名还不规范,


    任何开发前期的考虑不周全,设计不严谨,开发的松懈,测试的不到位都是部署后发生灾难的根源。码农总是急于编码,真的是一场恶梦!



本文转自 secondriver 51CTO博客,原文链接:http://blog.51cto.com/aiilive/1586440,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Spring的JdbcTemplate的简单使用(七)
Spring的JdbcTemplate的简单使用(七)
27 0
Spring JdbcTemplate基本使用
Spring JdbcTemplate基本使用
88 0
spring jdbcTemplate使用
(1)springJdbcContext.xml  Java代码                springApp                      ...
715 0
Spring Boot中使用@Scheduled创建定时任务
我们在编写Spring Boot应用中经常会遇到这样的场景,比如:我需要定时地发送一些短信、邮件之类的操作,也可能会定时地检查和监控一些标志、参数等。 创建定时任务 在Spring Boot中编写定时任务是非常简单的事,下面通过实例介绍如何在Spring Boot中创建定时任务,实现每过5秒输出一下当前时间。
971 0
Spring Boot中使用@Async实现异步调用
什么是“异步调用”? “异步调用”对应的是“同步调用”,同步调用指程序按照定义顺序依次执行,每一行程序都必须等待上一行程序执行完成之后才能执行;异步调用指程序在顺序执行时,不等待异步调用的语句返回结果就执行后面的程序。
981 0
13688
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载