gpt4 book ai didi

java - 错误的 boolean 映射 Hibernate (ArrayIndexOutOfBoundsException)

转载 作者:行者123 更新时间:2023-11-29 10:10:33 25 4
gpt4 key购买 nike

我有一个具有以下属性的持久化 Book 类

  • PropertyName -> HibernateMappingType -> JavaType
  • id -> long -> long
  • 标题 -> 文本 -> 字符串
  • 作者 -> 字符串 -> 字符串
  • systemId -> long -> long
  • 状态 -> boolean 值 -> boolean 值
  • 完整分类 -> 字符串 -> 字符串

我的表描述如下所示: Book Table Diagram

到目前为止一切似乎都很好,但是当我尝试获取表中的所有值时,我收到以下异常消息:

   20:04:43,832 TRACE BasicExtractor:61 - extracted value ([classifi1_1_0_] : [BIGINT]) - [11]
20:04:43,832 TRACE BasicExtractor:61 - extracted value ([collecti1_2_1_] : [BIGINT]) - [11]
20:04:43,833 TRACE BasicExtractor:61 - extracted value ([book_id1_0_2_] : [BIGINT]) - [1]
20:04:43,839 TRACE BasicExtractor:61 - extracted value ([classifi2_1_0_] : [VARCHAR]) - [Prueba]
20:04:43,841 TRACE BasicExtractor:61 - extracted value ([collecti2_2_1_] : [VARCHAR]) - [Prueba]
20:04:43,841 TRACE BasicExtractor:61 - extracted value ([book_tit2_0_2_] : [LONGVARCHAR]) - [Libro de Prueba (No Existe) ]
20:04:43,842 TRACE BasicExtractor:61 - extracted value ([book_aut3_0_2_] : [LONGVARCHAR]) - [Jonathan Pichardo]
20:04:43,842 TRACE BasicExtractor:61 - extracted value ([book_sys4_0_2_] : [BIGINT]) - [190996]
java.lang.ArrayIndexOutOfBoundsException: 57
at com.mysql.cj.mysqla.MysqlaUtils.bitToLong(MysqlaUtils.java:68)
at com.mysql.cj.core.io.MysqlTextValueDecoder.decodeBit(MysqlTextValueDecoder.java:231)
at com.mysql.cj.jdbc.ResultSetRow.decodeAndCreateReturnValue(ResultSetRow.java:170)
at com.mysql.cj.jdbc.ResultSetRow.getValueFromBytes(ResultSetRow.java:269)
at com.mysql.cj.jdbc.BufferRow.getValue(BufferRow.java:349)
at com.mysql.cj.jdbc.ResultSetImpl.getNonStringValueFromRow(ResultSetImpl.java:813)
at com.mysql.cj.jdbc.ResultSetImpl.getBoolean(ResultSetImpl.java:904)
at com.mysql.cj.jdbc.ResultSetImpl.getBoolean(ResultSetImpl.java:908)
at org.hibernate.type.descriptor.sql.BooleanTypeDescriptor$2.doExtract(BooleanTypeDescriptor.java:59)
at org.hibernate.type.descriptor.sql.BasicExtractor.extract(BasicExtractor.java:47)

等等等等

我正在运行的代码是:

session session = SessionFactoryHandler.buildIfNeeded()。 打开 session ();

    Criteria crit = session.createCriteria( Book.class );

crit.list();

session.close();

SessionFactoryHandler.closeFactory();

据我所知,它发生在 status 属性上 我只是不知道为什么,如果我在 xml 中注释映射属性,它会完美地工作,但它总是抛出相同的异常相同的索引 57,它不会影响数据库(只有一个注册表)中该列的值。

映射文件如下:

<hibernate-mapping package="com.cetys.librarymanagement">
<class name="com.cetys.librarymanagement.Core.DomainModels.Book" table="book">
<meta attribute="class-description">
This class contains the whole description of a Book,
according to the specification in ALTAIR system.
</meta>
<id name="id" type="long" column="book_id">
</id>
<property name="title" column="book_title" type="text" length="500" not-null="true"/>
<property name="author" column="book_author" type="text" not-null="true"/>
<property name="systemId" column="book_system_id" type="long" not-null="true"/>
<property name="status" column="book_status" type="boolean" not-null="true"/>
<property name="fullClassification" column="book_full_classification"
type="string" not-null="true"/>

<many-to-one name="classification" column="classification_id"
class="com.cetys.librarymanagement.Core.DomainModels.Classification" not-null="true"
unique="false" cascade="save-update" fetch="join"/>
<many-to-one name="collection" column="collection_id"
class="com.cetys.librarymanagement.Core.DomainModels.Collection" not-null="false"
unique="false" cascade="save-update" fetch="join"/>
</class>
</hibernate-mapping>

有什么想法吗?

最佳答案

据我所知,您正在尝试将数据库中的 BIT 类型映射到 hibernate 代码中的 boolean 值。

从 5.0.3 版本开始,带有 BIT 值的 MySQL 中存在一个错误,因为它不存储单个 BIT 值。它存储类似 SET 或 ENUM 的东西。当您进行数值比较时,这经常会引发问题。有关更多详细信息,请在此处查看

http://www.xaprb.com/blog/2006/04/11/bit-values-in-mysql/

您可以要求您的 DBA 将数据类型更改为 tinyint,但是如果这不可能,您可以将状态映射从 boolean 更改为 numeric_boolean,这样会像

<property name="status" column="book_status" type="numeric_boolean" not-null="true"/>

关于java - 错误的 boolean 映射 Hibernate (ArrayIndexOutOfBoundsException),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37914191/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com