jpa 参数绑定布尔类型
ANSI SQL 1999标准引入了BOOLEAN数据类型(尽管遗憾的是仅作为可选功能)。 但是到目前为止,大多数主要的数据库系统仍未实现它。 结果,布尔列以各种方式实现。 例如,包含“ Y”或“ N”的CHAR列,或使用BIT列。 随后,JPA无法提供将实体的布尔字段映射到数据库列的标准化方法。
Hibernate为使用包含“ Y”或“ N”字符的CHAR(1)列的布尔实现提供了一个自定义YesNoType。 但是对于其他实践,您基本上必须提供自己的解决方案。 幸运的是,Hibernate提供了创建自己的自定义UserType的可能性。 在此博客条目中,我将提供一个这样的自定义布尔UserType的示例。
最近,我遇到了一个荷兰传统数据库架构,其中“ Y”(表示“是”)和“ N”(表示“否”)分别由“ J”(“ ja”)和“ N”(“ nee”)表示, 分别。 这排除了使用Hibernate的YesNoType。 更复杂的是,其中有些列使用CHAR(1),另一些使用带有填充空间的CHAR(2)–不要问为什么!
因此,我最终编写了一个自定义UserType,使我基本上可以转换以下内容…
起点