简体   繁体   中英

how to resolve "IllegalArgumentException occurred while calling setter for property"?

I'm trying get all the entries from Messages table using criteria

Criteria getCriteria = session.createCriteria(MessageAttributes.class);
List<MessageAttributes> unProcessedJcbMessagesList=getCriteria.list(); 

I'm getiing following exception when I'm trying run above criteria. FieldId is the foreign key from AvailableFields(AvailableFieldsIs) table.

  IllegalArgumentException occurred while calling setter for property [com.alu.jcb.model.MessageAttributes.fieldId (expected type = com.alu.jcb.model.AvailableFields)]; target = [com.alu.jcb.model.MessageAttributes@1cf3877], property value = [2]
    at org.hibernate.property.BasicPropertyAccessor$BasicSetter.set(BasicPropertyAccessor.java:123)
    at org.hibernate.tuple.entity.AbstractEntityTuplizer.setPropertyValues(AbstractEntityTuplizer.java:713)
    at org.hibernate.tuple.entity.PojoEntityTuplizer.setPropertyValues(PojoEntityTuplizer.java:362)
    at org.hibernate.persister.entity.AbstractEntityPersister.setPropertyValues(AbstractEntityPersister.java:4718)
    at org.hibernate.engine.internal.TwoPhaseLoad.doInitializeEntity(TwoPhaseLoad.java:188)
    at org.hibernate.engine.internal.TwoPhaseLoad.initializeEntity(TwoPhaseLoad.java:144)
    at org.hibernate.loader.Loader.initializeEntitiesAndCollections(Loader.java:1115)
    at org.hibernate.loader.Loader.processResultSet(Loader.java:973)
    at org.hibernate.loader.Loader.doQuery(Loader.java:921)
    at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:355)
    at org.hibernate.loader.Loader.doList(Loader.java:2554)
    at org.hibernate.loader.Loader.doList(Loader.java:2540)
    at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2370)
    at org.hibernate.loader.Loader.list(Loader.java:2365)
    at org.hibernate.loader.criteria.CriteriaLoader.list(CriteriaLoader.java:126)
    at org.hibernate.internal.SessionImpl.list(SessionImpl.java:1718)
    at org.hibernate.internal.CriteriaImpl.list(CriteriaImpl.java:380)
    at com.alu.jcb.messageProcessor.Test.main(Test.java:23)
Caused by: java.lang.IllegalArgumentException: argument type mismatch
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.hibernate.property.BasicPropertyAccessor$BasicSetter.set(BasicPropertyAccessor.java:68)
    ... 17 more

Beans

MessageAttributes.java

public class MessageAttributes {
    private long messageAttributeId=1L;
    private AvailableFields fieldId;
    private String value;
//getters and setters
}

AvailableFields.java

public class AvailableFields {

    private long availableFieldsId=1L;
    private Instance instance;
    private String fieldDisplayName;

//getters and setters
}

HBM files MessageAttributes.hbm.xml

<hibernate-mapping package="com.alu.jcb.model">
    <class name="MessageAttributes" table="MESSAGE_ATTRIBUTES">
        <id name="messageAttributeId" column="message_attribute_id" type="long">
            <generator class="sequence" />
        </id>

        <many-to-one name="fieldId" class="com.alu.jcb.model.AvailableFields" fetch="select">
            <column name="field_id" not-null="true" />
        </many-to-one>

        <property name="value" type="string" column="value" />                          
    </class>
</hibernate-mapping>

AvailableFields.hbm.xml

<hibernate-mapping package="com.alu.jcb.model">
    <class name="AvailableFields" table="AVAILABLE_FIELDS">
         <id name="availableFieldsId" column="available_fields_id" type="java.lang.Long">
            <generator class="sequence" />
        </id>
        <many-to-one name="instance" class="com.alu.jcb.model.Instance" fetch="select">
            <column name="instance_id" not-null="true" />
        </many-to-one>
        <property name="fieldDisplayName" type="string" column="field_display_name" not-null="true"/>
    </class>
</hibernate-mapping>

Please help me

The error means something wrong with setter of fieldId . It should be like this

public void setFieldId(AvailableFields fieldId) {
   this.fieldId=fieldId;
}

but it seems in your case incorrect class (guess long) is used in the setter.

SQLQuery sqlquery=session.createSQLQuery(queryString);

sqlquery.addScalar("fieldId ", IntegerType.INSTANCE);

I was receiving this error of

IllegalArgumentException occurred while calling setter for property Version (type expected is Long but received 0)

because instead of using

Query query = sess.createSQLQuery(sqlQueryStr).addEntity(instance.getClass().getName());
retval = query.list();

I was doing

Query query = sess.createSQLQuery(sqlQueryStr)
        .setResultTransformer(Transformers.aliasToBean(instance.getClass()));
    retval = query.list();

In case it helps anyone.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM