jpa添加数据后接着查询该数据并不是从数据库中查询,该怎么办?

jpa添加数据后接着查询该数据并不是从数据库中查询,该怎么办?,第1张

--创建一个名称为student的数据库CREATE DATABASE studentGO--打开student.db数据库USE studentGO--建表CREATE TABLE student( _id INT PRIMARY KEY, name VARCHAR(8) NOT NULL, grade FLOAT CHECK(grade>=0 AND grade <=100) NOT NULL)--增加数据INSERT INTO student VALUES(1,'张三',84.5)--查询所有数据SELECT * FROM student--修改“张三”的成绩为90分UPDATE student SET grade=90 WHERE name='张三'--删除表中名字为“张三”数据DELETE FROM student WHERE name='张三'

@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 。

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

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

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

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


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

原文地址: http://outofmemory.cn/sjk/6697690.html

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

发表评论

登录后才能评论

评论列表(0条)

保存