栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

持久性@Column nullable = false可以插入null

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

持久性@Column nullable = false可以插入null

我认为如果您使用EntityManager的实现生成模式,则会使用可为空的。我不知道是否也必须在持久化实体时对其进行验证。

如果使用@NotNull批注可能会有所帮助,但这不是普通的JPA。它在JSR-303中定义


编辑:在JPA 2.1规范中,有此部分:

11.2.2.1列
在架构生成中使用了列注释的以下元素:
名称
唯一的
可为空的 列定义
表的
长度(仅字符串值的列)精度(仅精确的数字(十进制/数字)列)规模(精确的数字(十进制/数字)
)(仅限列))有关适用于这些元素和列创建的规则,请参见11.1.9节。AttributeOverride批注可用于覆盖列映射。

因为没有给出其他提示,所以我假设以下内容:如果遵循JPA的EntityManager创建架构,则它必须通过使用与数据库等效的约束(例如notnull)在特定列上应用可为空的约束。
,则Entitymanager BUT不会通过基础数据库对其进行检查。因此,如果数据库引发错误,则EntityManager将此错误传播到调用者。

如果您在不使用DB可为空的约束的情况下自行创建表,则entitymanager会尝试保留该实体,并且不会出现错误->持久化还可以,但是有些空值不应该存在。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/439026.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号