Hybris自定义表每次都被覆盖

时间:2018-04-17 16:48:21

标签: deployment hybris

我在自定义扩展程序中定义了自定义项类型。它使用默认的hsql db。它应该为每个下订单保存所有与交易相关的元数据。但是,每次我从店面下订单时,它都会替换先前存储的数据,因此最后,我只在表格中留下了一行数据。 我试着查看hybris wiki,但找不到任何需要为此设置的属性。

这是我的扩展程序的item.xml文件中的项类型定义

<itemtype code="PaymetricITransHeaderObject2"
              extends="GenericItem"
              autocreate="true"
              generate="true">

        <deployment table="ITransPayLoadTable2" typecode="11011"/>

        <attributes>
             <attribute qualifier="trans_id" type="java.lang.String">
             <modifiers read="true" write="true" search="true" optional="false" unique="true"/>
             <persistence type="property" />
             </attribute>
             <attribute autocreate="true" qualifier="payload" type="java.lang.String">
                <modifiers read="true" write="true" search="true" optional="false"/>
                <persistence type="property">
                <columntype>
                        <value>varchar(8K)</value>
                </columntype>
                </persistence>
            </attribute>

        </attributes>
    </itemtype>

这是一个保存此类型的java代码

 public PaymetricITransHeaderObject2Model iTransactionHeaderObj = new PaymetricITransHeaderObject2Model();
 iTransactionHeaderObj.setTrans_id("1234");
 iTransactionHeaderObj.setPayload("some long string....");
 Transaction tx = Transaction.current();
try
    {
        tx = Transaction.current();
        tx.begin();

        modelService.save(iTransactionHeaderObj);

        tx.commit();

    }
    catch (final Exception e)
    {
        if (null != tx)
        {
            tx.rollback();
        }


        e.printStackTrace();

    }

任何建议都表示赞赏!!
我使用的是Hybris 6.4版本

感谢

1 个答案:

答案 0 :(得分:1)

<attribute qualifier="trans_id" type="java.lang.String">
         <modifiers read="true" write="true" search="true" optional="false" unique="true"/>
         <persistence type="property" />
</attribute>

此处您已将trans_id声明为唯一(unique="true"),因此请确保每次在班级中设置唯一的trans_id时。

像:

 iTransactionHeaderObj.setTrans_id(transGenerator.generate().toString());

查看Persistent Key Generation以生成唯一编号

<强> local.properties

keygen.serialNumber.code.name=serial_number_code
keygen.serialNumber.code.digits=10
keygen.serialNumber.code.start=7000000000
keygen.serialNumber.code.type=numeric
keygen.serialNumber.code.template=$

<强> * spring.xml

<bean id="serialNumberCodeGenerator" class="de.hybris.platform.servicelayer.keygenerator.impl.PersistentKeyGenerator">
    <property name="key" value="${keygen.serialNumber.code.name}"/>
    <property name="digits" value="${keygen.serialNumber.code.digits}"/>
    <property name="start" value="${keygen.serialNumber.code.start}"/>
    <property name="type" value="${keygen.serialNumber.code.type}"/>
    <property name="template" value="${keygen.serialNumber.code.template}"/>
</bean>

<强>的.java

@Resource
private KeyGenerator serialNumberCodeGenerator;

String serialNumber = serialNumberCodeGenerator.generate().toString();