1

我尝试基于A basic ad hoc query example 构建一个基本的 ad hoc 查询示例

但是,我不能插入整数值。我认为是因为这段代码:

private Class getStorageTypeAsClass() {
    switch (getStorageType())
    {
        case STRING:
            return String.class;
        case INTEGER:
            return BigInteger.class;
    }
}

我的代码:

package playorm;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.UUID;

import com.alvazan.orm.api.base.Bootstrap;
import com.alvazan.orm.api.base.DbTypeEnum;
import com.alvazan.orm.api.base.NoSqlEntityManager;
import com.alvazan.orm.api.base.NoSqlEntityManagerFactory;
import com.alvazan.orm.api.z3api.NoSqlTypedSession;
import com.alvazan.orm.api.z8spi.KeyValue;
import com.alvazan.orm.api.z8spi.meta.DboColumnCommonMeta;
import com.alvazan.orm.api.z8spi.meta.DboColumnIdMeta;
import com.alvazan.orm.api.z8spi.meta.DboDatabaseMeta;
import com.alvazan.orm.api.z8spi.meta.DboTableMeta;
import com.alvazan.orm.api.z8spi.meta.TypedColumn;
import com.alvazan.orm.api.z8spi.meta.TypedRow;

public class PlayOrm {
    private static NoSqlEntityManager mgr;

    @SuppressWarnings({ "unchecked", "rawtypes" })
    public static void main(String[] args) {

        Map properties = new HashMap();
        properties.put(Bootstrap.AUTO_CREATE_KEY, "create");

        String clusterName = "Test Cluster";
        String seeds = "localhost:9160";
        String keyspace = "nosql";

        Bootstrap.createAndAddBestCassandraConfiguration(properties, clusterName, keyspace, seeds);
        NoSqlEntityManagerFactory factory = Bootstrap.create(DbTypeEnum.CASSANDRA, properties,null,null);
        mgr = factory.createEntityManager();
        DboDatabaseMeta metaDb = mgr.find(DboDatabaseMeta.class,
                DboDatabaseMeta.META_DB_ROWKEY);
        DboTableMeta meta = new DboTableMeta();
        meta.setup(null, "MyEntity", false);
        metaDb.addMetaClassDbo(meta);

        DboColumnIdMeta idMeta = new DboColumnIdMeta();
        idMeta.setup(meta, "idField", String.class, true);
        mgr.put(idMeta);

        DboColumnCommonMeta fieldDbo = new DboColumnCommonMeta();
        fieldDbo.setup(meta, "firstname", String.class, true, false);
        mgr.put(fieldDbo);
        DboColumnCommonMeta fieldDbo2 = new DboColumnCommonMeta();
        fieldDbo2.setup(meta, "lastname", Integer.class, true, false);
        mgr.put(fieldDbo2);

        mgr.put(meta);
        mgr.flush();

        NoSqlTypedSession session = mgr.getTypedSession();
        for (int i = 0; i < 10000; i++) {
            TypedRow typedRow = session.createTypedRow("MyEntity");
            typedRow.addColumn("firstname", "harry");
                        //**THE PROBLEM**
            typedRow.addColumn("lastname", new Integer(i));
            typedRow.setRowKey(UUID.randomUUID().toString());

            session.put("MyEntity", typedRow);

            if(i > 1000 && (i % 10) == 0 ){
                session.flush();
                mgr.clear();
            }

        }
        session.flush();

}

没有返回 Integer.class 的选项。所以,它不能构造一个整数转换器:

Exception in thread "main" java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at com.alvazan.orm.impl.meta.data.NoSqlProxyImpl.invoke(NoSqlProxyImpl.java:96)
    at com.alvazan.orm.api.z8spi.meta.DboColumnCommonMeta_$$_javassist_1.convertToStorage2(DboColumnCommonMeta_$$_javassist_1.java)
    at com.alvazan.orm.api.z8spi.meta.TypedRow.addColumn(TypedRow.java:99)
    at playorm.PlayOrm.main(PlayOrm.java:62)
Caused by: java.lang.ClassCastException: java.lang.Integer cannot be cast to java.math.BigInteger
    at com.alvazan.orm.api.z8spi.conv.Converters$BigIntegerConverter.convertToNoSqlImpl(Converters.java:89)
    at com.alvazan.orm.api.z8spi.conv.Converters$BaseConverter.convertToNoSql(Converters.java:138)
    at com.alvazan.orm.api.z8spi.meta.DboColumnMeta.convertToStorage2(DboColumnMeta.java:167)
    at com.alvazan.orm.api.z8spi.meta.DboColumnCommonMeta_$$_javassist_1._d8convertToStorage2(DboColumnCommonMeta_$$_javassist_1.java)
    ... 8 more
4

1 回答 1

0

TypedRow 是一个特殊的 api,现在允许 BigInteger、BigDecimal 和 String 类型......但是,这些类型在存储时尽可能存储为最低字节,因此 int 值 10 存储为一个字节。

出于好奇,为什么不使用带有 @NoSqlEntity 注释的 MyEntity.java 类呢???在您的情况下,使用 POJO 似乎更有益。

MyEntity.java 可以有任何原始类型,int、double 等。等等。

我们认为您正在使用实体,因为大多数人使用实体来加快开发速度。

后来,迪恩

于 2013-09-04T14:26:02.107 回答