什么是用于referencedColumnName在JPA

什么是用于referencedColumnName在JPA,第1张

贴注解代码··怀疑你关联写错了,JPA里关联写的是数据库字段名·· @JoinColumn(name = "brand_id", referencedColumnName = "id") 这里name是本类(表)在数据库的字段名,referencedColumnName 是关联类(表)在数据库中的关联字段名

建立主键有两种方法:一种是在数据库提供的GUI环境中建立,另一种是通过SQL语句执行建立,下面分别介绍。
1在数据库提供的GUI环境中建立(以SQL7为例)。
输入表信息后按Ctrl键同时选中多行,然后点上面的主键按钮就行了。
2通过SQL语句执行建立。又分两种,一是在建表语句中直接写,二是建表之后更改表结构。
在建表语句中直接写:
Create Table 表名 (字段名1 Int Not Null,
字段名2 nvarchar(13) Not Null Primary Key (字段名1, 字段名2),
字段名3字段名N )建表之后更改表结构:
CREATE TABLE 表名 (字段名1 Int Not Null,
字段名2 nvarchar(13) Not Null字段名3字段名N)GOALTER TABLE 表名 WITH NOCHECK ADD
CONSTRAINT [PK_表名] PRIMARY KEY NONCLUSTERED([字段名1],

当Model字段的名称和数据表的字段名称对应不上的时候会出现异常

当Model的字段总数小于数据表字段的总数的时候,是没有问题的。

当Model的字段总数多余数据表字段的总数的时候,会出现异常。

原因是查询的时候会将model的属性当成SQL检索的字段,如果字段不一样,或者属性名称不存在数据表字段里,就会报字段不存在的错误。

No1:之前项目中hibernate对Integer参数注入String类型值进行模糊查询,并不会抛出异常。最近接触Spring Data JPA在写demo的过程中发现JPA对Integer的模糊查询支持比较差,无论是简单查询还是复杂查询均不支持。
注:equal无影响,仍可使用String参数注入
No2:自定义接口方法中,属性有几个,则参数要有几个。
注意:多了也不行
No3:查看JpaRepository具体实现类可发现在repository层已加事务,但是如何在service层控制事务?:

简单查询(zipCode是Integer类型):

复杂查询(假设sex也是zipCode):

mysql:

两个属性,一个参数

两个属性,两个参数

正常 *** 作结果会导致数据不回滚,正常插入

增加@Transactional,则数据回滚

1虽然说正常情况下Integer是不应该模糊查询的,但是也许就有用到。当使用JPA开发项目时,可能需要模糊查询的字段,尽量用String。

@Version @Version 默认情况下,JPA 持续性提供程序假设应用程序负责数据一致性。 使用 @Version 批注通过指定用作其乐观锁定值的实体类的版本字段或属性来 启用 JPA 管理的乐观锁定(推荐做法)。 选择版本字段或属性时,确保: · · 每个实体只有一个版本字段或属性 选择一个持久保存到主表的属性或字段(请参阅 @Table ) · 您的应用程序不修改版本属性或字段 此批注没有属性。有关更多详细信息,请参阅 API 。 示例 1-91 显示了如何使用此批注将属性 getVersionNum 指定为乐观锁定值。 在该示例中,该属性的列名设置为 OPTLOCK (请参阅 @Column ),而非属性的 默认列名。 示例 1-91 @Version @Entity public class Employee implements Serializable { @Version @Column(name="OPTLOCK") protected int getVersionNum() { return versionNum; } } @Column 默认情况下, JPA 持续性提供程序假设每个实体的持久字段存储在其名称与持久 字段的名称相匹配的数据库表列中。 使用 @Column 批注: 将持久字段与其他名称关联(如果默认列名难于处理、与事先存在的数据 模型不兼容或作为数据库中的列名无效) 将持久字段与辅助表中的列关联(请参阅 @SecondaryTable ) 微调数据库中列的特征 表 1-7 列出了此批注的属性。有关更多详细信息,请参阅 API 。 表 1-7 @Column 属性 属性 columnDefinition 必 需 说明 默认值:空 String 。 默认情况下,JPA 使用最少量 SQL 创建一个数据库表 列。 如果需要使用更多指定选项创建的列,请将 columnDefinition 设置为在针对列生成 DDL 时希望 JPA 使用的 SQL 片断。 注意:捕获批注中的 DDL 信息时,某些 JPA 持续性提 供程序可以在生成数据库模式时使用此 DDL 。

应该使用User类的属性名:sumScore,而不是使用数据库表的字段名sum_score

看一下Spring的orgspringframeworkdatajparepositoryqueryQueryUtils

方法toJpaOrder的第一行

PropertyPath property = PropertyPathfrom(ordergetProperty(), fromgetJavaType());

由于Spring在解析你的排序条件时自身使用下划线作为字段匹配的分隔符

 SPLITTERmatcher("_" + itpath);
while(matcherfind()) {
    iteratorSourceadd(matchergroup(1));
}

所以sum_score会被它拆成两个字段sum和score,而你的表里没有这两个字段,所以会报错。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/13399974.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-07-29
下一篇 2023-07-29

发表评论

登录后才能评论

评论列表(0条)

保存