码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Mybatis 下划线_英文 _test 与 下划线_数字 _1 等特殊字段无法映射为实体类的字段问题


    目录

    • 一、下划线_英文 _test 无法映射为实体类的字段问题
      • 方案一
      • 方案二
    • 二、下划线_数字 _1 等特殊字段无法映射为实体类的字段问题
    • 参考链接

    一、下划线_英文 _test 无法映射为实体类的字段问题

    方案一

    开启驼峰命名规则映射

    在MyBatis配置文件mybatis-config.xml中开启驼峰命名规则(camel case)映射,即从经典数据库列名 A_COLUMN 到经典Java 属性名 aColumn 的映射;代码如下:

    <configuration>
        
        <settings>
            
            <setting name="mapUnderscoreToCamelCase" value="true"/>
        settings>
    configuration>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    方案二

    在mapper映射文件的< select >标签中利用resultMap处理结果映射。

    方案二有点麻烦,笔者的思路是使用具有实体类映射的方法注解,去映射字段,如果有特殊的字段,如果下划线后是英文,笔者的这个注解方法映射,是可以解决的,但如果下划线后的是数字,那么就要考虑在 使用 SQL 语句时,使用 AS 关键字配置下划线后是数字的字段别名,例如特殊字段 test_1 那么就可以配置别名为 AS test_one,也就可以使用笔者之前的方法 —— 实体类映射数据库字段的注解方法。

    实体类映射数据库字段的注解方法:

    1. 若依框架内的实体类映射注解方法
    import org.springframework.data.mongodb.core.mapping.Field;
    
    • 1
    1. 传统 Javax 实体类映射注解方法
    import javax.persistence.Column;
    
    • 1

    具体实体类映射演示:

    数据库字段:test_id、test_name

    映射

    实体类字段:testId、testName

    import org.springframework.data.mongodb.core.mapping.Field;
    import javax.persistence.Column;
    import lombok.Data;
    
    @Data
    public class TestEntity {
        /**
         * 测试编号
         */
        @Field(name = "test_id")
        private String testId;
        /**
         * 测试姓名
         */
        @Column(name = "test_name")
        private String testName;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    二、下划线_数字 _1 等特殊字段无法映射为实体类的字段问题

    从上面的方案二解释中知道,下划线_数字 名字的字段是无法被映射的,最好的方法是使用 SQL 语句中使用 关键字AS 配置字段的别名。

    具体实体类映射无法映射的问题演示:

    import org.springframework.data.mongodb.core.mapping.Field;
    import javax.persistence.Column;
    import lombok.Data;
    
    @Data
    public class TestEntity {
        /**
         * 测试1
         */
        @Field(name = "test_1")
        private String test1;
        /**
         * 测试2
         */
        @Column(name = "test_2")
        private String test2;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    (实体类 TestEntity 的test1、test2值会是 null 值,无法获取到数据)

    具体的 xml 文件 SQL 别名查询

    <select id="testFunction" resultType="com.test.entity.TestEntity">
    	SELECT test_1 AS test_one, test_2 AS test_two FROM test_table
    select>
    
    
    • 1
    • 2
    • 3
    • 4
    import org.springframework.data.mongodb.core.mapping.Field;
    import javax.persistence.Column;
    import lombok.Data;
    
    @Data
    public class TestEntity {
        /**
         * 测试1
         */
        @Field(name = "test_one")
        private String testOne;
        /**
         * 测试2
         */
        @Column(name = "test_two")
        private String testTwo;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    参考链接

    1. 解决MyBatis不能将表中含有下划线的字段映射到实体属性的两种方案

    2. mybatis+springmvc 搭建的系统——数据库带下划线的字段无法取到值

  • 相关阅读:
    qtcreator警告“unknown type name qapplication”解决
    利用pyhton整理生活中的小事情
    知识点9--容器的数据卷
    发送邮件(三)
    FFmpeg转换器分析-基础篇
    关于使用 vxe-table 时设置了 show-overflow tooltip 不展示的问题(Dialog 组件和 table 同时使用)
    java 版本企业招标投标管理系统源码+多个行业+tbms+及时准确+全程电子化
    Chapter 02 - Let's Get Started(C#篇)
    移远通信新一代LTE智能模组SC200E系列,以强大性能赋能多场景转型
    CLion 2023:专注于C和C++编程的智能IDE mac/win版
  • 原文地址:https://blog.csdn.net/qq_42701659/article/details/132849150
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号