JPA Model字段和数据表字段不一致的问题总结

JPA Model字段和数据表字段不一致的问题总结,第1张

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

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

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

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

很多朋友可能会遇到这样的问题,明明是已经正确配置hbm2dll了,可就是不能正常自动生成数据库。在这个时候,请检查你的entity类的 annotation配置或者hbmxml配置。在hbmxml配置当中,class节点需要根据不同的数据库类型来配置属性,一般情况下只需要如下配置就行

view plaincopy to clipboardprint

<class name="类名" table="表名"> <class name="类名" table="表名">

有时可能还会用到sechema和catalog属性。如:

view plaincopy to clipboardprint

<class name="entityEducate" table="educate" schema="dbo" catalog="HR">

选择开始菜单中→程序→Management SQL Server 2008→SQL Server Management Studio命令,打开SQL Server Management Studio窗口,并使用Windows或 SQL Server身份验证建立连接。

在对象资源管理器窗口中展开服务器,然后选择数据库节点

右键单击数据库节点,从d出来的快捷菜单中选择新建数据库命令。

执行上述 *** 作后,会d出新建数据库对话框。在对话框、左侧有3个选项,分别是常规、选项和文件组。完成这三个选项中的设置会后,就完成了数据库的创建工作,

在数据库名称文本框中输入要新建数据库的名称。例如,这里以“新建的数据库”。

在所有者文本框中输入新建数据库的所有者,如sa。根据数据库的使用情况,选择启用或者禁用使用全文索引复选框。

在数据库文件列表中包括两行,一行是数据库文件,而另一行是日记文件。通过单击下面的添加、删除按钮添加或删除数据库文件。

切换到选项页、在这里可以设置数据库的排序规则、恢复模式、兼容级别和其他属性。

切换到文件组页,在这里可以添加或删除文件组。

完成以上 *** 作后,单击确定按钮关闭新建数据库对话框。至此“新建的数据”数据库创建成功。新建的数据库可以再对象资源管理器窗口看到。

@Transient

两位 看清楚了再说好么

楼主的问题是使用JPA注解如何能使一个Entity中的属性作为普通属性而不成为数据表中的某个字段。。。

@Transient表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性

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

以上就是关于JPA Model字段和数据表字段不一致的问题总结全部的内容,包括:JPA Model字段和数据表字段不一致的问题总结、jpa为什么有些实体类会自动建表有些不自动建表、数据库表已存在 jpa自动创建么等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: https://outofmemory.cn/sjk/9737482.html

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

发表评论

登录后才能评论

评论列表(0条)

保存