2018-09-25 解决springdatajpa 在解析实体类的字段时候驼峰自动转为下划线问题

解决springdatajpa 在解析实体类的字段时候驼峰自动转为下划线问题

问题描述

springboot 在配置jpa时,利用idea自带工具逆向工程生成实体类,结果在调用findOne的时候,报错
错误内容如下所示:

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column 'shasset0_.asset_type_name' in 'field list'
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) ~[na:1.7.0_80]
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57) ~[na:1.7.0_80]
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) ~[na:1.7.0_80]
    at java.lang.reflect.Constructor.newInstance(Constructor.java:526) ~[na:1.7.0_80]
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:425) ~[mysql-connector-java-5.1.47.jar:5.1.47]
    at com.mysql.jdbc.Util.getInstance(Util.java:408) ~[mysql-connector-java-5.1.47.jar:5.1.47]

实体类片段

@Entity
@Table(name = "sh_asset")
public class ShAsset {
    private String id;
    private String assetTypeName;
    private String assetName;
    private String assetCode;
    private String assetType;
    private String area;
    private String orgname;
    private String username;
    private String contract;
    private String address;
    private String recorderId;
    private String recorderName;
    private Timestamp recorddate;
    private String iPadd;
    private Timestamp editTime;
    private Integer assetStatus;
    private String maCadd;
    private Date userDate;
    private Integer leaseState;

    @Id
    @Column(name = "id")
    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    @Basic
    @Column(name = "asset_typeName")
    public String getAssetTypeName() {
        return assetTypeName;
    }

    public void setAssetTypeName(String assetTypeName) {
        this.assetTypeName = assetTypeName;
    }

问题原因

由于springboot 中jpa默认自动将实体类中的驼峰命名转化为下划线隔开的方式进行数据库查询,将字段getAssetTypeName自动转换为 asset_type_name导致数据库找不到该字段

解决办法

在配置文件中取消自动将驼峰命名转为下划线形式

 jpa:
    hibernate:
      naming:
        physical-strategy: org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本章是《 Spring Boot 快速入门 》系列教程的第三章,若要查看本系列的全部章节,请点击 这里 。 目录...
    terran4j阅读 5,932评论 4 10
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,971评论 6 342
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • 2017年8月21日 我原本只想简单记录一下springboot中应用Jpa的简单操作。不想由于hibernate...
    行者N阅读 6,531评论 0 23
  • title: 【翻译】SpringData官方文档第四章date: 2016-11-27tags: 翻译categ...
    zhanghTK阅读 1,331评论 0 1